aboutsummaryrefslogtreecommitdiff
path: root/sim
diff options
context:
space:
mode:
Diffstat (limited to 'sim')
-rw-r--r--sim/testsuite/v850/mul.cgs15
-rw-r--r--sim/v850/simops.c4
2 files changed, 17 insertions, 2 deletions
diff --git a/sim/testsuite/v850/mul.cgs b/sim/testsuite/v850/mul.cgs
new file mode 100644
index 0000000..7d19b70
--- /dev/null
+++ b/sim/testsuite/v850/mul.cgs
@@ -0,0 +1,15 @@
+# v850e mul
+# mach: v850e
+# as(v850e): -mv850e
+
+ .include "testutils.inc"
+
+# Trivial regression test for incorrect sign bit handling in mul
+
+ seti -10, r1
+ seti 2, r2
+ mul r1, r2, r3
+ reg r2, -20
+ reg r3, -1
+
+ pass
diff --git a/sim/v850/simops.c b/sim/v850/simops.c
index 8fac8bd..d264057 100644
--- a/sim/v850/simops.c
+++ b/sim/v850/simops.c
@@ -339,10 +339,10 @@ Multiply64 (int sign, unsigned long op0)
sign = (op0 ^ op1) & 0x80000000;
- if (((signed long) op0) < 0)
+ if (op0 & 0x80000000)
op0 = - op0;
- if (((signed long) op1) < 0)
+ if (op1 & 0x80000000)
op1 = - op1;
}