From 86c335dd777aa5533031f9bba2cfa39236a384f0 Mon Sep 17 00:00:00 2001 From: Yuichi Nishiwaki Date: Mon, 1 Sep 2014 08:50:11 +0900 Subject: [PATCH 1/2] vm_tear_off should happen in cont. saving, not in restoring --- src/cont.c | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/cont.c b/src/cont.c index 30d26568..6839c586 100644 --- a/src/cont.c +++ b/src/cont.c @@ -113,9 +113,12 @@ native_stack_length(pic_state *pic, char **pos) static void save_cont(pic_state *pic, struct pic_cont **c) { + void pic_vm_tear_off(pic_state *); struct pic_cont *cont; char *pos; + pic_vm_tear_off(pic); /* tear off */ + cont = *c = (struct pic_cont *)pic_obj_alloc(pic, sizeof(struct pic_cont), PIC_TT_CONT); cont->blk = pic->blk; @@ -163,13 +166,10 @@ native_stack_extend(pic_state *pic, struct pic_cont *cont) noreturn static void restore_cont(pic_state *pic, struct pic_cont *cont) { - void pic_vm_tear_off(pic_state *); char v; struct pic_cont *tmp = cont; struct pic_block *blk; - pic_vm_tear_off(pic); /* tear off */ - if (&v < pic->native_stack_start) { if (&v > cont->stk_pos) native_stack_extend(pic, cont); } From 91f75bc226084f53ffc0c1bd5744bacd361bb150 Mon Sep 17 00:00:00 2001 From: Yuichi Nishiwaki Date: Mon, 1 Sep 2014 08:50:51 +0900 Subject: [PATCH 2/2] lset/lref can access to torn-off regions because of call/cc --- src/vm.c | 12 ++++++++++++ 1 file changed, 12 insertions(+) diff --git a/src/vm.c b/src/vm.c index 99f12f82..2fcd74fc 100644 --- a/src/vm.c +++ b/src/vm.c @@ -668,10 +668,22 @@ pic_apply(pic_state *pic, struct pic_proc *proc, pic_value argv) NEXT; } CASE(OP_LREF) { + pic_callinfo *ci = pic->ci; + + if (ci->env != NULL && ci->env->regs == ci->env->storage) { + PUSH(ci->env->regs[c.u.i - (ci->regs - ci->fp)]); + NEXT; + } PUSH(pic->ci->fp[c.u.i]); NEXT; } CASE(OP_LSET) { + pic_callinfo *ci = pic->ci; + + if (ci->env != NULL && ci->env->regs == ci->env->storage) { + ci->env->regs[c.u.i - (ci->regs - ci->fp)] = POP(); + NEXT; + } pic->ci->fp[c.u.i] = POP(); NEXT; }