diff options
| author | Mike Pall <mike> | 2013-06-20 16:32:45 +0200 |
|---|---|---|
| committer | Mike Pall <mike> | 2013-06-20 16:32:45 +0200 |
| commit | 053041a9f47e3d341f98682ea1e4907a578e4920 (patch) | |
| tree | 8821a1a6c9e6706346865aec2c68dd20ef2a9370 | |
| parent | 9211a66e0e2bcbcaffc4a8c76bfc2a39bce6f0e5 (diff) | |
| download | luajit-053041a9f47e3d341f98682ea1e4907a578e4920.tar.gz luajit-053041a9f47e3d341f98682ea1e4907a578e4920.tar.bz2 luajit-053041a9f47e3d341f98682ea1e4907a578e4920.zip | |
FFI: Add missing GC steps for callback argument conversions.
| -rw-r--r-- | src/lj_ccallback.c | 5 |
1 files changed, 4 insertions, 1 deletions
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) | |||
| 408 | intptr_t *stack = cts->cb.stack; | 408 | intptr_t *stack = cts->cb.stack; |
| 409 | MSize slot = cts->cb.slot; | 409 | MSize slot = cts->cb.slot; |
| 410 | CTypeID id = 0, rid, fid; | 410 | CTypeID id = 0, rid, fid; |
| 411 | int gcsteps = 0; | ||
| 411 | CType *ct; | 412 | CType *ct; |
| 412 | GCfunc *fn; | 413 | GCfunc *fn; |
| 413 | MSize ngpr = 0, nsp = 0, maxgpr = CCALL_NARG_GPR; | 414 | MSize ngpr = 0, nsp = 0, maxgpr = CCALL_NARG_GPR; |
| @@ -475,7 +476,7 @@ static void callback_conv_args(CTState *cts, lua_State *L) | |||
| 475 | done: | 476 | done: |
| 476 | if (LJ_BE && cta->size < CTSIZE_PTR) | 477 | if (LJ_BE && cta->size < CTSIZE_PTR) |
| 477 | sp = (void *)((uint8_t *)sp + CTSIZE_PTR-cta->size); | 478 | sp = (void *)((uint8_t *)sp + CTSIZE_PTR-cta->size); |
| 478 | lj_cconv_tv_ct(cts, cta, 0, o++, sp); | 479 | gcsteps += lj_cconv_tv_ct(cts, cta, 0, o++, sp); |
| 479 | } | 480 | } |
| 480 | fid = ctf->sib; | 481 | fid = ctf->sib; |
| 481 | } | 482 | } |
| @@ -485,6 +486,8 @@ static void callback_conv_args(CTState *cts, lua_State *L) | |||
| 485 | if (ctype_cconv(ct->info) != CTCC_CDECL) | 486 | if (ctype_cconv(ct->info) != CTCC_CDECL) |
| 486 | (L->base-2)->u32.hi |= (nsp << (16+2)); | 487 | (L->base-2)->u32.hi |= (nsp << (16+2)); |
| 487 | #endif | 488 | #endif |
| 489 | while (gcsteps-- > 0) | ||
| 490 | lj_gc_check(L); | ||
| 488 | } | 491 | } |
| 489 | 492 | ||
| 490 | /* Convert Lua object to callback result. */ | 493 | /* Convert Lua object to callback result. */ |
