aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sim/d10v/d10v_sim.h12
-rw-r--r--sim/d10v/endian.c63
-rw-r--r--sim/d10v/interp.c63
3 files changed, 69 insertions, 69 deletions
diff --git a/sim/d10v/d10v_sim.h b/sim/d10v/d10v_sim.h
index 038f23a..3ecdc7a 100644
--- a/sim/d10v/d10v_sim.h
+++ b/sim/d10v/d10v_sim.h
@@ -167,12 +167,12 @@ extern struct simops Simops[];
#undef ENDIAN_INLINE
#else
-uint32 get_longword PARAMS ((uint8 *));
-uint16 get_word PARAMS ((uint8 *));
-int64 get_longlong PARAMS ((uint8 *));
-void write_word PARAMS ((uint8 *addr, uint16 data));
-void write_longword PARAMS ((uint8 *addr, uint32 data));
-void write_longlong PARAMS ((uint8 *addr, int64 data));
+extern uint32 get_longword PARAMS ((uint8 *));
+extern uint16 get_word PARAMS ((uint8 *));
+extern int64 get_longlong PARAMS ((uint8 *));
+extern void write_word PARAMS ((uint8 *addr, uint16 data));
+extern void write_longword PARAMS ((uint8 *addr, uint32 data));
+extern void write_longlong PARAMS ((uint8 *addr, int64 data));
#endif
#define SW(addr,data) write_word((long)(addr)+State.imem,data)
diff --git a/sim/d10v/endian.c b/sim/d10v/endian.c
new file mode 100644
index 0000000..929edc9
--- /dev/null
+++ b/sim/d10v/endian.c
@@ -0,0 +1,63 @@
+#ifndef ENDIAN_INLINE
+#define NO_ENDIAN_INLINE
+#include "d10v_sim.h"
+#define ENDIAN_INLINE
+#endif
+
+ENDIAN_INLINE uint32
+get_longword (x)
+ uint8 *x;
+{
+ return ((uint32)x[0]<<24) + ((uint32)x[1]<<16) + ((uint32)x[2]<<8) + ((uint32)x[3]);
+}
+
+ENDIAN_INLINE int64
+get_longlong (x)
+ uint8 *x;
+{
+ uint32 top = ((uint32)x[0]<<24) + ((uint32)x[1]<<16) + ((uint32)x[2]<<8) + ((uint32)x[3]);
+ uint32 bottom = ((uint32)x[4]<<24) + ((uint32)x[5]<<16) + ((uint32)x[6]<<8) + ((uint32)x[7]);
+ return (((int64)top)<<32) | (int64)bottom;
+}
+
+ENDIAN_INLINE uint16
+get_word (x)
+ uint8 *x;
+{
+ return ((uint16)x[0]<<8) + x[1];
+}
+
+ENDIAN_INLINE void
+write_word (addr, data)
+ uint8 *addr;
+ uint16 data;
+{
+ addr[0] = (data >> 8) & 0xff;
+ addr[1] = data & 0xff;
+}
+
+ENDIAN_INLINE void
+write_longword (addr, data)
+ uint8 *addr;
+ uint32 data;
+{
+ addr[0] = (data >> 24) & 0xff;
+ addr[1] = (data >> 16) & 0xff;
+ addr[2] = (data >> 8) & 0xff;
+ addr[3] = data & 0xff;
+}
+
+ENDIAN_INLINE void
+write_longlong (addr, data)
+ uint8 *addr;
+ int64 data;
+{
+ addr[0] = data >> 56;
+ addr[1] = (data >> 48) & 0xff;
+ addr[2] = (data >> 40) & 0xff;
+ addr[3] = (data >> 32) & 0xff;
+ addr[4] = (data >> 24) & 0xff;
+ addr[5] = (data >> 16) & 0xff;
+ addr[6] = (data >> 8) & 0xff;
+ addr[7] = data & 0xff;
+}
diff --git a/sim/d10v/interp.c b/sim/d10v/interp.c
index 11a18c4..d06b86b 100644
--- a/sim/d10v/interp.c
+++ b/sim/d10v/interp.c
@@ -65,69 +65,6 @@ lookup_hash (ins, size)
return (h);
}
-uint32
-get_longword (x)
- uint8 *x;
-{
- uint8 *a = x;
- return (a[0]<<24) + (a[1]<<16) + (a[2]<<8) + (a[3]);
-}
-
-int64
-get_longlong (x)
- uint8 *x;
-{
- uint8 *a = x;
- return ((int64)a[0]<<56) + ((int64)a[1]<<48) + ((int64)a[2]<<40) + ((int64)a[3]<<32) +
- ((int64)a[4]<< 24) + ((int64)a[5]<<16) + ((int64)a[6]<<8) + (int64)a[7];
-}
-
-uint16
-get_word (x)
- uint8 *x;
-{
- uint8 *a = x;
- return ((uint16)a[0]<<8) + a[1];
-}
-
-
-void
-write_word (addr, data)
- uint8 *addr;
- uint16 data;
-{
- uint8 *a = addr;
- a[0] = data >> 8;
- a[1] = data & 0xff;
-}
-
-void
-write_longword (addr, data)
- uint8 *addr;
- uint32 data;
-{
- addr[0] = (data >> 24) & 0xff;
- addr[1] = (data >> 16) & 0xff;
- addr[2] = (data >> 8) & 0xff;
- addr[3] = data & 0xff;
-}
-
-void
-write_longlong (addr, data)
- uint8 *addr;
- int64 data;
-{
- uint8 *a = addr;
- a[0] = data >> 56;
- a[1] = (data >> 48) & 0xff;
- a[2] = (data >> 40) & 0xff;
- a[3] = (data >> 32) & 0xff;
- a[4] = (data >> 24) & 0xff;
- a[5] = (data >> 16) & 0xff;
- a[6] = (data >> 8) & 0xff;
- a[7] = data & 0xff;
-}
-
static void
get_operands (struct simops *s, uint32 ins)
{