summaryrefslogtreecommitdiff
path: root/sql/sql_manager.cc
diff options
context:
space:
mode:
authorunknown <tim@threads.polyesthetic.msg>2000-11-28 13:46:59 -0500
committerunknown <tim@threads.polyesthetic.msg>2000-11-28 13:46:59 -0500
commit53c0d95e924c7ea8ef67af2c85856c2e26b6d2da (patch)
treedeea4395a31d3b03972297e4c33d6f7def1e6a9d /sql/sql_manager.cc
parentc1fdd5b55afab11e981929519b96294cac4f1e04 (diff)
parent289244acf3e507ee4951edc4df816ba4e6f35a24 (diff)
downloadmariadb-git-53c0d95e924c7ea8ef67af2c85856c2e26b6d2da.tar.gz
Merge work.mysql.com:/home/bk/mysql
into threads.polyesthetic.msg:/usr/local/src/my/work Docs/manual.texi: Auto merged sql/mysql_priv.h: Auto merged sql/mysqld.cc: Auto merged
Diffstat (limited to 'sql/sql_manager.cc')
-rw-r--r--sql/sql_manager.cc101
1 files changed, 101 insertions, 0 deletions
diff --git a/sql/sql_manager.cc b/sql/sql_manager.cc
new file mode 100644
index 00000000000..13fef76d4ab
--- /dev/null
+++ b/sql/sql_manager.cc
@@ -0,0 +1,101 @@
+/* Copyright (C) 2000 MySQL AB & MySQL Finland AB & TCX DataKonsult AB
+
+ This program is free software; you can redistribute it and/or modify
+ it under the terms of the GNU General Public License as published by
+ the Free Software Foundation; either version 2 of the License, or
+ (at your option) any later version.
+
+ This program is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU General Public License for more details.
+
+ You should have received a copy of the GNU General Public License
+ along with this program; if not, write to the Free Software
+ Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA */
+
+/*
+ * sql_manager.cc
+ * This thread manages various maintenance tasks.
+ *
+ * o Flushing the tables every flush_time seconds.
+ * o Berkeley DB: removing unneeded log files.
+ */
+
+#include "mysql_priv.h"
+#include "sql_manager.h"
+
+ulong manager_status;
+bool volatile manager_thread_in_use;
+
+pthread_t manager_thread;
+pthread_mutex_t LOCK_manager;
+pthread_cond_t COND_manager;
+
+pthread_handler_decl(handle_manager,arg __attribute__((unused)))
+{
+ int error = 0;
+ ulong status;
+ struct timespec abstime;
+ bool reset_flush_time = TRUE;
+ my_thread_init();
+ DBUG_ENTER("handle_manager");
+
+ pthread_detach_this_thread();
+ manager_thread = pthread_self();
+ manager_status = 0;
+ manager_thread_in_use = 1;
+
+ for (;;)
+ {
+ pthread_mutex_lock(&LOCK_manager);
+ /* XXX: This will need to be made more general to handle different
+ * polling needs. */
+ if (flush_time)
+ {
+ if (reset_flush_time)
+ {
+#ifdef HAVE_TIMESPEC_TS_SEC
+ abstime.ts_sec = time(NULL)+flush_time; // Bsd 2.1
+ abstime.ts_nsec = 0;
+#else
+ abstime.tv_sec = time(NULL)+flush_time; // Linux or Solairs
+ abstime.tv_nsec = 0;
+#endif
+ reset_flush_time = FALSE;
+ }
+ while (!manager_status && !error && !abort_loop)
+ error = pthread_cond_timedwait(&COND_manager, &LOCK_manager, &abstime);
+ }
+ else
+ while (!manager_status && !error && !abort_loop)
+ error = pthread_cond_wait(&COND_manager, &LOCK_manager);
+ status = manager_status;
+ manager_status = 0;
+ pthread_mutex_unlock(&LOCK_manager);
+
+ if (abort_loop)
+ break;
+
+ if (error) /* == ETIMEDOUT */
+ {
+ flush_tables();
+ error = 0;
+ reset_flush_time = TRUE;
+ }
+
+#ifdef HAVE_BERKELEY_DB
+ if (status & MANAGER_BERKELEY_LOG_CLEANUP)
+ {
+ berkeley_cleanup_log_files();
+ status &= ~MANAGER_BERKELEY_LOG_CLEANUP;
+ }
+#endif
+
+ if (status)
+ DBUG_PRINT("error", ("manager did not handle something: %lx", status));
+ }
+ manager_thread_in_use = 0;
+ my_thread_end();
+ DBUG_RETURN(NULL);
+}