summaryrefslogtreecommitdiffhomepage
path: root/src
diff options
context:
space:
mode:
authorYukihiro "Matz" Matsumoto <[email protected]>2017-06-14 02:26:00 +0900
committerYukihiro "Matz" Matsumoto <[email protected]>2017-06-14 02:49:07 +0900
commitb979226871ab4a0f9977720d2a1fbf278d446cd3 (patch)
tree83e0a3318c940d48b5c61783412840b7af591e69 /src
parent7830b841c74f83c15c4b67ca89f1e908b68e5b7d (diff)
downloadmruby-b979226871ab4a0f9977720d2a1fbf278d446cd3.tar.gz
mruby-b979226871ab4a0f9977720d2a1fbf278d446cd3.zip
Clear stack in OP_CALL; fix #3694
Diffstat (limited to 'src')
-rw-r--r--src/vm.c12
1 files changed, 7 insertions, 5 deletions
diff --git a/src/vm.c b/src/vm.c
index a0f9adfd4..4b121cecb 100644
--- a/src/vm.c
+++ b/src/vm.c
@@ -856,9 +856,7 @@ mrb_vm_run(mrb_state *mrb, struct RProc *proc, mrb_value self, unsigned int stac
if (stack_keep > nregs)
nregs = stack_keep;
stack_extend(mrb, nregs);
- if (nregs > stack_keep) {
- stack_clear(c->stack + stack_keep, nregs - stack_keep);
- }
+ stack_clear(c->stack + stack_keep, nregs - stack_keep);
c->stack[0] = self;
result = mrb_vm_exec(mrb, proc, irep->iseq);
if (c->ci - c->cibase > cioff) {
@@ -1437,10 +1435,14 @@ RETRY_TRY_BLOCK:
syms = irep->syms;
ci->nregs = irep->nregs;
if (ci->argc < 0) {
- stack_extend(mrb, (irep->nregs < 3) ? 3 : irep->nregs);
+ if (irep->nregs > 3) {
+ stack_extend(mrb, irep->nregs);
+ stack_clear(regs+3, irep->nregs-3);
+ }
}
- else {
+ else if (ci->argc+2 < irep->nregs) {
stack_extend(mrb, irep->nregs);
+ stack_clear(regs+ci->argc+2, irep->nregs-ci->argc-2);
}
if (m->env) {
regs[0] = m->env->stack[0];