summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authorYukihiro "Matz" Matsumoto <[email protected]>2013-05-26 00:37:44 +0900
committerYukihiro "Matz" Matsumoto <[email protected]>2013-05-26 00:37:44 +0900
commitd78f23d28b4706e58622493de60e17818b491fde (patch)
tree3df0f0c4f51ce40153c2d90f56e1f69fd382ac40
parent9ea1155c983515f0cf31b463fa802493935650e6 (diff)
downloadmruby-d78f23d28b4706e58622493de60e17818b491fde.tar.gz
mruby-d78f23d28b4706e58622493de60e17818b491fde.zip
fix fiber GC problem
-rw-r--r--mrbgems/mruby-fiber/src/fiber.c4
-rw-r--r--src/gc.c2
2 files changed, 5 insertions, 1 deletions
diff --git a/mrbgems/mruby-fiber/src/fiber.c b/mrbgems/mruby-fiber/src/fiber.c
index 5be2095f7..317fdb06a 100644
--- a/mrbgems/mruby-fiber/src/fiber.c
+++ b/mrbgems/mruby-fiber/src/fiber.c
@@ -171,6 +171,8 @@ fiber_resume(mrb_state *mrb, mrb_value self)
}
c->cibase->argc = len;
c->prev = mrb->c;
+ if (c->prev->fib)
+ mrb_field_write_barrier(mrb, (struct RBasic*)c->fib, (struct RBasic*)c->prev->fib);
c->status = MRB_FIBER_RUNNING;
mrb->c = c;
@@ -179,6 +181,8 @@ fiber_resume(mrb_state *mrb, mrb_value self)
}
MARK_CONTEXT_MODIFY(c);
c->prev = mrb->c;
+ if (c->prev->fib)
+ mrb_field_write_barrier(mrb, (struct RBasic*)c->fib, (struct RBasic*)c->prev->fib);
c->status = MRB_FIBER_RUNNING;
mrb->c = c;
return fiber_result(mrb, a, len);
diff --git a/src/gc.c b/src/gc.c
index 4d0ba8a16..00ddadffc 100644
--- a/src/gc.c
+++ b/src/gc.c
@@ -623,7 +623,7 @@ root_scan_phase(mrb_state *mrb)
/* mark exception */
mrb_gc_mark(mrb, (struct RBasic*)mrb->exc);
- mark_context(mrb, mrb->c);
+ mark_context(mrb, mrb->root_c);
/* mark irep pool */
if (mrb->irep) {
size_t len = mrb->irep_len;