From ee29ae309e17ce727ea0dc120d254b42d37c9dc3 Mon Sep 17 00:00:00 2001 From: ian Date: Fri, 10 Feb 2012 15:55:37 +0000 Subject: [PATCH] runtime: For g0 set stack_size to 0 when not -fsplit-stack. git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@184099 138bc75d-0d04-0410-961f-82ee72b054a4 --- libgo/runtime/proc.c | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/libgo/runtime/proc.c b/libgo/runtime/proc.c index 42a5779bc99..94c2a51730e 100644 --- a/libgo/runtime/proc.c +++ b/libgo/runtime/proc.c @@ -909,7 +909,9 @@ runtime_mstart(void* mp) __splitstack_getcontext(&g->stack_context[0]); #else g->gcinitial_sp = ∓ - g->gcstack_size = StackMin; + // Setting gcstack_size to 0 is a marker meaning that gcinitial_sp + // is the top of the stack, not the bottom. + g->gcstack_size = 0; g->gcnext_sp = ∓ #endif getcontext(&g->context); @@ -1267,6 +1269,8 @@ __go_go(void (*fn)(void*), void* arg) #else sp = newg->gcinitial_sp; spsize = newg->gcstack_size; + if(spsize == 0) + runtime_throw("bad spsize in __go_go"); newg->gcnext_sp = sp; #endif } else { -- 2.11.0