summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog5
-rw-r--r--gc.c10
2 files changed, 13 insertions, 2 deletions
diff --git a/ChangeLog b/ChangeLog
index 1749b99b52..b7e62ab2e9 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,8 @@
+Fri Aug 1 21:36:00 2008 Yusuke Endoh <mame@tsg.ne.jp>
+
+ * gc.c (allocate_heaps, assign_heap_slot, rb_newobj_from_heap):
+ reset during_gc before raising NoMemoryError.
+
Fri Aug 1 21:29:56 2008 Yusuke Endoh <mame@tsg.ne.jp>
* vm.c (Init_BareVM): check failure of malloc().
diff --git a/gc.c b/gc.c
index 6b14d6745d..27fd988bd9 100644
--- a/gc.c
+++ b/gc.c
@@ -555,7 +555,10 @@ allocate_heaps(rb_objspace_t *objspace, size_t next_heaps_length)
p = heaps = (struct heaps_slot *)malloc(size);
}
);
- if (p == 0) rb_memerror();
+ if (p == 0) {
+ during_gc = 0;
+ rb_memerror();
+ }
heaps_length = next_heaps_length;
}
@@ -568,8 +571,10 @@ assign_heap_slot(rb_objspace_t *objspace)
objs = HEAP_OBJ_LIMIT;
RUBY_CRITICAL(p = (RVALUE*)malloc(HEAP_SIZE));
- if (p == 0)
+ if (p == 0) {
+ during_gc = 0;
rb_memerror();
+ }
membase = p;
if ((VALUE)p % sizeof(RVALUE) != 0) {
@@ -663,6 +668,7 @@ rb_newobj_from_heap(rb_objspace_t *objspace)
if ((ruby_gc_stress && !ruby_disable_gc_stress) || !freelist) {
if (!heaps_increment(objspace) && !garbage_collect(objspace)) {
+ during_gc = 0;
rb_memerror();
}
}