summaryrefslogtreecommitdiff
path: root/libmysqld/lib_sql.cc
diff options
context:
space:
mode:
Diffstat (limited to 'libmysqld/lib_sql.cc')
-rw-r--r--libmysqld/lib_sql.cc884
1 files changed, 22 insertions, 862 deletions
diff --git a/libmysqld/lib_sql.cc b/libmysqld/lib_sql.cc
index d764aefa210..a6029ccc3c1 100644
--- a/libmysqld/lib_sql.cc
+++ b/libmysqld/lib_sql.cc
@@ -36,7 +36,7 @@ static char inited, org_my_init_done;
#define SCRAMBLE_LENGTH 8
C_MODE_START
-#include "lib_vio.c"
+#include <mysql.h>
#include "errmsg.h"
static int check_connections1(THD * thd);
@@ -50,199 +50,41 @@ char * get_mysql_real_data_home(){ return mysql_real_data_home;};
my_bool simple_command(MYSQL *mysql,enum enum_server_command command, const char *arg,
ulong length, my_bool skipp_check)
{
- NET *net= &mysql->net;
my_bool result= 1;
- THD *thd=(THD *) net->vio->dest_thd;
+ THD *thd=(THD *) mysql->thd;
/* Check that we are calling the client functions in right order */
if (mysql->status != MYSQL_STATUS_READY)
{
- strmov(net->last_error,ER(mysql->net.last_errno=CR_COMMANDS_OUT_OF_SYNC));
+ strmov(thd->net.last_error,ER(thd->net.last_errno=CR_COMMANDS_OUT_OF_SYNC));
return 1;
}
/* Clear result variables */
- mysql->net.last_error[0]=0;
- mysql->net.last_errno=0;
- mysql->info=0;
+ thd->net.last_error[0]=0;
+ thd->net.last_errno=0;
mysql->affected_rows= ~(my_ulonglong) 0;
- /* Clear receive buffer and vio packet list */
- net_clear(net);
- vio_reset(net->vio);
-
thd->store_globals(); // Fix if more than one connect
-// thd->net.last_error[0]=0; // Clear error message
-// thd->net.last_errno=0;
-
- net_new_transaction(net);
result= dispatch_command(command, thd, (char *) arg, length + 1);
if (!skipp_check)
- result= net->last_errno ? -1 : 0;
+ result= thd->net.last_errno ? -1 : 0;
+ mysql->last_error= thd->net.last_error;
+ mysql->last_errno= thd->net.last_errno;
return result;
}
-#ifdef _DUMMY
-void lib_connection_phase(NET * net, int phase)
-{
- THD * thd;
- thd = (THD *)(net->vio->dest_thd);
- if (thd)
- {
- switch (phase)
- {
- case 2:
- check_connections2(thd);
- break;
- }
- }
-}
C_MODE_END
-
-void start_embedded_conn1(NET * net)
+void THD::clear_error()
{
- THD * thd = new THD;
- my_net_init(&thd->net,NULL);
- /* if (protocol_version>9) */
- thd->net.return_errno=1;
- thd->thread_id = thread_id++;
-
- Vio * v = net->vio;
- if (!v)
- {
- v = vio_new(0,VIO_BUFFER,0);
- net->vio = v;
- }
- if (v)
- {
- v -> dest_thd = thd;
- }
- thd->net.vio = v;
- if (thd->store_globals())
- {
- fprintf(stderr,"store_globals failed.\n");
- return;
- }
-
- thd->mysys_var=my_thread_var;
- thd->dbug_thread_id=my_thread_id();
- thd->thread_stack= (char*) &thd;
-
- if (thd->variables.max_join_size == (ulong) HA_POS_ERROR)
- thd->options |= OPTION_BIG_SELECTS;
-
- thd->proc_info=0; // Remove 'login'
- thd->command=COM_SLEEP;
- thd->version=refresh_version;
- thd->set_time();
- bzero(thd->scramble, sizeof(thd->scramble));
- init_sql_alloc(&thd->mem_root,8192,8192);
-
- check_connections1(thd);
-}
-
-static int
-check_connections1(THD *thd)
-{
- uint connect_errors=0;
- NET *net= &thd->net;
- /*
- ** store the connection details
- */
- DBUG_PRINT("info", (("check_connections called by thread %d"),
- thd->thread_id));
- DBUG_PRINT("general",("New connection received on %s",
- vio_description(net->vio)));
- if (!thd->host) // If TCP/IP connection
- {
- thd->host=(char*) localhost;
- }
- else /* Hostname given means that the connection was on a socket */
- {
- DBUG_PRINT("general",("Host: %s",thd->host));
- thd->ip=0;
- bzero((char*) &thd->remote,sizeof(struct sockaddr));
- }
- //vio_keepalive(net->vio, TRUE);
-
- /* nasty, but any other way? */
- uint pkt_len = 0;
-
- char buff[80],*end;
- int client_flags = CLIENT_LONG_FLAG | CLIENT_CONNECT_WITH_DB |
- CLIENT_TRANSACTIONS;
- LINT_INIT(pkt_len);
-
- end=strmov(buff,server_version)+1;
- int4store((uchar*) end,thd->thread_id);
- end+=4;
- memcpy(end,thd->scramble,SCRAMBLE_LENGTH+1);
- end+=SCRAMBLE_LENGTH +1;
- int2store(end,client_flags);
- end[2]=MY_CHARSET_CURRENT;
- int2store(end+3,thd->server_status);
- bzero(end+5,13);
- end+=18;
- if (net_write_command(net,protocol_version,
- NullS, 0,
- buff, (uint) (end-buff)))
- {
- inc_host_errors(&thd->remote.sin_addr);
- return(ER_HANDSHAKE_ERROR);
- }
- return 0;
+ net.last_error[0]= 0;
+ net.last_errno= 0;
+ net.report_error= 0;
}
-#define MIN_HANDSHAKE_SIZE 6
-
-static int
-check_connections2(THD * thd)
-{
- uint connect_errors=0;
- uint pkt_len = 0;
- NET * net = &thd -> net;
- if (protocol_version>9) net -> return_errno=1;
-
- if ( (pkt_len=my_net_read(net)) == packet_error ||
- pkt_len < MIN_HANDSHAKE_SIZE)
- {
- inc_host_errors(&thd->remote.sin_addr);
- return(ER_HANDSHAKE_ERROR);
- }
-
-#ifdef _CUSTOMCONFIG_
-#include "_cust_sql_parse.h"
-#endif
- if (connect_errors)
- reset_host_errors(&thd->remote.sin_addr);
- if (thd->packet.alloc(thd->variables.net_buffer_length))
- return(ER_OUT_OF_RESOURCES);
-
- thd->client_capabilities=uint2korr(net->read_pos);
-
- thd->max_client_packet_length=uint3korr(net->read_pos+2);
- char *user= (char*) net->read_pos+5;
- char *passwd= strend(user)+1;
- char *db=0;
- if (passwd[0] && strlen(passwd) != SCRAMBLE_LENGTH)
- return ER_HANDSHAKE_ERROR;
- if (thd->client_capabilities & CLIENT_CONNECT_WITH_DB)
- db=strend(passwd)+1;
- if (thd->client_capabilities & CLIENT_TRANSACTIONS)
- thd->net.return_status= &thd->server_status;
- net->read_timeout=thd->variables.net_read_timeout;
- if (check_user(thd,COM_CONNECT, user, passwd, db, 1))
- return (-1);
- thd->password=test(passwd[0]);
- return 0;
-}
-#else
-C_MODE_END
-#endif /* _DUMMY */
-
static bool check_user(THD *thd,enum_server_command command, const char *user,
const char *passwd, const char *db, bool check_count)
{
@@ -430,581 +272,6 @@ int STDCALL mysql_server_init(int argc, char **argv, char **groups)
return 0;
}
-
-#ifdef __DUMMY
-int STDCALL mysql_server_init(int argc, char **argv, char **groups)
-{
- char glob_hostname[FN_REFLEN];
-
- /* This mess is to allow people to call the init function without
- * having to mess with a fake argv */
- int *argcp;
- char ***argvp;
- int fake_argc = 1;
- char *fake_argv[] = { (char *)"", 0 };
- const char *fake_groups[] = { "server", "embedded", 0 };
- if (argc)
- {
- argcp = &argc;
- argvp = (char***) &argv;
- }
- else
- {
- argcp = &fake_argc;
- argvp = (char ***) &fake_argv;
- }
- if (!groups)
- groups = (char**) fake_groups;
-
- my_umask=0660; // Default umask for new files
- my_umask_dir=0700; // Default umask for new directories
-
- /* Only call MY_INIT() if it hasn't been called before */
- if (!inited)
- {
- inited=1;
- org_my_init_done=my_init_done;
- }
- if (!org_my_init_done)
- {
- MY_INIT((char *)"mysql_embedded"); // init my_sys library & pthreads
- }
-
- /*
- Make a copy of the arguments to guard against applications that
- may change or move the initial arguments.
- */
- if (argvp == &argv)
- if (!(copy_arguments_ptr= argv= copy_arguments(argc, argv)))
- return 1;
-
- tzset(); // Set tzname
-
- start_time=time((time_t*) 0);
-#ifdef HAVE_TZNAME
-#if defined(HAVE_LOCALTIME_R) && defined(_REENTRANT)
- {
- struct tm tm_tmp;
- localtime_r(&start_time,&tm_tmp);
- strmov(time_zone,tzname[tm_tmp.tm_isdst != 0 ? 1 : 0]);
- }
-#else
- {
- struct tm *start_tm;
- start_tm=localtime(&start_time);
- strmov(time_zone,tzname[start_tm->tm_isdst != 0 ? 1 : 0]);
- }
-#endif
-#endif
-
- if (gethostname(glob_hostname,sizeof(glob_hostname)-4) < 0)
- strmov(glob_hostname,"mysql");
-#ifndef DBUG_OFF
- strxmov(strend(server_version),MYSQL_SERVER_SUFFIX,"-debug",NullS);
-#else
- strmov(strend(server_version),MYSQL_SERVER_SUFFIX);
-#endif
- load_defaults("my", (const char **) groups, argcp, argvp);
- defaults_argv=*argvp;
-
- /* Get default temporary directory */
- opt_mysql_tmpdir=getenv("TMPDIR"); /* Use this if possible */
-#if defined( __WIN__) || defined(OS2)
- if (!opt_mysql_tmpdir)
- opt_mysql_tmpdir=getenv("TEMP");
- if (!opt_mysql_tmpdir)
- opt_mysql_tmpdir=getenv("TMP");
-#endif
- if (!opt_mysql_tmpdir || !opt_mysql_tmpdir[0])
- opt_mysql_tmpdir=(char*) P_tmpdir; /* purecov: inspected */
-
- set_options();
- get_options(*argcp, *argvp);
-
- if (opt_log || opt_update_log || opt_slow_log || opt_bin_log)
- strcat(server_version,"-log");
- DBUG_PRINT("info",("%s Ver %s for %s on %s\n",my_progname,
- server_version, SYSTEM_TYPE,MACHINE_TYPE));
-
- /* These must be set early */
-
- (void) pthread_mutex_init(&LOCK_mysql_create_db,MY_MUTEX_INIT_SLOW);
- (void) pthread_mutex_init(&LOCK_Acl,MY_MUTEX_INIT_SLOW);
- (void) pthread_mutex_init(&LOCK_open,MY_MUTEX_INIT_FAST);
- (void) pthread_mutex_init(&LOCK_thread_count,MY_MUTEX_INIT_FAST);
- (void) pthread_mutex_init(&LOCK_mapped_file,MY_MUTEX_INIT_SLOW);
- (void) pthread_mutex_init(&LOCK_status,MY_MUTEX_INIT_FAST);
- (void) pthread_mutex_init(&LOCK_error_log,MY_MUTEX_INIT_FAST);
- (void) pthread_mutex_init(&LOCK_delayed_insert,MY_MUTEX_INIT_FAST);
- (void) pthread_mutex_init(&LOCK_delayed_status,MY_MUTEX_INIT_FAST);
- (void) pthread_mutex_init(&LOCK_delayed_create,MY_MUTEX_INIT_SLOW);
- (void) pthread_mutex_init(&LOCK_manager,MY_MUTEX_INIT_FAST);
- (void) pthread_mutex_init(&LOCK_crypt,MY_MUTEX_INIT_FAST);
- (void) pthread_mutex_init(&LOCK_bytes_sent,MY_MUTEX_INIT_FAST);
- (void) pthread_mutex_init(&LOCK_bytes_received,MY_MUTEX_INIT_FAST);
- (void) pthread_mutex_init(&LOCK_timezone,MY_MUTEX_INIT_FAST);
- (void) pthread_mutex_init(&LOCK_user_conn, MY_MUTEX_INIT_FAST);
- (void) pthread_mutex_init(&LOCK_rpl_status, MY_MUTEX_INIT_FAST);
- (void) pthread_mutex_init(&LOCK_active_mi, MY_MUTEX_INIT_FAST);
- (void) pthread_mutex_init(&LOCK_global_system_variables, MY_MUTEX_INIT_FAST);
- (void) my_rwlock_init(&LOCK_grant, NULL);
- (void) pthread_cond_init(&COND_thread_count,NULL);
- (void) pthread_cond_init(&COND_refresh,NULL);
- (void) pthread_cond_init(&COND_thread_cache,NULL);
- (void) pthread_cond_init(&COND_flush_thread_cache,NULL);
- (void) pthread_cond_init(&COND_manager,NULL);
- (void) pthread_cond_init(&COND_rpl_status, NULL);
-
- if (set_default_charset_by_name(sys_charset.value, MYF(MY_WME)))
- {
- mysql_server_end();
- return 1;
- }
- charsets_list = list_charsets(MYF(MY_CS_COMPILED|MY_CS_CONFIG));
-
- /* Parameter for threads created for connections */
- (void) pthread_attr_init(&connection_attrib);
- (void) pthread_attr_setdetachstate(&connection_attrib,
- PTHREAD_CREATE_DETACHED);
- pthread_attr_setstacksize(&connection_attrib,thread_stack);
- pthread_attr_setscope(&connection_attrib, PTHREAD_SCOPE_SYSTEM);
-
-#if defined( SET_RLIMIT_NOFILE) || defined( OS2)
- /* connections and databases needs lots of files */
- {
- uint wanted_files=10+(uint) max(max_connections*5,
- max_connections+table_cache_size*2);
- set_if_bigger(wanted_files, open_files_limit);
- // Note that some system returns 0 if we succeed here:
- uint files=set_maximum_open_files(wanted_files);
- if (files && files < wanted_files && ! open_files_limit)
- {
- max_connections= (ulong) min((files-10),max_connections);
- table_cache_size= (ulong) max((files-10-max_connections)/2,64);
- DBUG_PRINT("warning",
- ("Changed limits: max_connections: %ld table_cache: %ld",
- max_connections,table_cache_size));
- sql_print_error("Warning: Changed limits: max_connections: %ld table_cache: %ld",max_connections,table_cache_size);
- }
- }
-#endif
- unireg_init(opt_specialflag); /* Set up extern variabels */
- init_errmessage(); /* Read error messages from file */
- lex_init();
- item_init();
- set_var_init();
- mysys_uses_curses=0;
-#ifdef USE_REGEX
- regex_init();
-#endif
- if (use_temp_pool && bitmap_init(&temp_pool,1024,1))
- {
- mysql_server_end();
- return 1;
- }
-
- /*
- We have enough space for fiddling with the argv, continue
- */
- umask(((~my_umask) & 0666));
- table_cache_init();
- hostname_cache_init();
- query_cache_result_size_limit(query_cache_limit);
- query_cache_resize(query_cache_size);
- randominit(&sql_rand,(ulong) start_time,(ulong) start_time/2);
- reset_floating_point_exceptions();
- init_thr_lock();
- init_slave_list();
-
- /* Setup log files */
- if (opt_log)
- open_log(&mysql_log, glob_hostname, opt_logname, ".log", NullS,
- LOG_NORMAL);
- if (opt_update_log)
- {
- open_log(&mysql_update_log, glob_hostname, opt_update_logname, "",
- NullS, LOG_NEW);
- using_update_log=1;
- }
-
- if (opt_slow_log)
- open_log(&mysql_slow_log, glob_hostname, opt_slow_logname, "-slow.log",
- NullS, LOG_NORMAL);
- if (ha_init())
- {
- sql_print_error("Can't init databases");
- exit(1);
- }
- ha_key_cache();
-#if defined(HAVE_MLOCKALL) && defined(MCL_CURRENT)
- if (locked_in_memory && !geteuid())
- {
- if (mlockall(MCL_CURRENT))
- {
- sql_print_error("Warning: Failed to lock memory. Errno: %d\n",errno);
- }
- else
- locked_in_memory=1;
- }
-#else
- locked_in_memory=0;
-#endif
-
- if (opt_myisam_log)
- (void) mi_log( 1 );
- ft_init_stopwords(ft_precompiled_stopwords);
-
- /*
- init signals & alarm
- After this we can't quit by a simple unireg_abort
- */
- error_handler_hook = my_message_sql;
- if (pthread_key_create(&THR_THD,NULL) ||
- pthread_key_create(&THR_MALLOC,NULL))
- {
- sql_print_error("Can't create thread-keys");
- exit(1);
- }
- opt_noacl = 1; // No permissions
- if (acl_init(opt_noacl))
- {
- mysql_server_end();
- return 1;
- }
- if (!opt_noacl)
- (void) grant_init();
- init_max_user_conn();
- init_update_queries();
-
-#ifdef HAVE_DLOPEN
- if (!opt_noacl)
- udf_init();
-#endif
-
- if (opt_bin_log)
- {
- if (!opt_bin_logname)
- {
- char tmp[FN_REFLEN];
- /* TODO: The following should be using fn_format(); We just need to
- first change fn_format() to cut the file name if it's too long.
- */
- strmake(tmp,glob_hostname,FN_REFLEN-5);
- strmov(strcend(tmp,'.'),"-bin");
- opt_bin_logname=my_strdup(tmp,MYF(MY_WME));
- }
- open_log(&mysql_bin_log, glob_hostname, opt_bin_logname, "-bin",
- opt_binlog_index_name, LOG_BIN);
- using_update_log=1;
- }
-
- (void) thr_setconcurrency(concurrency); // 10 by default
-
- if (
-#ifdef HAVE_BERKELEY_DB
- !berkeley_skip ||
-#endif
- (flush_time && flush_time != ~(ulong) 0L))
- {
- pthread_t hThread;
- if (pthread_create(&hThread,&connection_attrib,handle_manager,0))
- sql_print_error("Warning: Can't create thread to manage maintenance");
- }
-
- /*
- Update mysqld variables from client variables if set
- The client variables are set also by get_one_option() in mysqld.cc
- */
- if (max_allowed_packet)
- global_system_variables.max_allowed_packet= max_allowed_packet;
- if (net_buffer_length)
- global_system_variables.net_buffer_length= net_buffer_length;
- return 0;
-}
-
-int STDCALL mysql_server_init(int argc, char **argv, char **groups)
-{
- char glob_hostname[FN_REFLEN];
-
- /* This mess is to allow people to call the init function without
- * having to mess with a fake argv */
- int *argcp;
- char ***argvp;
- int fake_argc = 1;
- char *fake_argv[] = { (char *)"", 0 };
- const char *fake_groups[] = { "server", "embedded", 0 };
- if (argc)
- {
- argcp = &argc;
- argvp = (char***) &argv;
- }
- else
- {
- argcp = &fake_argc;
- argvp = (char ***) &fake_argv;
- }
- if (!groups)
- groups = (char**) fake_groups;
-
- my_umask=0660; // Default umask for new files
- my_umask_dir=0700; // Default umask for new directories
-
- /* Only call MY_INIT() if it hasn't been called before */
- if (!inited)
- {
- inited=1;
- org_my_init_done=my_init_done;
- }
- if (!org_my_init_done)
- {
- MY_INIT((char *)"mysql_embedded"); // init my_sys library & pthreads
- }
-
- tzset(); // Set tzname
-
- start_time=time((time_t*) 0);
-#ifdef HAVE_TZNAME
-#if defined(HAVE_LOCALTIME_R) && defined(_REENTRANT)
- {
- struct tm tm_tmp;
- localtime_r(&start_time,&tm_tmp);
- strmov(time_zone,tzname[tm_tmp.tm_isdst != 0 ? 1 : 0]);
- }
-#else
- {
- struct tm *start_tm;
- start_tm=localtime(&start_time);
- strmov(time_zone,tzname[start_tm->tm_isdst != 0 ? 1 : 0]);
- }
-#endif
-#endif
-
- if (gethostname(glob_hostname,sizeof(glob_hostname)-4) < 0)
- strmov(glob_hostname,"mysql");
-#ifndef DBUG_OFF
- strxmov(strend(server_version),MYSQL_SERVER_SUFFIX,"-debug",NullS);
-#else
- strmov(strend(server_version),MYSQL_SERVER_SUFFIX);
-#endif
- load_defaults("my", (const char **) groups, argcp, argvp);
- defaults_argv=*argvp;
-
- /* Get default temporary directory */
- opt_mysql_tmpdir=getenv("TMPDIR"); /* Use this if possible */
-#if defined( __WIN__) || defined(OS2)
- if (!opt_mysql_tmpdir)
- opt_mysql_tmpdir=getenv("TEMP");
- if (!opt_mysql_tmpdir)
- opt_mysql_tmpdir=getenv("TMP");
-#endif
- if (!opt_mysql_tmpdir || !opt_mysql_tmpdir[0])
- opt_mysql_tmpdir=(char*) P_tmpdir; /* purecov: inspected */
-
- set_options();
- get_options(*argcp, *argvp);
-
- if (opt_log || opt_update_log || opt_slow_log || opt_bin_log)
- strcat(server_version,"-log");
- DBUG_PRINT("info",("%s Ver %s for %s on %s\n",my_progname,
- server_version, SYSTEM_TYPE,MACHINE_TYPE));
-
- /* These must be set early */
-
- (void) pthread_mutex_init(&LOCK_mysql_create_db,MY_MUTEX_INIT_SLOW);
- (void) pthread_mutex_init(&LOCK_Acl,MY_MUTEX_INIT_SLOW);
- (void) pthread_mutex_init(&LOCK_open,MY_MUTEX_INIT_FAST);
- (void) pthread_mutex_init(&LOCK_thread_count,MY_MUTEX_INIT_FAST);
- (void) pthread_mutex_init(&LOCK_mapped_file,MY_MUTEX_INIT_SLOW);
- (void) pthread_mutex_init(&LOCK_status,MY_MUTEX_INIT_FAST);
- (void) pthread_mutex_init(&LOCK_error_log,MY_MUTEX_INIT_FAST);
- (void) pthread_mutex_init(&LOCK_delayed_insert,MY_MUTEX_INIT_FAST);
- (void) pthread_mutex_init(&LOCK_delayed_status,MY_MUTEX_INIT_FAST);
- (void) pthread_mutex_init(&LOCK_delayed_create,MY_MUTEX_INIT_SLOW);
- (void) pthread_mutex_init(&LOCK_manager,MY_MUTEX_INIT_FAST);
- (void) pthread_mutex_init(&LOCK_crypt,MY_MUTEX_INIT_FAST);
- (void) pthread_mutex_init(&LOCK_bytes_sent,MY_MUTEX_INIT_FAST);
- (void) pthread_mutex_init(&LOCK_bytes_received,MY_MUTEX_INIT_FAST);
- (void) pthread_mutex_init(&LOCK_timezone,MY_MUTEX_INIT_FAST);
- (void) pthread_mutex_init(&LOCK_user_conn, MY_MUTEX_INIT_FAST);
- (void) pthread_mutex_init(&LOCK_rpl_status, MY_MUTEX_INIT_FAST);
- (void) pthread_mutex_init(&LOCK_active_mi, MY_MUTEX_INIT_FAST);
- (void) pthread_mutex_init(&LOCK_global_system_variables, MY_MUTEX_INIT_FAST);
- (void) my_rwlock_init(&LOCK_grant, NULL);
- (void) pthread_cond_init(&COND_thread_count,NULL);
- (void) pthread_cond_init(&COND_refresh,NULL);
- (void) pthread_cond_init(&COND_thread_cache,NULL);
- (void) pthread_cond_init(&COND_flush_thread_cache,NULL);
- (void) pthread_cond_init(&COND_manager,NULL);
- (void) pthread_cond_init(&COND_rpl_status, NULL);
-
- if (set_default_charset_by_name(sys_charset.value, MYF(MY_WME)))
- {
- mysql_server_end();
- return 1;
- }
- charsets_list = list_charsets(MYF(MY_CS_COMPILED|MY_CS_CONFIG));
-
- /* Parameter for threads created for connections */
- (void) pthread_attr_init(&connection_attrib);
- (void) pthread_attr_setdetachstate(&connection_attrib,
- PTHREAD_CREATE_DETACHED);
- pthread_attr_setstacksize(&connection_attrib,thread_stack);
- pthread_attr_setscope(&connection_attrib, PTHREAD_SCOPE_SYSTEM);
-
-#if defined( SET_RLIMIT_NOFILE) || defined( OS2)
- /* connections and databases needs lots of files */
- {
- uint wanted_files=10+(uint) max(max_connections*5,
- max_connections+table_cache_size*2);
- set_if_bigger(wanted_files, open_files_limit);
- // Note that some system returns 0 if we succeed here:
- uint files=set_maximum_open_files(wanted_files);
- if (files && files < wanted_files && ! open_files_limit)
- {
- max_connections= (ulong) min((files-10),max_connections);
- table_cache_size= (ulong) max((files-10-max_connections)/2,64);
- DBUG_PRINT("warning",
- ("Changed limits: max_connections: %ld table_cache: %ld",
- max_connections,table_cache_size));
- sql_print_error("Warning: Changed limits: max_connections: %ld table_cache: %ld",max_connections,table_cache_size);
- }
- }
-#endif
- unireg_init(opt_specialflag); /* Set up extern variabels */
- init_errmessage(); /* Read error messages from file */
- lex_init();
- item_init();
- set_var_init();
- mysys_uses_curses=0;
-#ifdef USE_REGEX
- regex_init();
-#endif
- if (use_temp_pool && bitmap_init(&temp_pool,1024,1))
- {
- mysql_server_end();
- return 1;
- }
-
- /*
- We have enough space for fiddling with the argv, continue
- */
- umask(((~my_umask) & 0666));
- table_cache_init();
- hostname_cache_init();
- query_cache_result_size_limit(query_cache_limit);
- query_cache_resize(query_cache_size);
- randominit(&sql_rand,(ulong) start_time,(ulong) start_time/2);
- reset_floating_point_exceptions();
- init_thr_lock();
- init_slave_list();
-
- /* Setup log files */
- if (opt_log)
- open_log(&mysql_log, glob_hostname, opt_logname, ".log", NullS,
- LOG_NORMAL);
- if (opt_update_log)
- {
- open_log(&mysql_update_log, glob_hostname, opt_update_logname, "",
- NullS, LOG_NEW);
- using_update_log=1;
- }
-
- if (opt_slow_log)
- open_log(&mysql_slow_log, glob_hostname, opt_slow_logname, "-slow.log",
- NullS, LOG_NORMAL);
- if (ha_init())
- {
- sql_print_error("Can't init databases");
- exit(1);
- }
- ha_key_cache();
-#if defined(HAVE_MLOCKALL) && defined(MCL_CURRENT)
- if (locked_in_memory && !geteuid())
- {
- if (mlockall(MCL_CURRENT))
- {
- sql_print_error("Warning: Failed to lock memory. Errno: %d\n",errno);
- }
- else
- locked_in_memory=1;
- }
-#else
- locked_in_memory=0;
-#endif
-
- if (opt_myisam_log)
- (void) mi_log( 1 );
- ft_init_stopwords(ft_precompiled_stopwords);
-
- /*
- init signals & alarm
- After this we can't quit by a simple unireg_abort
- */
- error_handler_hook = my_message_sql;
- if (pthread_key_create(&THR_THD,NULL) ||
- pthread_key_create(&THR_MALLOC,NULL))
- {
- sql_print_error("Can't create thread-keys");
- exit(1);
- }
- opt_noacl = 1; // No permissions
- if (acl_init(opt_noacl))
- {
- mysql_server_end();
- return 1;
- }
- if (!opt_noacl)
- (void) grant_init();
- init_max_user_conn();
- init_update_queries();
-
-#ifdef HAVE_DLOPEN
- if (!opt_noacl)
- udf_init();
-#endif
-
- if (opt_bin_log)
- {
- if (!opt_bin_logname)
- {
- char tmp[FN_REFLEN];
- /* TODO: The following should be using fn_format(); We just need to
- first change fn_format() to cut the file name if it's too long.
- */
- strmake(tmp,glob_hostname,FN_REFLEN-5);
- strmov(strcend(tmp,'.'),"-bin");
- opt_bin_logname=my_strdup(tmp,MYF(MY_WME));
- }
- open_log(&mysql_bin_log, glob_hostname, opt_bin_logname, "-bin",
- opt_binlog_index_name, LOG_BIN);
- using_update_log=1;
- }
-
- (void) thr_setconcurrency(concurrency); // 10 by default
-
- if (
-#ifdef HAVE_BERKELEY_DB
- !berkeley_skip ||
-#endif
- (flush_time && flush_time != ~(ulong) 0L))
- {
- pthread_t hThread;
- if (pthread_create(&hThread,&connection_attrib,handle_manager,0))
- sql_print_error("Warning: Can't create thread to manage maintenance");
- }
-
- /*
- Update mysqld variables from client variables if set
- The client variables are set also by get_one_option() in mysqld.cc
- */
- if (max_allowed_packet)
- global_system_variables.max_allowed_packet= max_allowed_packet;
- if (net_buffer_length)
- global_system_variables.net_buffer_length= net_buffer_length;
- return 0;
-}
-#endif
-
void STDCALL mysql_server_end()
{
my_free((char*) copy_arguments_ptr, MYF(MY_ALLOW_ZERO_PTR));
@@ -1035,75 +302,19 @@ void STDCALL mysql_thread_end()
my_thread_end();
#endif
}
-
-void start_embedded_connection(NET * net)
-{
-// start_embedded_conn1(net);
-}
-
-void end_embedded_connection(NET * net)
-{
- THD *thd = (THD *) net->vio->dest_thd;
- delete thd;
-}
-
} /* extern "C" */
C_MODE_START
-NET *get_mysql_net(MYSQL *mysql)
-{
- return &((THD *)mysql->net.vio->dest_thd)->net;
-}
-
void init_embedded_mysql(MYSQL *mysql, int client_flag, char *db)
{
- THD *thd = (THD *)mysql->net.vio->dest_thd;
- mysql->reconnect= 1; /* Reconnect as default */
- mysql->server_status= SERVER_STATUS_AUTOCOMMIT;
-
- mysql->protocol_version= ::protocol_version;
- mysql->thread_id= thd->thread_id;
- strmake(mysql->scramble_buff, thd->scramble, 8);
- mysql->server_capabilities= CLIENT_LONG_FLAG | CLIENT_CONNECT_WITH_DB |
- CLIENT_TRANSACTIONS;
- mysql->server_language= MY_CHARSET_CURRENT;
- mysql->server_status= thd->server_status;
- mysql->client_flag= client_flag | mysql->options.client_flag;
- mysql->db= db;
+ THD *thd = (THD *)mysql->thd;
thd->mysql= mysql;
+ mysql->last_error= thd->net.last_error;
}
-C_MODE_END
-
-static int embedded_thd_net_init(NET *net, unsigned char *buff)
-{
- net->buff = buff;
- if (net_buffer_length > max_allowed_packet)
- max_allowed_packet= net_buffer_length;
- net->buff_end= net->buff+(net->max_packet=net_buffer_length);
- net->vio= NULL;
- net->no_send_ok= 0;
- net->error=0; net->return_errno=0; net->return_status=0;
-// net->timeout=(uint) net_read_timeout; /* Timeout for read */
- net->pkt_nr= net->compress_pkt_nr=0;
- net->write_pos= net->read_pos = net->buff;
- net->last_error[0]= 0;
- net->compress= 0;
- net->reading_or_writing= 0;
- net->where_b = net->remain_in_buf= 0;
- net->last_errno= 0;
- net->query_cache_query= 0;
- return 0;
-}
-
-C_MODE_START
-void *create_embedded_thd(Vio *vio, unsigned char *buff, int client_flag, char *db)
+void *create_embedded_thd(int client_flag, char *db)
{
THD * thd= new THD;
- embedded_thd_net_init(&thd->net, buff);
-
- /* if (protocol_version>9) */
- thd->net.return_errno=1;
thd->thread_id= thread_id++;
if (thd->store_globals())
@@ -1116,30 +327,22 @@ void *create_embedded_thd(Vio *vio, unsigned char *buff, int client_flag, char *
thd->dbug_thread_id= my_thread_id();
thd->thread_stack= (char*) &thd;
-// if (thd->max_join_size == HA_POS_ERROR)
-// thd->options |= OPTION_BIG_SELECTS;
-
thd->proc_info=0; // Remove 'login'
thd->command=COM_SLEEP;
thd->version=refresh_version;
thd->set_time();
init_sql_alloc(&thd->mem_root,8192,8192);
thd->client_capabilities= client_flag;
-// thd->max_packet_length= max_allowed_packet;
- thd->net.vio = vio;
-
-// if (thd->client_capabilities & CLIENT_INTERACTIVE)
-// thd->inactive_timeout= net_interactive_timeout;
- if (thd->client_capabilities & CLIENT_TRANSACTIONS)
- thd->net.return_status= &thd->server_status;
thd->db= db;
thd->db_length= db ? strip_sp(db) : 0;
thd->db_access= DB_ACLS;
thd->master_access= ~NO_ACCESS;
+ thd->net.query_cache_query= 0;
return thd;
}
+
C_MODE_END
bool send_fields(THD *thd, List<Item> &list, uint flag)
@@ -1295,63 +498,16 @@ bool select_send::send_data(List<Item> &items)
DBUG_RETURN(0);
}
-bool do_command(THD *thd)
-{
- MYSQL *mysql= thd->mysql;
-
- char *packet;
- uint old_timeout;
- ulong packet_length;
- NET *net;
- enum enum_server_command command;
- DBUG_ENTER("do_command");
-
- net= &thd->net;
- thd->current_tablenr=0;
-
- packet=0;
-// old_timeout=net->timeout;
-// net->timeout=(uint) thd->inactive_timeout; // Wait max for 8 hours
- net->last_error[0]=0; // Clear error message
- net->last_errno=0;
-
- net_new_transaction(net);
- if ((packet_length=my_net_read(net)) == packet_error)
- {
- DBUG_PRINT("info",("Got error reading command from socket %s",
- vio_description(net->vio) ));
- return TRUE;
- }
- else
- {
- packet=(char*) net->read_pos;
-
- command = (enum enum_server_command) (uchar) packet[0];
- DBUG_PRINT("info",("Command on %s = %d (%s)",
- vio_description(net->vio), command,
- command_name[command]));
- }
-// net->timeout=old_timeout; // Timeout for writing
- DBUG_RETURN(dispatch_command(command,thd, packet+1, (uint) packet_length));
-}
-
void
send_ok(THD *thd,ha_rows affected_rows,ulonglong id,const char *message)
{
- NET *net= &thd->net;
- if (net->no_send_ok) // hack for re-parsing queries
- return;
-
DBUG_ENTER("send_ok");
MYSQL *mysql= current_thd->mysql;
mysql->affected_rows= affected_rows;
mysql->insert_id= id;
- if (net->return_status)
- mysql->server_status= *net->return_status;
if (message)
{
- strmake(net->last_error, message, sizeof(net->last_error));
- mysql->info= net->last_error;
+ strmake(thd->net.last_error, message, sizeof(thd->net.last_error)-1);
}
DBUG_VOID_RETURN;
}
@@ -1438,3 +594,7 @@ int embedded_send_row(THD *thd, int n_fields, char *data, int data_len)
DBUG_RETURN(0);
}
+uint STDCALL mysql_warning_count(MYSQL *mysql)
+{
+ return ((THD *)mysql->thd)->total_warn_count;
+}