From 889a1bb95e87ad19bd25d0d60838b4f3e85e29fc Mon Sep 17 00:00:00 2001 From: shyouhei Date: Sat, 7 Jun 2008 20:32:26 +0000 Subject: merge revision(s) 14255: * gc.c (stack_end_address): use local variable address instead of __builtin_frame_address(0) to avoid SEGV on SunOS 5.11 on x86 with gcc (GCC) 3.4.3 (csl-sol210-3_4-20050802). git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_8_5@16990 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- gc.c | 9 +++++---- version.h | 2 +- 2 files changed, 6 insertions(+), 5 deletions(-) diff --git a/gc.c b/gc.c index 2e171bd9d7..996713ef19 100644 --- a/gc.c +++ b/gc.c @@ -449,12 +449,13 @@ static unsigned int STACK_LEVEL_MAX = 655300; # if ( __GNUC__ == 3 && __GNUC_MINOR__ > 0 ) || __GNUC__ > 3 __attribute__ ((noinline)) # endif -static VALUE * -stack_end_address(void) +static void +stack_end_address(VALUE **stack_end_p) { - return (VALUE *)__builtin_frame_address(0); + VALUE stack_end; + *stack_end_p = &stack_end; } -# define SET_STACK_END VALUE *stack_end = stack_end_address() +# define SET_STACK_END VALUE *stack_end; stack_end_address(&stack_end) # else # define SET_STACK_END VALUE *stack_end = alloca(1) # endif diff --git a/version.h b/version.h index 658331498a..f3e6c81b2a 100644 --- a/version.h +++ b/version.h @@ -2,7 +2,7 @@ #define RUBY_RELEASE_DATE "2008-06-08" #define RUBY_VERSION_CODE 185 #define RUBY_RELEASE_CODE 20080608 -#define RUBY_PATCHLEVEL 159 +#define RUBY_PATCHLEVEL 160 #define RUBY_VERSION_MAJOR 1 #define RUBY_VERSION_MINOR 8 -- cgit v1.2.3