summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorpetr@mysql.com <>2006-04-18 08:47:22 +0400
committerpetr@mysql.com <>2006-04-18 08:47:22 +0400
commit423119d21463ffdd38b1775d25a9e590d4f18b6b (patch)
treea44c13fabdb0798717f5dcb15b5cafad04e978c8
parentac6450b85895c360b19fd50f68abe75d01a91f38 (diff)
parentde97f94a49ce139b630b344c39958ea3b92ceeea (diff)
downloadmariadb-git-423119d21463ffdd38b1775d25a9e590d4f18b6b.tar.gz
Merge pchardin@bk-internal.mysql.com:/home/bk/mysql-5.1-new
into mysql.com:/home/cps/mysql/trees/mysql-5.1-virgin
-rw-r--r--sql/log.cc38
1 files changed, 27 insertions, 11 deletions
diff --git a/sql/log.cc b/sql/log.cc
index 3f6e3108a0b..818abe89e02 100644
--- a/sql/log.cc
+++ b/sql/log.cc
@@ -676,20 +676,36 @@ bool LOGGER::flush_logs(THD *thd)
/* reopen log files */
file_log_handler->flush();
- /*
- this will lock and wait for all but the logger thread to release the
- tables. Then we could reopen log tables. Then release the name locks.
- */
- lock_and_wait_for_table_name(thd, &close_slow_log);
- lock_and_wait_for_table_name(thd, &close_general_log);
+ /* flush tables, in the case they are enabled */
+ if (logger.is_log_tables_initialized)
+ {
+ /*
+ This will lock and wait for all but the logger thread to release the
+ tables. Then we could reopen log tables. Then release the name locks.
+
+ NOTE: in fact, the first parameter used in lock_and_wait_for_table_name()
+ and table_log_handler->flush() could be any non-NULL THD, as the
+ underlying code makes certain assumptions about this.
+ Here we use one of the logger handler THD's. Simply because it
+ seems appropriate.
+ */
+ lock_and_wait_for_table_name(table_log_handler->general_log_thd,
+ &close_slow_log);
+ lock_and_wait_for_table_name(table_log_handler->general_log_thd,
+ &close_general_log);
- /* deny others from logging to general and slow log, while reopening tables */
- logger.lock();
+ /*
+ Deny others from logging to general and slow log,
+ while reopening tables.
+ */
+ logger.lock();
- table_log_handler->flush(thd, &close_slow_log, &close_general_log);
+ table_log_handler->flush(table_log_handler->general_log_thd,
+ &close_slow_log, &close_general_log);
- /* end of log tables flush */
- logger.unlock();
+ /* end of log tables flush */
+ logger.unlock();
+ }
return FALSE;
}