Commit 8f9d5938 authored by Venkatesh Duggirala's avatar Venkatesh Duggirala

BUG#11753923-SQL THREAD CRASHES ON DISK FULL

Merging fix from mysql-5.1
parents 7a846307 c72f687f
...@@ -210,6 +210,7 @@ extern char curr_dir[]; /* Current directory for user */ ...@@ -210,6 +210,7 @@ extern char curr_dir[]; /* Current directory for user */
extern void (*error_handler_hook)(uint my_err, const char *str,myf MyFlags); extern void (*error_handler_hook)(uint my_err, const char *str,myf MyFlags);
extern void (*fatal_error_handler_hook)(uint my_err, const char *str, extern void (*fatal_error_handler_hook)(uint my_err, const char *str,
myf MyFlags); myf MyFlags);
extern void(*sql_print_warning_hook)(const char *format,...);
extern uint my_file_limit; extern uint my_file_limit;
extern ulong my_thread_stack_size; extern ulong my_thread_stack_size;
...@@ -641,6 +642,7 @@ extern void my_printv_error(uint error, const char *format, myf MyFlags, ...@@ -641,6 +642,7 @@ extern void my_printv_error(uint error, const char *format, myf MyFlags,
va_list ap); va_list ap);
extern int my_error_register(const char** (*get_errmsgs) (), extern int my_error_register(const char** (*get_errmsgs) (),
int first, int last); int first, int last);
extern void my_printf_warning (const char * format, ...);
extern const char **my_error_unregister(int first, int last); extern const char **my_error_unregister(int first, int last);
extern void my_message(uint my_err, const char *str,myf MyFlags); extern void my_message(uint my_err, const char *str,myf MyFlags);
extern void my_message_stderr(uint my_err, const char *str, myf MyFlags); extern void my_message_stderr(uint my_err, const char *str, myf MyFlags);
......
...@@ -99,17 +99,29 @@ void init_glob_errs() ...@@ -99,17 +99,29 @@ void init_glob_errs()
} }
#endif #endif
/*
We cannot call my_error/my_printf_error here in this function.
Those functions will set status variable in diagnostic area
and there is no provision to reset them back.
Here we are waiting for free space and will wait forever till
space is created. So just giving warning in the error file
should be enough.
*/
void wait_for_free_space(const char *filename, int errors) void wait_for_free_space(const char *filename, int errors)
{ {
if (errors == 0)
my_error(EE_DISK_FULL,MYF(ME_BELL | ME_NOREFRESH),
filename,my_errno,MY_WAIT_FOR_USER_TO_FIX_PANIC);
if (!(errors % MY_WAIT_GIVE_USER_A_MESSAGE)) if (!(errors % MY_WAIT_GIVE_USER_A_MESSAGE))
my_printf_error(EE_DISK_FULL, {
"Retry in %d secs. Message reprinted in %d secs", my_printf_warning(EE(EE_DISK_FULL),
MYF(ME_BELL | ME_NOREFRESH), filename,my_errno,MY_WAIT_FOR_USER_TO_FIX_PANIC);
my_printf_warning("Retry in %d secs. Message reprinted in %d secs",
MY_WAIT_FOR_USER_TO_FIX_PANIC, MY_WAIT_FOR_USER_TO_FIX_PANIC,
MY_WAIT_GIVE_USER_A_MESSAGE * MY_WAIT_FOR_USER_TO_FIX_PANIC ); MY_WAIT_GIVE_USER_A_MESSAGE * MY_WAIT_FOR_USER_TO_FIX_PANIC );
}
DBUG_EXECUTE_IF("simulate_file_write_error_once",
{
(void) sleep(1);
return;
});
(void) sleep(MY_WAIT_FOR_USER_TO_FIX_PANIC); (void) sleep(MY_WAIT_FOR_USER_TO_FIX_PANIC);
} }
......
...@@ -148,6 +148,28 @@ void my_printv_error(uint error, const char *format, myf MyFlags, va_list ap) ...@@ -148,6 +148,28 @@ void my_printv_error(uint error, const char *format, myf MyFlags, va_list ap)
DBUG_VOID_RETURN; DBUG_VOID_RETURN;
} }
/*
Warning as printf
SYNOPSIS
my_printf_warning()
format> Format string
...> variable list
*/
void(*sql_print_warning_hook)(const char *format,...);
void my_printf_warning(const char *format, ...)
{
va_list args;
char wbuff[ERRMSGSIZE];
DBUG_ENTER("my_printf_warning");
DBUG_PRINT("my", ("Format: %s", format));
va_start(args,format);
(void) my_vsnprintf (wbuff, sizeof(wbuff), format, args);
va_end(args);
(*sql_print_warning_hook)(wbuff);
DBUG_VOID_RETURN;
}
/* /*
Give message using error_handler_hook Give message using error_handler_hook
......
...@@ -33,6 +33,8 @@ size_t my_write(File Filedes, const uchar *Buffer, size_t Count, myf MyFlags) ...@@ -33,6 +33,8 @@ size_t my_write(File Filedes, const uchar *Buffer, size_t Count, myf MyFlags)
if (unlikely(!Count)) if (unlikely(!Count))
DBUG_RETURN(0); DBUG_RETURN(0);
DBUG_EXECUTE_IF ("simulate_file_write_error_once",
{ DBUG_SET("+d,simulate_file_write_error");});
for (;;) for (;;)
{ {
#ifdef _WIN32 #ifdef _WIN32
...@@ -65,6 +67,8 @@ size_t my_write(File Filedes, const uchar *Buffer, size_t Count, myf MyFlags) ...@@ -65,6 +67,8 @@ size_t my_write(File Filedes, const uchar *Buffer, size_t Count, myf MyFlags)
{ {
wait_for_free_space(my_filename(Filedes), errors); wait_for_free_space(my_filename(Filedes), errors);
errors++; errors++;
DBUG_EXECUTE_IF("simulate_file_write_error_once",
{ DBUG_SET("-d,simulate_file_write_error");});
continue; continue;
} }
......
...@@ -4507,6 +4507,7 @@ int mysqld_main(int argc, char **argv) ...@@ -4507,6 +4507,7 @@ int mysqld_main(int argc, char **argv)
After this we can't quit by a simple unireg_abort After this we can't quit by a simple unireg_abort
*/ */
error_handler_hook= my_message_sql; error_handler_hook= my_message_sql;
sql_print_warning_hook = sql_print_warning;
start_signal_handler(); // Creates pidfile start_signal_handler(); // Creates pidfile
if (mysql_rm_tmp_tables() || acl_init(opt_noacl) || if (mysql_rm_tmp_tables() || acl_init(opt_noacl) ||
......
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