diff options
author | Jeff Law <law@redhat.com> | 1996-09-10 02:51:07 +0000 |
---|---|---|
committer | Jeff Law <law@redhat.com> | 1996-09-10 02:51:07 +0000 |
commit | 9909e232c06c030918ea370b6a4a9e55f0767749 (patch) | |
tree | d0de66636f44519ec120a7c92024811986eaff2d /sim/v850/interp.c | |
parent | ca296aab0ea05bd38c724091e13d06126731958f (diff) | |
download | gdb-9909e232c06c030918ea370b6a4a9e55f0767749.zip gdb-9909e232c06c030918ea370b6a4a9e55f0767749.tar.gz gdb-9909e232c06c030918ea370b6a4a9e55f0767749.tar.bz2 |
* interp.c (hash): Make this an inline function
when compiling with GCC. Simplify.
* simpos.c: Explicitly include "sys/syscall.h". Remove
some #if 0'd code. Enable more emulated syscalls.
Checking in more stuff.
Diffstat (limited to 'sim/v850/interp.c')
-rw-r--r-- | sim/v850/interp.c | 42 |
1 files changed, 28 insertions, 14 deletions
diff --git a/sim/v850/interp.c b/sim/v850/interp.c index bb7aa9b..b9f5a9e 100644 --- a/sim/v850/interp.c +++ b/sim/v850/interp.c @@ -6,6 +6,14 @@ #include "v850_sim.h" +#ifndef INLINE +#ifdef __GNUC__ +#define INLINE inline +#else +#define INLINE +#endif +#endif + #define MEM_SIZE 18 /* V850 memory size is 18 bits XXX */ host_callback *v850_callback; @@ -14,6 +22,16 @@ host_callback *v850_callback; uint32 OP[4]; static struct hash_entry *lookup_hash PARAMS ((uint32 ins)); +static long hash PARAMS ((long)); +static void do_format_1_2 PARAMS ((uint32)); +static void do_format_3 PARAMS ((uint32)); +static void do_format_4 PARAMS ((uint32)); +static void do_format_5 PARAMS ((uint32)); +static void do_format_6 PARAMS ((uint32)); +static void do_format_7 PARAMS ((uint32)); +static void do_format_8 PARAMS ((uint32)); +static void do_format_9_10 PARAMS ((uint32)); +static void init_system PARAMS ((void)); #define MAX_HASH 63 struct hash_entry @@ -26,25 +44,22 @@ struct hash_entry struct hash_entry hash_table[MAX_HASH+1]; -static long + +static INLINE long hash(insn) long insn; { if ((insn & 0x0600) == 0 - || (insn & 0x0700) == 0x0200) + || (insn & 0x0700) == 0x0200 + || (insn & 0x0700) == 0x0600 + || (insn & 0x0780) == 0x0700) return (insn & 0x07e0) >> 5; if ((insn & 0x0700) == 0x0300 || (insn & 0x0700) == 0x0400 || (insn & 0x0700) == 0x0500) return (insn & 0x0780) >> 7; - if ((insn & 0x0700) == 0x0600) - return (insn & 0x07e0) >> 5; - if ((insn & 0x0780) == 0x0700) - return (insn & 0x07e0) >> 5; if ((insn & 0x07c0) == 0x0780) return (insn & 0x07c0) >> 6; - if ((insn & 0x07E0) == 0x07C0) - return (insn & 0x07e0) >> 5; return (insn & 0x07e0) >> 5; } @@ -56,7 +71,7 @@ lookup_hash (ins) h = &hash_table[hash(ins)]; - while ( (ins & h->mask) != h->opcode) + while ((ins & h->mask) != h->opcode) { if (h->next == NULL) { @@ -209,7 +224,7 @@ do_format_8 (insn) } static void -do_formats_9_10 (insn) +do_format_9_10 (insn) uint32 insn; { struct hash_entry *h; @@ -266,7 +281,7 @@ sim_open (args) char *args; { struct simops *s; - struct hash_entry *h, *prev; + struct hash_entry *h; if (args != NULL) printf ("sim_open %s\n",args); @@ -317,10 +332,8 @@ sim_resume (step, siggnal) int step, siggnal; { uint32 inst, opcode; - int i; reg_t oldpc; - if (step) State.exception = SIGTRAP; else @@ -373,7 +386,7 @@ sim_resume (step, siggnal) } else { - do_formats_9_10 (inst); + do_format_9_10 (inst); PC += 4; } } @@ -449,6 +462,7 @@ sim_store_register (rn, memory) State.regs[rn]= *(uint32 *)memory; } +int sim_read (addr, buffer, size) SIM_ADDR addr; unsigned char *buffer; |