From b1cd2f83b5d085bb71368b87c91a461be77d4364 Mon Sep 17 00:00:00 2001 From: Mike Pall Date: Sat, 6 Dec 2025 08:39:11 +0100 Subject: DUALNUM: Fix narrowing of unary minus. Reported by Sergey Kaplun. #1418 --- src/lj_opt_narrow.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) (limited to 'src') diff --git a/src/lj_opt_narrow.c b/src/lj_opt_narrow.c index 3085c837..a4a1c8ee 100644 --- a/src/lj_opt_narrow.c +++ b/src/lj_opt_narrow.c @@ -545,9 +545,9 @@ TRef lj_opt_narrow_unm(jit_State *J, TRef rc, TValue *vc) rc = conv_str_tonum(J, rc, vc); if (tref_isinteger(rc)) { uint32_t k = (uint32_t)numberVint(vc); - if ((LJ_DUALNUM || k != 0) && k != 0x80000000u) { + if ((tvisint(vc) || k != 0) && k != 0x80000000u) { TRef zero = lj_ir_kint(J, 0); - if (!LJ_DUALNUM) + if (!tvisint(vc)) emitir(IRTGI(IR_NE), rc, zero); return emitir(IRTGI(IR_SUBOV), zero, rc); } -- cgit v1.2.3-55-g6feb