summaryrefslogtreecommitdiff
path: root/gc.c
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2004-06-16 07:01:32 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2004-06-16 07:01:32 +0000
commit35ec0ad3f34424267a9193a472f093a648b451a3 (patch)
tree086655da35e1b9c382f017088914436d54158136 /gc.c
parent8335f4254342066c5a428542eb16f7a9794c24ec (diff)
* gc.c (stack_grow_direction): memoize the direction.
* gc.c (Init_stack): should always move to end of VALUE. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_8@6461 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'gc.c')
-rw-r--r--gc.c11
1 files changed, 7 insertions, 4 deletions
diff --git a/gc.c b/gc.c
index 24ac61dfb4..ce3d72645f 100644
--- a/gc.c
+++ b/gc.c
@@ -447,15 +447,17 @@ static unsigned int STACK_LEVEL_MAX = 655300;
#elif STACK_GROW_DIRECTION < 0
# define STACK_UPPER(x, a, b) b
#else
+static int grow_direction;
static int
-stack_growup_p(addr)
+stack_grow_direction(addr)
VALUE *addr;
{
SET_STACK_END;
- if (STACK_END > addr) return Qtrue;
- return Qfalse;
+ if (STACK_END > addr) return grow_direction = 1;
+ return grow_direction = -1;
}
+# define stack_growup_p(x) ((grow_direction ? grow_direction : stack_grow_direction(x)) > 0)
# define STACK_UPPER(x, a, b) (stack_growup_p(x) ? a : b)
#endif
@@ -1411,10 +1413,11 @@ Init_stack(addr)
rb_gc_stack_start = _SEND;
#else
if (!addr) addr = (VALUE *)&addr;
+ STACK_UPPER(&addr, addr, ++addr);
if (rb_gc_stack_start) {
if (STACK_UPPER(&addr,
rb_gc_stack_start > addr,
- rb_gc_stack_start < ++addr))
+ rb_gc_stack_start < addr))
rb_gc_stack_start = addr;
return;
}