aboutsummaryrefslogtreecommitdiffhomepage
path: root/ir
diff options
context:
space:
mode:
authorlemon <lsof@mailbox.org>2026-03-14 17:39:29 +0100
committerlemon <lsof@mailbox.org>2026-03-14 17:46:57 +0100
commitde8673af7c0885201f284ffd8851ece2cde8cb18 (patch)
tree162475f18ce772b3038250f6422b7626a1d75815 /ir
parent1400850e7f579d2c0aa2bf2dddffc4e05d87a804 (diff)
eval & fold: handle division overflow for MIN/-1
Diffstat (limited to 'ir')
-rw-r--r--ir/fold.c8
1 files changed, 6 insertions, 2 deletions
diff --git a/ir/fold.c b/ir/fold.c
index 92d17fa..4c9861e 100644
--- a/ir/fold.c
+++ b/ir/fold.c
@@ -41,9 +41,13 @@ foldint(enum op op, enum irclass k, union ref lr, union ref rr)
case Oadd: x = l.u + r.u; break;
case Osub: x = l.u - r.u; break;
case Omul: x = l.u * r.u; break;
- case Odiv: x = w ? l.s / r.s : (int)l.s / (int)r.s; break;
+ case Odiv: if (r.s == -1 && (w ? l.s == LLONG_MIN : (int)l.s == INT_MIN)) x = l.s;
+ else x = w ? l.s / r.s : (int)l.s / (int)r.s;
+ break;
case Oudiv: x = w ? l.u / r.u : (uint)l.u / (uint)r.u; break;
- case Orem: x = w ? l.s % r.s : (int)l.s % (int)r.s; break;
+ case Orem: if (r.s == -1 && (w ? l.s == LLONG_MIN : (int)l.s == INT_MIN)) x = 0;
+ else x = w ? l.s % r.s : (int)l.s % (int)r.s;
+ break;
case Ourem: x = w ? l.u % r.u : (uint)l.u % (uint)r.u; break;
case Oand: x = l.u & r.u; break;
case Oior: x = l.u | r.u; break;