summaryrefslogtreecommitdiff
path: root/src/wasm
diff options
context:
space:
mode:
authorAlon Zakai <azakai@google.com>2023-10-04 11:07:00 -0700
committerGitHub <noreply@github.com>2023-10-04 11:07:00 -0700
commit1e17dfb695a19d5d41f1f88411fbcbc5f2408c8f (patch)
treed171071c9cbdbf571a5e1175d922c08e9e0397b1 /src/wasm
parent2abc1a80d42ccd3d8e85543d104b5a6dee127248 (diff)
downloadbinaryen-1e17dfb695a19d5d41f1f88411fbcbc5f2408c8f.tar.gz
binaryen-1e17dfb695a19d5d41f1f88411fbcbc5f2408c8f.tar.bz2
binaryen-1e17dfb695a19d5d41f1f88411fbcbc5f2408c8f.zip
Work around a gcc 13 issue with signbit that made us not compute fmin of -0 properly (#5994)
Diffstat (limited to 'src/wasm')
-rw-r--r--src/wasm/literal.cpp18
1 files changed, 14 insertions, 4 deletions
diff --git a/src/wasm/literal.cpp b/src/wasm/literal.cpp
index 075028127..4bae54693 100644
--- a/src/wasm/literal.cpp
+++ b/src/wasm/literal.cpp
@@ -1526,8 +1526,12 @@ Literal Literal::min(const Literal& other) const {
if (std::isnan(r)) {
return standardizeNaN(Literal(r));
}
+ // This code is written in a form that avoids a gcc 13 bug, see
+ // https://gcc.gnu.org/bugzilla/show_bug.cgi?id=111694
if (l == r && l == 0) {
- return Literal(std::signbit(l) ? l : r);
+ auto lSigned = std::signbit(l);
+ auto rSigned = std::signbit(r);
+ return Literal(lSigned || rSigned ? -0.0f : 0.0f);
}
return Literal(std::min(l, r));
}
@@ -1540,7 +1544,9 @@ Literal Literal::min(const Literal& other) const {
return standardizeNaN(Literal(r));
}
if (l == r && l == 0) {
- return Literal(std::signbit(l) ? l : r);
+ auto lSigned = std::signbit(l);
+ auto rSigned = std::signbit(r);
+ return Literal(lSigned || rSigned ? -0.0 : 0.0);
}
return Literal(std::min(l, r));
}
@@ -1560,7 +1566,9 @@ Literal Literal::max(const Literal& other) const {
return standardizeNaN(Literal(r));
}
if (l == r && l == 0) {
- return Literal(std::signbit(l) ? r : l);
+ auto lSigned = std::signbit(l);
+ auto rSigned = std::signbit(r);
+ return Literal(lSigned && rSigned ? -0.0f : 0.0f);
}
return Literal(std::max(l, r));
}
@@ -1573,7 +1581,9 @@ Literal Literal::max(const Literal& other) const {
return standardizeNaN(Literal(r));
}
if (l == r && l == 0) {
- return Literal(std::signbit(l) ? r : l);
+ auto lSigned = std::signbit(l);
+ auto rSigned = std::signbit(r);
+ return Literal(lSigned && rSigned ? -0.0 : 0.0);
}
return Literal(std::max(l, r));
}