Commit e6f5fc1c authored by Michael Widenius's avatar Michael Widenius

Fixed lp:909051 Options --debug and --disable-debug are known but ambiguous in RelWithDebInfo build

Fixed memory leak printing when doing 'mysqld --version', 'mysqld --debug --help' and 'mysqld --debug --help --verbose'


mysys/my_init.c:
  Moved checking if we should call DBUG_END() before my_thread_end() as otherwise we will not free DBUG variables and files.
mysys/thr_lock.c:
  Fixed compiler warning
sql/mysqld.cc:
  Fixed memory leaks when using mysqld --help and mysqld --version
  Added --debug as an option that works for all builds. For non debug builds we now get a warning.
strings/dtoa.c:
  Fixed valgrind warning (c could contain data outside of the given string)
parent e72a6096
...@@ -199,6 +199,9 @@ Voluntary context switches %ld, Involuntary context switches %ld\n", ...@@ -199,6 +199,9 @@ Voluntary context switches %ld, Involuntary context switches %ld\n",
#endif #endif
} }
if (!(infoflag & MY_DONT_FREE_DBUG))
DBUG_END(); /* Must be done as late as possible */
my_thread_end(); my_thread_end();
my_thread_global_end(); my_thread_global_end();
my_mutex_end(); my_mutex_end();
...@@ -216,9 +219,6 @@ Voluntary context switches %ld, Involuntary context switches %ld\n", ...@@ -216,9 +219,6 @@ Voluntary context switches %ld, Involuntary context switches %ld\n",
WSACleanup(); WSACleanup();
#endif /* __WIN__ */ #endif /* __WIN__ */
if (!(infoflag & MY_DONT_FREE_DBUG))
DBUG_END(); /* Must be done as late as possible */
my_init_done=0; my_init_done=0;
} /* my_end */ } /* my_end */
......
...@@ -1386,7 +1386,7 @@ void thr_downgrade_write_lock(THR_LOCK_DATA *in_data, ...@@ -1386,7 +1386,7 @@ void thr_downgrade_write_lock(THR_LOCK_DATA *in_data,
enum thr_lock_type new_lock_type) enum thr_lock_type new_lock_type)
{ {
THR_LOCK *lock=in_data->lock; THR_LOCK *lock=in_data->lock;
#ifndef DBUG_OFF #ifdef EXTRA_DEBUG
enum thr_lock_type old_lock_type= in_data->type; enum thr_lock_type old_lock_type= in_data->type;
#endif #endif
DBUG_ENTER("thr_downgrade_write_only_lock"); DBUG_ENTER("thr_downgrade_write_only_lock");
......
...@@ -356,11 +356,12 @@ static I_List<THD> thread_cache; ...@@ -356,11 +356,12 @@ static I_List<THD> thread_cache;
static bool binlog_format_used= false; static bool binlog_format_used= false;
LEX_STRING opt_init_connect, opt_init_slave; LEX_STRING opt_init_connect, opt_init_slave;
static mysql_cond_t COND_thread_cache, COND_flush_thread_cache; static mysql_cond_t COND_thread_cache, COND_flush_thread_cache;
static DYNAMIC_ARRAY all_options;
/* Global variables */ /* Global variables */
bool opt_bin_log, opt_ignore_builtin_innodb= 0; bool opt_bin_log, opt_ignore_builtin_innodb= 0;
my_bool opt_log, opt_slow_log, debug_assert_if_crashed_table= 0, opt_help= 0; my_bool opt_log, opt_slow_log, debug_assert_if_crashed_table= 0, opt_help= 0, opt_abort;
ulonglong log_output_options; ulonglong log_output_options;
my_bool opt_userstat_running; my_bool opt_userstat_running;
my_bool opt_log_queries_not_using_indexes= 0; my_bool opt_log_queries_not_using_indexes= 0;
...@@ -1177,8 +1178,9 @@ bool mysqld_embedded=1; ...@@ -1177,8 +1178,9 @@ bool mysqld_embedded=1;
static my_bool plugins_are_initialized= FALSE; static my_bool plugins_are_initialized= FALSE;
#ifndef DBUG_OFF #ifndef DBUG_OFF
static const char* default_dbug_option, *current_dbug_option; static const char* default_dbug_option;
#endif #endif
static const char *current_dbug_option;
#ifdef HAVE_LIBWRAP #ifdef HAVE_LIBWRAP
const char *libwrapName= NULL; const char *libwrapName= NULL;
int allow_severity = LOG_INFO; int allow_severity = LOG_INFO;
...@@ -1709,7 +1711,7 @@ extern "C" void unireg_abort(int exit_code) ...@@ -1709,7 +1711,7 @@ extern "C" void unireg_abort(int exit_code)
usage(); usage();
if (exit_code) if (exit_code)
sql_print_error("Aborting\n"); sql_print_error("Aborting\n");
clean_up(!opt_help && (exit_code || !opt_bootstrap)); /* purecov: inspected */ clean_up(!opt_abort && (exit_code || !opt_bootstrap)); /* purecov: inspected */
DBUG_PRINT("quit",("done with cleanup in unireg_abort")); DBUG_PRINT("quit",("done with cleanup in unireg_abort"));
mysqld_exit(exit_code); mysqld_exit(exit_code);
} }
...@@ -1725,9 +1727,8 @@ static void mysqld_exit(int exit_code) ...@@ -1725,9 +1727,8 @@ static void mysqld_exit(int exit_code)
mysql_audit_finalize(); mysql_audit_finalize();
clean_up_mutexes(); clean_up_mutexes();
clean_up_error_log_mutex(); clean_up_error_log_mutex();
my_end((opt_endinfo ? MY_CHECK_ERROR | MY_GIVE_INFO : 0) | MY_DONT_FREE_DBUG); my_end((opt_endinfo ? MY_CHECK_ERROR | MY_GIVE_INFO : 0));
shutdown_performance_schema(); // we do it as late as possible shutdown_performance_schema(); // we do it as late as possible
DBUG_END(); // but this - even later
exit(exit_code); /* purecov: inspected */ exit(exit_code); /* purecov: inspected */
} }
...@@ -1802,6 +1803,7 @@ void clean_up(bool print_message) ...@@ -1802,6 +1803,7 @@ void clean_up(bool print_message)
free_global_client_stats(); free_global_client_stats();
free_global_table_stats(); free_global_table_stats();
free_global_index_stats(); free_global_index_stats();
delete_dynamic(&all_options);
#ifdef HAVE_REPLICATION #ifdef HAVE_REPLICATION
end_slave_list(); end_slave_list();
#endif #endif
...@@ -3645,7 +3647,7 @@ static int init_common_variables() ...@@ -3645,7 +3647,7 @@ static int init_common_variables()
set_server_version(); set_server_version();
#ifndef EMBEDDED_LIBRARY #ifndef EMBEDDED_LIBRARY
if (opt_help && !opt_verbose) if (opt_abort && !opt_verbose)
unireg_abort(0); unireg_abort(0);
#endif /*!EMBEDDED_LIBRARY*/ #endif /*!EMBEDDED_LIBRARY*/
...@@ -4206,7 +4208,7 @@ static int init_server_components() ...@@ -4206,7 +4208,7 @@ static int init_server_components()
help information. Since the implementation of plugin server help information. Since the implementation of plugin server
variables the help output is now written much later. variables the help output is now written much later.
*/ */
if (opt_error_log && !opt_help) if (opt_error_log && !opt_abort)
{ {
if (!log_error_file_ptr[0]) if (!log_error_file_ptr[0])
fn_format(log_error_file, pidfile_name, mysql_data_home, ".err", fn_format(log_error_file, pidfile_name, mysql_data_home, ".err",
...@@ -4365,7 +4367,7 @@ a file name for --log-bin-index option", opt_binlog_index_name); ...@@ -4365,7 +4367,7 @@ a file name for --log-bin-index option", opt_binlog_index_name);
if (plugin_init(&remaining_argc, remaining_argv, if (plugin_init(&remaining_argc, remaining_argv,
(opt_noacl ? PLUGIN_INIT_SKIP_PLUGIN_TABLE : 0) | (opt_noacl ? PLUGIN_INIT_SKIP_PLUGIN_TABLE : 0) |
(opt_help ? PLUGIN_INIT_SKIP_INITIALIZATION : 0))) (opt_abort ? PLUGIN_INIT_SKIP_INITIALIZATION : 0)))
{ {
sql_print_error("Failed to initialize plugins."); sql_print_error("Failed to initialize plugins.");
unireg_abort(1); unireg_abort(1);
...@@ -4409,7 +4411,7 @@ a file name for --log-bin-index option", opt_binlog_index_name); ...@@ -4409,7 +4411,7 @@ a file name for --log-bin-index option", opt_binlog_index_name);
} }
} }
if (opt_help) if (opt_abort)
unireg_abort(0); unireg_abort(0);
/* if the errmsg.sys is not loaded, terminate to maintain behaviour */ /* if the errmsg.sys is not loaded, terminate to maintain behaviour */
...@@ -4914,7 +4916,7 @@ int mysqld_main(int argc, char **argv) ...@@ -4914,7 +4916,7 @@ int mysqld_main(int argc, char **argv)
We have enough space for fiddling with the argv, continue We have enough space for fiddling with the argv, continue
*/ */
check_data_home(mysql_real_data_home); check_data_home(mysql_real_data_home);
if (my_setwd(mysql_real_data_home, opt_help ? 0 : MYF(MY_WME)) && !opt_help) if (my_setwd(mysql_real_data_home, opt_abort ? 0 : MYF(MY_WME)) && !opt_abort)
unireg_abort(1); /* purecov: inspected */ unireg_abort(1); /* purecov: inspected */
if ((user_info= check_user(mysqld_user))) if ((user_info= check_user(mysqld_user)))
...@@ -6159,8 +6161,6 @@ error: ...@@ -6159,8 +6161,6 @@ error:
Handle start options Handle start options
******************************************************************************/ ******************************************************************************/
DYNAMIC_ARRAY all_options;
/** /**
System variables are automatically command-line options (few System variables are automatically command-line options (few
exceptions are documented in sys_var.h), so don't need exceptions are documented in sys_var.h), so don't need
...@@ -6172,6 +6172,11 @@ struct my_option my_long_options[]= ...@@ -6172,6 +6172,11 @@ struct my_option my_long_options[]=
{"help", '?', "Display this help and exit.", {"help", '?', "Display this help and exit.",
&opt_help, &opt_help, 0, GET_BOOL, NO_ARG, 0, 0, 0, 0, &opt_help, &opt_help, 0, GET_BOOL, NO_ARG, 0, 0, 0, 0,
0, 0}, 0, 0},
#ifdef DBUG_OFF
{"debug", '#', "Built in DBUG debugger. Disabled in this build.",
&current_dbug_option, &current_dbug_option, 0, GET_STR, OPT_ARG,
0, 0, 0, 0, 0, 0},
#endif
#ifdef HAVE_REPLICATION #ifdef HAVE_REPLICATION
{"debug-abort-slave-event-count", 0, {"debug-abort-slave-event-count", 0,
"Option used by mysql-test for debugging and testing of replication.", "Option used by mysql-test for debugging and testing of replication.",
...@@ -7203,7 +7208,6 @@ static void print_help() ...@@ -7203,7 +7208,6 @@ static void print_help()
my_print_variables((my_option*) all_options.buffer); my_print_variables((my_option*) all_options.buffer);
free_root(&mem_root, MYF(0)); free_root(&mem_root, MYF(0));
delete_dynamic(&all_options);
} }
static void usage(void) static void usage(void)
...@@ -7471,8 +7475,8 @@ mysqld_get_one_option(int optid, ...@@ -7471,8 +7475,8 @@ mysqld_get_one_option(int optid,
char *argument) char *argument)
{ {
switch(optid) { switch(optid) {
#ifndef DBUG_OFF
case '#': case '#':
#ifndef DBUG_OFF
if (!argument) if (!argument)
argument= (char*) default_dbug_option; argument= (char*) default_dbug_option;
if (argument[0] == '0' && !argument[1]) if (argument[0] == '0' && !argument[1])
...@@ -7485,8 +7489,10 @@ mysqld_get_one_option(int optid, ...@@ -7485,8 +7489,10 @@ mysqld_get_one_option(int optid,
break; break;
DBUG_SET_INITIAL(argument); DBUG_SET_INITIAL(argument);
opt_endinfo=1; /* unireg: memory allocation */ opt_endinfo=1; /* unireg: memory allocation */
break; #else
sql_print_warning("'%s' is disabled in this build", opt->name);
#endif #endif
break;
case OPT_DEPRECATED_OPTION: case OPT_DEPRECATED_OPTION:
sql_print_warning("'%s' is deprecated. It does nothing and exists only " sql_print_warning("'%s' is deprecated. It does nothing and exists only "
"for compatiblity with old my.cnf files.", "for compatiblity with old my.cnf files.",
...@@ -7529,7 +7535,8 @@ mysqld_get_one_option(int optid, ...@@ -7529,7 +7535,8 @@ mysqld_get_one_option(int optid,
#ifndef EMBEDDED_LIBRARY #ifndef EMBEDDED_LIBRARY
case 'V': case 'V':
print_version(); print_version();
exit(0); opt_abort= 1; // Abort after parsing all options
break;
#endif /*EMBEDDED_LIBRARY*/ #endif /*EMBEDDED_LIBRARY*/
case 'W': case 'W':
if (!argument) if (!argument)
...@@ -7872,6 +7879,8 @@ static int get_options(int *argc_ptr, char ***argv_ptr) ...@@ -7872,6 +7879,8 @@ static int get_options(int *argc_ptr, char ***argv_ptr)
if (!opt_help) if (!opt_help)
delete_dynamic(&all_options); delete_dynamic(&all_options);
else
opt_abort= 1;
/* Add back the program name handle_options removes */ /* Add back the program name handle_options removes */
(*argc_ptr)++; (*argc_ptr)++;
...@@ -8272,7 +8281,7 @@ static int test_if_case_insensitive(const char *dir_name) ...@@ -8272,7 +8281,7 @@ static int test_if_case_insensitive(const char *dir_name)
if ((file= mysql_file_create(key_file_casetest, if ((file= mysql_file_create(key_file_casetest,
buff, 0666, O_RDWR, MYF(0))) < 0) buff, 0666, O_RDWR, MYF(0))) < 0)
{ {
if (!opt_help) if (!opt_abort)
sql_print_warning("Can't create test file %s", buff); sql_print_warning("Can't create test file %s", buff);
DBUG_RETURN(-1); DBUG_RETURN(-1);
} }
......
...@@ -1398,12 +1398,12 @@ static double my_strtod_int(const char *s00, char **se, int *error, char *buf, s ...@@ -1398,12 +1398,12 @@ static double my_strtod_int(const char *s00, char **se, int *error, char *buf, s
nd0= nd; nd0= nd;
if (s < end - 1 && c == '.') if (s < end - 1 && c == '.')
{ {
c= *++s; ++s;
if (!nd) if (!nd)
{ {
for (; s < end && c == '0'; c= *++s) for (; s < end && (c= *s) == '0'; ++s)
nz++; nz++;
if (s < end && c > '0' && c <= '9') if (s < end && (c= *s) > '0' && c <= '9')
{ {
s0= s; s0= s;
nf+= nz; nf+= nz;
...@@ -1412,7 +1412,7 @@ static double my_strtod_int(const char *s00, char **se, int *error, char *buf, s ...@@ -1412,7 +1412,7 @@ static double my_strtod_int(const char *s00, char **se, int *error, char *buf, s
} }
goto dig_done; goto dig_done;
} }
for (; s < end && c >= '0' && c <= '9'; c = *++s) for (; s < end && (c= *s) >= '0' && c <= '9'; ++s)
{ {
have_dig: have_dig:
nz++; nz++;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment