aboutsummaryrefslogtreecommitdiff
path: root/sim/common/sim-alu.h
diff options
context:
space:
mode:
Diffstat (limited to 'sim/common/sim-alu.h')
-rw-r--r--sim/common/sim-alu.h23
1 files changed, 13 insertions, 10 deletions
diff --git a/sim/common/sim-alu.h b/sim/common/sim-alu.h
index 6bb35f0..46306c9 100644
--- a/sim/common/sim-alu.h
+++ b/sim/common/sim-alu.h
@@ -62,11 +62,6 @@
values */
-/* Macro's to type cast 32bit constants to 64bits */
-#define SIGNED64(val) ((signed64)(signed32)(val))
-#define UNSIGNED64(val) ((unsigned64)(unsigned32)(val))
-
-
/* Start a section of ALU code */
#define ALU16_BEGIN(VAL) \
@@ -82,6 +77,14 @@
signed64 alu_overflow_val; \
ALU32_SET(VAL)
+#define ALU64_BEGIN(VAL) \
+{ \
+ natural64 alu_val; \
+ unsigned64 alu_carry_val; \
+ signed64 alu_overflow_val; \
+ ALU64_SET(VAL)
+
+
#define ALU_BEGIN(VAL) XCONCAT3(ALU,WITH_TARGET_WORD_BITSIZE,_BEGIN)(VAL)
/* More basic alu operations */
@@ -128,14 +131,14 @@ do { \
#define ALU64_ADD(VAL) \
do { \
- unsigned64 alu_lo = (UNSIGNED64(alu_val) \
- + UNSIGNED64(VAL)); \
- signed alu_carry = ((alu_lo & BIT(31)) != 0); \
+ unsigned64 val = (VAL); \
+ unsigned64 alu_lo = alu_val + val); \
+ signed alu_carry = ((alu_lo & LSBIT64 (31)) != 0); \
alu_carry_val = (alu_carry_val \
- + UNSIGNED64(EXTRACTED(val, 0, 31)) \
+ + MSEXTRACTED64 (val, 0, 31) \
+ alu_carry); \
alu_overflow_val = (alu_overflow_val \
- + SIGNED64(EXTRACTED(val, 0, 31)) \
+ + MSEXTRACTED64 (val, 0, 31) \
+ alu_carry); \
alu_val = alu_val + val; \
} while (0)