diff options
author | Mike Frysinger <vapier@gentoo.org> | 2021-06-30 20:30:43 -0400 |
---|---|---|
committer | Mike Frysinger <vapier@gentoo.org> | 2021-07-01 20:38:07 -0400 |
commit | 055a3f27e8c704a459a84ef6deeadd06a4a55d23 (patch) | |
tree | 829e3b6af9bcef984e5e5054eadae517926d06f3 /sim/m32r | |
parent | 33b477e1c7fc12b21934e5f8fa799c163a554b20 (diff) | |
download | fsf-binutils-gdb-055a3f27e8c704a459a84ef6deeadd06a4a55d23.zip fsf-binutils-gdb-055a3f27e8c704a459a84ef6deeadd06a4a55d23.tar.gz fsf-binutils-gdb-055a3f27e8c704a459a84ef6deeadd06a4a55d23.tar.bz2 |
sim: m32r: fix virtual environment with Linux targets
We don't want to handle Linux syscalls when in the virtual environment,
just the user environment, so adjust the Linux traps logic to check for
that specifically (instead of just skipping the operating environment).
Also tweak some testcases to explicitly specify the environment they run
under rather than relying on the default matching their needs. This gets
the tests passing for all m32r targets.
Diffstat (limited to 'sim/m32r')
-rw-r--r-- | sim/m32r/ChangeLog | 5 | ||||
-rw-r--r-- | sim/m32r/traps-linux.c | 11 |
2 files changed, 8 insertions, 8 deletions
diff --git a/sim/m32r/ChangeLog b/sim/m32r/ChangeLog index 5243cda..19ddf8f 100644 --- a/sim/m32r/ChangeLog +++ b/sim/m32r/ChangeLog @@ -1,5 +1,10 @@ 2021-07-01 Mike Frysinger <vapier@gentoo.org> + * traps-linux.c (m32r_trap): Change OPERATING_ENVIRONMENT check to + !USER_ENVIRONMENT. Jump to default switch case. + +2021-07-01 Mike Frysinger <vapier@gentoo.org> + * syscall.h: Change __NR_ prefix on all symbols to TARGET_LINUX_SYS_. * traps-linux.c: Likewise. Include sim/callback.h & stdlib.h. diff --git a/sim/m32r/traps-linux.c b/sim/m32r/traps-linux.c index d60be7c..7aec04b 100644 --- a/sim/m32r/traps-linux.c +++ b/sim/m32r/traps-linux.c @@ -231,14 +231,8 @@ m32r_trap (SIM_CPU *current_cpu, PCADDR pc, int num) unsigned int func, arg1, arg2, arg3, arg4, arg5, arg6, arg7; int result, result2, errcode; - if (STATE_ENVIRONMENT (sd) == OPERATING_ENVIRONMENT) - { - /* The new pc is the trap vector entry. - We assume there's a branch there to some handler. - Use cr5 as EVB (EIT Vector Base) register. */ - USI new_pc = m32rbf_h_cr_get (current_cpu, 5) + 0x40 + num * 4; - return new_pc; - } + if (STATE_ENVIRONMENT (sd) != USER_ENVIRONMENT) + goto case_default; func = m32rbf_h_gr_get (current_cpu, 7); arg1 = m32rbf_h_gr_get (current_cpu, 0); @@ -1344,6 +1338,7 @@ m32r_trap (SIM_CPU *current_cpu, PCADDR pc, int num) /* Do nothing. */ break; + case_default: default : { /* Use cr5 as EVB (EIT Vector Base) register. */ |