From 053041a9f47e3d341f98682ea1e4907a578e4920 Mon Sep 17 00:00:00 2001 From: Mike Pall Date: Thu, 20 Jun 2013 16:32:45 +0200 Subject: [PATCH] FFI: Add missing GC steps for callback argument conversions. --- src/lj_ccallback.c | 5 ++++- 1 file changed, 4 insertions(+), 1 deletion(-) diff --git a/src/lj_ccallback.c b/src/lj_ccallback.c index 00109923..c975c88f 100644 --- a/src/lj_ccallback.c +++ b/src/lj_ccallback.c @@ -408,6 +408,7 @@ static void callback_conv_args(CTState *cts, lua_State *L) intptr_t *stack = cts->cb.stack; MSize slot = cts->cb.slot; CTypeID id = 0, rid, fid; + int gcsteps = 0; CType *ct; GCfunc *fn; MSize ngpr = 0, nsp = 0, maxgpr = CCALL_NARG_GPR; @@ -475,7 +476,7 @@ static void callback_conv_args(CTState *cts, lua_State *L) done: if (LJ_BE && cta->size < CTSIZE_PTR) sp = (void *)((uint8_t *)sp + CTSIZE_PTR-cta->size); - lj_cconv_tv_ct(cts, cta, 0, o++, sp); + gcsteps += lj_cconv_tv_ct(cts, cta, 0, o++, sp); } fid = ctf->sib; } @@ -485,6 +486,8 @@ static void callback_conv_args(CTState *cts, lua_State *L) if (ctype_cconv(ct->info) != CTCC_CDECL) (L->base-2)->u32.hi |= (nsp << (16+2)); #endif + while (gcsteps-- > 0) + lj_gc_check(L); } /* Convert Lua object to callback result. */