diff options
| author | Yukihiro "Matz" Matsumoto <[email protected]> | 2013-05-26 00:37:44 +0900 |
|---|---|---|
| committer | Yukihiro "Matz" Matsumoto <[email protected]> | 2013-05-26 00:37:44 +0900 |
| commit | d78f23d28b4706e58622493de60e17818b491fde (patch) | |
| tree | 3df0f0c4f51ce40153c2d90f56e1f69fd382ac40 | |
| parent | 9ea1155c983515f0cf31b463fa802493935650e6 (diff) | |
| download | mruby-d78f23d28b4706e58622493de60e17818b491fde.tar.gz mruby-d78f23d28b4706e58622493de60e17818b491fde.zip | |
fix fiber GC problem
| -rw-r--r-- | mrbgems/mruby-fiber/src/fiber.c | 4 | ||||
| -rw-r--r-- | src/gc.c | 2 |
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); @@ -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; |
