From: Tom Tromey Date: Sat, 6 Jul 2013 20:31:16 +0000 (-0600) Subject: add assertion to flush_stack_call_func X-Git-Tag: emacs-26.0.90~1144^2~17^2~28 X-Git-Url: http://git.eshelyaron.com/gitweb/?a=commitdiff_plain;h=0a6f2ff0c8ceb29703e76cddd46ea3f176dd873a;p=emacs.git add assertion to flush_stack_call_func functions called via flush_stack_call_func are assumed to return with the global lock held again, and with current_thread reset. this assertion verifies part of this --- diff --git a/src/alloc.c b/src/alloc.c index b5885bdb283..d62b671d440 100644 --- a/src/alloc.c +++ b/src/alloc.c @@ -4649,6 +4649,7 @@ void flush_stack_call_func (void (*func) (void *arg), void *arg) { void *end; + struct thread_state *self = current_thread; #ifdef HAVE___BUILTIN_UNWIND_INIT /* Force callee-saved registers and register windows onto the stack. @@ -4702,8 +4703,10 @@ flush_stack_call_func (void (*func) (void *arg), void *arg) #endif /* not GC_SAVE_REGISTERS_ON_STACK */ #endif /* not HAVE___BUILTIN_UNWIND_INIT */ - current_thread->stack_top = end; + self->stack_top = end; (*func) (arg); + + eassert (current_thread == self); } #endif /* GC_MARK_STACK != 0 */