diff options
-rw-r--r-- | sim/arm/armos.c | 17 | ||||
-rw-r--r-- | sim/common/callback.c | 42 | ||||
-rw-r--r-- | sim/common/gentmap.c | 6 |
3 files changed, 40 insertions, 25 deletions
diff --git a/sim/arm/armos.c b/sim/arm/armos.c index a3713a5..a8ef7e4 100644 --- a/sim/arm/armos.c +++ b/sim/arm/armos.c @@ -31,11 +31,6 @@ #include <errno.h> #include <limits.h> #include <string.h> -#include "targ-vals.h" - -#ifndef TARGET_O_BINARY -#define TARGET_O_BINARY 0 -#endif #ifdef HAVE_UNISTD_H #include <unistd.h> /* For SEEK_SET etc. */ @@ -188,7 +183,17 @@ ARMul_OSInit (ARMul_State * state) return TRUE; } -static int translate_open_mode[] = +/* These are libgloss defines, but seem to be common across all supported ARM + targets at the moment. These should get moved to the callback open_map. */ +#define TARGET_O_BINARY 0 +#define TARGET_O_APPEND 0x8 +#define TARGET_O_CREAT 0x200 +#define TARGET_O_RDONLY 0x0 +#define TARGET_O_RDWR 0x2 +#define TARGET_O_TRUNC 0x400 +#define TARGET_O_WRONLY 0x1 + +static const int translate_open_mode[] = { TARGET_O_RDONLY, /* "r" */ TARGET_O_RDONLY + TARGET_O_BINARY, /* "rb" */ diff --git a/sim/common/callback.c b/sim/common/callback.c index 39d068c..941f430 100644 --- a/sim/common/callback.c +++ b/sim/common/callback.c @@ -37,7 +37,6 @@ #include <sys/types.h> #include <sys/stat.h> #include "sim/callback.h" -#include "targ-vals.h" /* For xmalloc. */ #include "libiberty.h" @@ -886,29 +885,44 @@ cb_target_to_host_open (host_callback *cb, int target_val) { int host_val = 0; CB_TARGET_DEFS_MAP *m; + int o_rdonly = 0; + int o_wronly = 0; + int o_rdwr = 0; + int o_binary = 0; + int o_rdwrmask; + /* O_RDONLY can be (and usually is) 0 which needs to be treated specially. */ for (m = &cb->open_map[0]; m->host_val != -1; ++m) { - switch (m->target_val) + if (!strcmp (m->name, "O_RDONLY")) + o_rdonly = m->target_val; + else if (!strcmp (m->name, "O_WRONLY")) + o_wronly = m->target_val; + else if (!strcmp (m->name, "O_RDWR")) + o_rdwr = m->target_val; + else if (!strcmp (m->name, "O_BINARY")) + o_binary = m->target_val; + } + o_rdwrmask = o_rdonly | o_wronly | o_rdwr; + + for (m = &cb->open_map[0]; m->host_val != -1; ++m) + { + if (m->target_val == o_rdonly || m->target_val == o_wronly + || m->target_val == o_rdwr) { - /* O_RDONLY can be (and usually is) 0 which needs to be treated - specially. */ - case TARGET_O_RDONLY : - case TARGET_O_WRONLY : - case TARGET_O_RDWR : - if ((target_val & (TARGET_O_RDONLY | TARGET_O_WRONLY | TARGET_O_RDWR)) - == m->target_val) + if ((target_val & o_rdwrmask) == m->target_val) host_val |= m->host_val; /* Handle the host/target differentiating between binary and text mode. Only one case is of importance */ -#if ! defined (TARGET_O_BINARY) && defined (O_BINARY) - host_val |= O_BINARY; +#ifdef O_BINARY + if (o_binary == 0) + host_val |= O_BINARY; #endif - break; - default : + } + else + { if ((m->target_val & target_val) == m->target_val) host_val |= m->host_val; - break; } } diff --git a/sim/common/gentmap.c b/sim/common/gentmap.c index fbc2901..2c7288b 100644 --- a/sim/common/gentmap.c +++ b/sim/common/gentmap.c @@ -39,11 +39,6 @@ gen_targ_vals_h (void) printf ("#define TARGET_%s %d\n", t->symbol, t->value); printf ("\n"); - printf ("/* open flag values */\n"); - for (t = &open_tdefs[0]; t->symbol; ++t) - printf ("#define TARGET_%s 0x%x\n", t->symbol, t->value); - printf ("\n"); - printf ("#endif /* TARG_VALS_H */\n"); } @@ -78,6 +73,7 @@ gen_targ_map_c (void) printf ("CB_TARGET_DEFS_MAP cb_init_open_map[] = {\n"); for (t = &open_tdefs[0]; t->symbol; ++t) { + printf ("#define TARGET_%s 0x%x\n", t->symbol, t->value); printf ("#ifdef %s\n", t->symbol); printf (" { \"%s\", %s, TARGET_%s },\n", t->symbol, t->symbol, t->symbol); printf ("#endif\n"); |