Ran
|
Jobs
1
|
Files
89
|
Run time
6s
|
Badge
README BADGES
|
push
github
Restore cur_L for specific Lua/C API use case. Thanks to Peter Cawley. (cherry-picked from commit e86990f7f) Consider the following Lua C API function: ``` static int error_after_coroutine_return(lua_State *L) { lua_State *innerL = lua_newthread(L); luaL_loadstring(innerL, "print('inner coro')"); lua_pcall(innerL, 0, 0, 0); luaL_error(L, "my fancy error"); return 0; } ``` And the following Lua script: ``` local libcur_L = require('libcur_L') local function onesnap_f(var) if var then return 1 else return 0 end end -- Compile function to trace with snapshot. if jit then jit.opt.start('hotloop=1') end onesnap_f(true) onesnap_f(true) local r, s = pcall(libcur_L.error_after_coroutine_return) onesnap_f(false) ``` This is the only case when `cur_L` is not restored, according to the analysis done in https://github.com/LuaJIT/LuaJIT/issues/1066. This patch changes the error-catching routine, so now the patch sets the actual cur_L there. Now it is possible to throw errors on non-executing coroutines, which is a violation of the Lua C API. So, even though it is now possible, that behavior should be avoided anyway. Maxim Kokryashkin: * added the description for the problem Resolves tarantool/tarantool#6323
5344 of 5972 branches covered (0.0%)
Branch coverage included in aggregate %.
4 of 4 new or added lines in 1 file covered. (100.0%)
20499 of 23296 relevant lines covered (87.99%)
2744986.07 hits per line
Lines | Coverage | ∆ | File |
---|---|---|---|
1 |
72.73 |
0.08% | src/lj_crecord.c |
2 |
91.4 |
0.41% | src/lib_base.c |
4 |
95.69 |
-0.12% | src/lj_state.c |
26 |
89.38 |
0.0% | src/lj_err.c |
173 |
73.0 |
0.08% | src/lj_api.c |
ID | Job ID | Ran | Files | Coverage | |
---|---|---|---|---|---|
1 | 6340880138.1 | 89 |
88.3 |
GitHub Action Run |
Coverage | ∆ | File | Lines | Relevant | Covered | Missed | Hits/Line | Branch Hits | Branch Misses |
---|---|---|---|---|---|---|---|---|---|
13.79 | src/lj_utils_leb128.c | 132 | 51 | 7 | 44 | 1470123.0 - 539 | 1 | 6 | |
61.83 | src/lj_cparse.c | 1935 | 1029 | 635 | 394 | 186995.0 - 64 | 183 | 111 | |
61.83 | src/lj_clib.c | 431 | 101 | 65 | 36 | 2737.0 - 1.0 | 16 | 14 | |
64.75 | src/lj_cconv.c | 763 | 387 | 238 | 149 | 517498.0 - 244 | 89 | 29 | |
70.38 | src/lj_carith.c | 429 | 252 | 175 | 77 | 557384.0 - 224 | 65 | 24 | |
72.73 | src/lj_crecord.c | 1912 | 927 | 656 + 1 | 271 - 1 | 66.0 - 1.0 | 208 | 53 | |
72.86 | src/lj_strscan.c | 537 | 261 | 188 | 73 | 2693057.0 - 162071 | 102 | 35 | |
73.0 | src/lj_api.c | 1368 - 5 | 859 - 4 | 622 - 2 | 237 - 2 | 962797.0 + 2001 | 173 | 57 | |
75.0 | src/lib_ffi.c | 866 | 518 | 387 | 131 | 85597.0 - 40 | 99 | 31 | |
75.77 | src/lj_opt_fold.c | 2522 | 971 | 720 | 251 | 21935.0 - 43 | 237 | 55 |