summaryrefslogtreecommitdiff
path: root/sql/mysql_priv.h
diff options
context:
space:
mode:
authorMikael Ronstrom <mikael@mysql.com>2009-10-12 11:00:39 +0200
committerMikael Ronstrom <mikael@mysql.com>2009-10-12 11:00:39 +0200
commitbae553cfcd9ad8b9df8b5305736f6810fbaed43b (patch)
treeb9c258d33b8f1dd330ba73287a648ffbd20488d7 /sql/mysql_priv.h
parenta4785fc4a2abeb3f8fbc253b78f558540b949482 (diff)
downloadmariadb-git-bae553cfcd9ad8b9df8b5305736f6810fbaed43b.tar.gz
Backported my_atomic from 6.0-codebase and added support for 64-bit atomics to enable removal of LOCK_thread_count from every query, removed LOCK_thread_count from use in dispatch_command and close of query which is used in every query, now uses atomic increments/decrements instead
Diffstat (limited to 'sql/mysql_priv.h')
-rw-r--r--sql/mysql_priv.h45
1 files changed, 42 insertions, 3 deletions
diff --git a/sql/mysql_priv.h b/sql/mysql_priv.h
index cd1a31f0fab..ff6d3578406 100644
--- a/sql/mysql_priv.h
+++ b/sql/mysql_priv.h
@@ -43,6 +43,7 @@
#include "sql_array.h"
#include "sql_plugin.h"
#include "scheduler.h"
+#include <my_atomic.h>
class Parser_state;
@@ -75,11 +76,49 @@ typedef ulong nesting_map; /* Used for flags of nesting constructs */
typedef ulonglong nested_join_map;
/* query_id */
-typedef ulonglong query_id_t;
+typedef int64 query_id_t;
extern query_id_t global_query_id;
+extern int32 thread_running;
+extern my_atomic_rwlock_t global_query_id_lock;
/* increment query_id and return it. */
-inline query_id_t next_query_id() { return global_query_id++; }
+inline query_id_t next_query_id()
+{
+ query_id_t id;
+ id= my_atomic_add64(&global_query_id, 1);
+ return (id+1);
+}
+
+inline query_id_t get_query_id()
+{
+ query_id_t id;
+ id= my_atomic_load64(&global_query_id);
+ return id;
+}
+
+inline int32
+inc_thread_running()
+{
+ int32 num_thread_running;
+ num_thread_running= my_atomic_add32(&thread_running, 1);
+ return (num_thread_running+1);
+}
+
+inline int32
+dec_thread_running()
+{
+ int32 num_thread_running;
+ num_thread_running= my_atomic_add32(&thread_running, -1);
+ return (num_thread_running-1);
+}
+
+inline int32
+get_thread_running()
+{
+ int32 num_thread_running;
+ num_thread_running= my_atomic_load32(&thread_running);
+ return num_thread_running;
+}
/* useful constants */
extern MYSQL_PLUGIN_IMPORT const key_map key_map_empty;
@@ -1994,7 +2033,7 @@ extern bool opt_ignore_builtin_innodb;
extern my_bool opt_character_set_client_handshake;
extern bool volatile abort_loop, shutdown_in_progress;
extern bool in_bootstrap;
-extern uint volatile thread_count, thread_running, global_read_lock;
+extern uint volatile thread_count, global_read_lock;
extern uint connection_count;
extern my_bool opt_sql_bin_update, opt_safe_user_create, opt_no_mix_types;
extern my_bool opt_safe_show_db, opt_local_infile, opt_myisam_use_mmap;