diff options
author | Mike Pall <mike> | 2021-07-19 17:03:16 +0200 |
---|---|---|
committer | Mike Pall <mike> | 2021-07-19 17:03:16 +0200 |
commit | 6ca580155b035fd369f193cdee59391b594a5028 (patch) | |
tree | 37e72019d7cb5d63abc73c9e1e3c7021267f0569 | |
parent | 44bd7437a27e0d19bcf878c20ad27a673f17f40b (diff) | |
download | luajit2-6ca580155b035fd369f193cdee59391b594a5028.tar.gz |
Avoid out-of-range number of results when compiling select(k, ...).
The interpreter will throw and abort the trace, anyway.
-rw-r--r-- | src/lj_ffrecord.c | 2 |
1 files changed, 1 insertions, 1 deletions
diff --git a/src/lj_ffrecord.c b/src/lj_ffrecord.c index ff6ecc51..9405e694 100644 --- a/src/lj_ffrecord.c +++ b/src/lj_ffrecord.c @@ -256,9 +256,9 @@ static void LJ_FASTCALL recff_select(jit_State *J, RecordFFData *rd) ptrdiff_t n = (ptrdiff_t)J->maxslot; if (start < 0) start += n; else if (start > n) start = n; - rd->nres = n - start; if (start >= 1) { ptrdiff_t i; + rd->nres = n - start; for (i = 0; i < n - start; i++) J->base[i] = J->base[start+i]; } /* else: Interpreter will throw. */ |