Commit 8882d71f authored by Michael Widenius's avatar Michael Widenius

Make event stop code even more robust.

(Test failed if we added my_sleep(200000) in event_queue::cond_wait() just before pthread_cond_wait();  Not likely scenario but better to get that fixed too)
parent 4cb68c0e
...@@ -648,7 +648,14 @@ Event_scheduler::stop() ...@@ -648,7 +648,14 @@ Event_scheduler::stop()
/* thd could be 0x0, when shutting down */ /* thd could be 0x0, when shutting down */
sql_print_information("Event Scheduler: " sql_print_information("Event Scheduler: "
"Waiting for the scheduler thread to reply"); "Waiting for the scheduler thread to reply");
COND_STATE_WAIT(thd, NULL, "Waiting scheduler to stop");
/*
Wait only 2 seconds, as there is a small chance the thread missed the
above awake() call and we may have to do it again
*/
struct timespec top_time;
set_timespec(top_time, 2);
COND_STATE_WAIT(thd, &top_time, "Waiting scheduler to stop");
} while (state == STOPPING); } while (state == STOPPING);
DBUG_PRINT("info", ("Scheduler thread has cleaned up. Set state to INIT")); DBUG_PRINT("info", ("Scheduler thread has cleaned up. Set state to INIT"));
sql_print_information("Event Scheduler: Stopped"); sql_print_information("Event Scheduler: Stopped");
......
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