Commit 141f88d1 authored by Vladislav Vaintroub's avatar Vladislav Vaintroub

MDEV-10357 my_context_continue() does not store current fiber on Windows

Make sure current fiber is saved in my_context::app_fiber
in both my_context_spawn() and my_context_continue()
parent ecb7ce78
...@@ -698,30 +698,27 @@ my_context_destroy(struct my_context *c) ...@@ -698,30 +698,27 @@ my_context_destroy(struct my_context *c)
int int
my_context_spawn(struct my_context *c, void (*f)(void *), void *d) my_context_spawn(struct my_context *c, void (*f)(void *), void *d)
{ {
void *current_fiber;
c->user_func= f; c->user_func= f;
c->user_arg= d; c->user_arg= d;
return my_context_continue(c);
}
int
my_context_continue(struct my_context *c)
{
/* /*
This seems to be a common trick to run ConvertThreadToFiber() only on the This seems to be a common trick to run ConvertThreadToFiber() only on the
first occurence in a thread, in a way that works on multiple Windows first occurence in a thread, in a way that works on multiple Windows
versions. versions.
*/ */
current_fiber= GetCurrentFiber(); void *current_fiber= GetCurrentFiber();
if (current_fiber == NULL || current_fiber == (void *)0x1e00) if (current_fiber == NULL || current_fiber == (void *)0x1e00)
current_fiber= ConvertThreadToFiber(c); current_fiber= ConvertThreadToFiber(c);
c->app_fiber= current_fiber; c->app_fiber= current_fiber;
DBUG_SWAP_CODE_STATE(&c->dbug_state); DBUG_SWAP_CODE_STATE(&c->dbug_state);
SwitchToFiber(c->lib_fiber); SwitchToFiber(c->lib_fiber);
DBUG_SWAP_CODE_STATE(&c->dbug_state); DBUG_SWAP_CODE_STATE(&c->dbug_state);
return c->return_value;
}
int
my_context_continue(struct my_context *c)
{
DBUG_SWAP_CODE_STATE(&c->dbug_state);
SwitchToFiber(c->lib_fiber);
DBUG_SWAP_CODE_STATE(&c->dbug_state);
return c->return_value; return c->return_value;
} }
......
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