summaryrefslogtreecommitdiff
path: root/sql/log.cc
diff options
context:
space:
mode:
authorLuis Soares <luis.soares@oracle.com>2010-12-17 01:29:53 +0000
committerLuis Soares <luis.soares@oracle.com>2010-12-17 01:29:53 +0000
commit246b4be056d9e276f9bc5198da64aba2f0d323b8 (patch)
tree05f39946e5563553c44625023f6e9823cd79b244 /sql/log.cc
parentb4fe0e0cb3cd9bb1c67c3cde90c11cd455e914eb (diff)
parent4c0c5525825714ccd91c3c07e303c068bcc12ce5 (diff)
downloadmariadb-git-246b4be056d9e276f9bc5198da64aba2f0d323b8.tar.gz
BUG#46166
Automerge from mysql-5.1-bugteam.
Diffstat (limited to 'sql/log.cc')
-rw-r--r--sql/log.cc18
1 files changed, 18 insertions, 0 deletions
diff --git a/sql/log.cc b/sql/log.cc
index e6f476fd8a1..b9be66f8ce7 100644
--- a/sql/log.cc
+++ b/sql/log.cc
@@ -2976,6 +2976,23 @@ bool MYSQL_BIN_LOG::open(const char *log_name,
sync_purge_index_file() ||
DBUG_EVALUATE_IF("fault_injection_registering_index", 1, 0))
{
+ /**
+ TODO: although this was introduced to appease valgrind
+ when injecting emulated faults using fault_injection_registering_index
+ it may be good to consider what actually happens when
+ open_purge_index_file succeeds but register or sync fails.
+
+ Perhaps we might need the code below in MYSQL_LOG_BIN::cleanup
+ for "real life" purposes as well?
+ */
+ DBUG_EXECUTE_IF("fault_injection_registering_index", {
+ if (my_b_inited(&purge_index_file))
+ {
+ end_io_cache(&purge_index_file);
+ my_close(purge_index_file.file, MYF(0));
+ }
+ });
+
sql_print_error("MSYQL_BIN_LOG::open failed to sync the index file.");
DBUG_RETURN(1);
}
@@ -4219,6 +4236,7 @@ int MYSQL_BIN_LOG::new_file_impl(bool need_lock)
if(DBUG_EVALUATE_IF("fault_injection_new_file_rotate_event", (error=close_on_error=TRUE), FALSE) ||
(error= r.write(&log_file)))
{
+ DBUG_EXECUTE_IF("fault_injection_new_file_rotate_event", errno=2;);
close_on_error= TRUE;
my_printf_error(ER_ERROR_ON_WRITE, ER(ER_CANT_OPEN_FILE), MYF(ME_FATALERROR), name, errno);
goto end;