aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sim/riscv/ChangeLog4
-rw-r--r--sim/riscv/sim-main.c2
2 files changed, 5 insertions, 1 deletions
diff --git a/sim/riscv/ChangeLog b/sim/riscv/ChangeLog
index 37284a9..367faac 100644
--- a/sim/riscv/ChangeLog
+++ b/sim/riscv/ChangeLog
@@ -1,3 +1,7 @@
+2021-05-01 Mike Frysinger <vapier@gentoo.org>
+
+ * sim-main.c (mulhu): Check if __SIZEOF_INT128__ is defined.
+
2021-04-26 Mike Frysinger <vapier@gentoo.org>
* sim-main.c (MAX, MIN): Delete.
diff --git a/sim/riscv/sim-main.c b/sim/riscv/sim-main.c
index a80dc68..6a2904c 100644
--- a/sim/riscv/sim-main.c
+++ b/sim/riscv/sim-main.c
@@ -603,7 +603,7 @@ execute_i (SIM_CPU *cpu, unsigned_word iw, const struct riscv_opcode *op)
static unsigned64
mulhu (unsigned64 a, unsigned64 b)
{
-#ifdef __GNUC__
+#if defined(__GNUC__) && defined(__SIZEOF_INT128__)
return ((__int128)a * b) >> 64;
#else
uint64_t t;