diff options
author | Mike Pall <mike> | 2023-09-09 13:37:31 +0200 |
---|---|---|
committer | Mike Pall <mike> | 2023-09-09 13:37:31 +0200 |
commit | 7f9907b4ed0870ba64342bcc4b26cff0a94540da (patch) | |
tree | 54121bc674c71203565cafe9db871b55ab28f473 | |
parent | 4d05806ae046838826f9bab3b3b804eae26cd017 (diff) | |
download | luajit-7f9907b4ed0870ba64342bcc4b26cff0a94540da.tar.gz luajit-7f9907b4ed0870ba64342bcc4b26cff0a94540da.tar.bz2 luajit-7f9907b4ed0870ba64342bcc4b26cff0a94540da.zip |
Add NaN check to IR_NEWREF.
Thanks to Peter Cawley. #1069
-rw-r--r-- | src/lj_opt_fold.c | 5 | ||||
-rw-r--r-- | src/lj_record.c | 12 |
2 files changed, 13 insertions, 4 deletions
diff --git a/src/lj_opt_fold.c b/src/lj_opt_fold.c index ab158143..b437d672 100644 --- a/src/lj_opt_fold.c +++ b/src/lj_opt_fold.c | |||
@@ -1739,7 +1739,10 @@ LJFOLD(NE any any) | |||
1739 | LJFOLDF(comm_equal) | 1739 | LJFOLDF(comm_equal) |
1740 | { | 1740 | { |
1741 | /* For non-numbers only: x == x ==> drop; x ~= x ==> fail */ | 1741 | /* For non-numbers only: x == x ==> drop; x ~= x ==> fail */ |
1742 | if (fins->op1 == fins->op2 && !irt_isnum(fins->t)) | 1742 | if (fins->op1 == fins->op2 && |
1743 | (!irt_isnum(fins->t) || | ||
1744 | (fleft->o == IR_CONV && /* Converted integers cannot be NaN. */ | ||
1745 | (uint32_t)(fleft->op2 & IRCONV_SRCMASK) - (uint32_t)IRT_I8 <= (uint32_t)(IRT_U64 - IRT_U8)))) | ||
1743 | return CONDFOLD(fins->o == IR_EQ); | 1746 | return CONDFOLD(fins->o == IR_EQ); |
1744 | return fold_comm_swap(J); | 1747 | return fold_comm_swap(J); |
1745 | } | 1748 | } |
diff --git a/src/lj_record.c b/src/lj_record.c index 0e14382c..dfcc3f65 100644 --- a/src/lj_record.c +++ b/src/lj_record.c | |||
@@ -1254,10 +1254,16 @@ TRef lj_record_idx(jit_State *J, RecordIndex *ix) | |||
1254 | lua_assert(!hasmm); | 1254 | lua_assert(!hasmm); |
1255 | if (oldv == niltvg(J2G(J))) { /* Need to insert a new key. */ | 1255 | if (oldv == niltvg(J2G(J))) { /* Need to insert a new key. */ |
1256 | TRef key = ix->key; | 1256 | TRef key = ix->key; |
1257 | if (tref_isinteger(key)) /* NEWREF needs a TValue as a key. */ | 1257 | if (tref_isinteger(key)) { /* NEWREF needs a TValue as a key. */ |
1258 | key = emitir(IRTN(IR_CONV), key, IRCONV_NUM_INT); | 1258 | key = emitir(IRTN(IR_CONV), key, IRCONV_NUM_INT); |
1259 | else if (tref_isnumber(key) && tref_isk(key) && tvismzero(&ix->keyv)) | 1259 | } else if (tref_isnum(key)) { |
1260 | key = lj_ir_knum_zero(J); /* Canonicalize -0.0 to +0.0. */ | 1260 | if (tref_isk(key)) { |
1261 | if (tvismzero(&ix->keyv)) | ||
1262 | key = lj_ir_knum_zero(J); /* Canonicalize -0.0 to +0.0. */ | ||
1263 | } else { | ||
1264 | emitir(IRTG(IR_EQ, IRT_NUM), key, key); /* Check for !NaN. */ | ||
1265 | } | ||
1266 | } | ||
1261 | xref = emitir(IRT(IR_NEWREF, IRT_P32), ix->tab, key); | 1267 | xref = emitir(IRT(IR_NEWREF, IRT_P32), ix->tab, key); |
1262 | keybarrier = 0; /* NEWREF already takes care of the key barrier. */ | 1268 | keybarrier = 0; /* NEWREF already takes care of the key barrier. */ |
1263 | } | 1269 | } |