From ef3cc47f9fb7df9ed2d92c420162cdabed81dc0e Mon Sep 17 00:00:00 2001 From: Mike Pall Date: Fri, 28 Feb 2014 14:09:09 +0100 Subject: [PATCH] Fix recording of BC_VARG. --- src/lj_record.c | 6 ++---- 1 file changed, 2 insertions(+), 4 deletions(-) diff --git a/src/lj_record.c b/src/lj_record.c index 0dfc10b3..c6848fc0 100644 --- a/src/lj_record.c +++ b/src/lj_record.c @@ -1508,10 +1508,8 @@ static void rec_varg(jit_State *J, BCReg dst, ptrdiff_t nresults) } else if (dst + nresults > J->maxslot) { J->maxslot = dst + (BCReg)nresults; } - for (i = 0; i < nresults; i++) { - J->base[dst+i] = i < nvararg ? J->base[i - nvararg - 1] : TREF_NIL; - lua_assert(J->base[dst+i] != 0); - } + for (i = 0; i < nresults; i++) + J->base[dst+i] = i < nvararg ? getslot(J, i - nvararg - 1) : TREF_NIL; } else { /* Unknown number of varargs passed to trace. */ TRef fr = emitir(IRTI(IR_SLOAD), 0, IRSLOAD_READONLY|IRSLOAD_FRAME); int32_t frofs = 8*(1+numparams)+FRAME_VARG;