mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-02 15:23:53 -06:00
linux-user: Save the correct resume address for MIPS signal handling
The current ISA mode needs to be saved in bit 0 of the resume address. If the current instruction happens to be in a branch delay slot, then the address of the preceding jump instruction should be stored instead. exception_resume_pc already does both of these tasks, so it is made available and reused. MIPS_HFLAG_BMASK in hflags is cleared, otherwise QEMU may treat the first instruction of the signal handler as a delay slot instruction. Signed-off-by: Kwok Cheung Yeung <kcy@codesourcery.com> Signed-off-by: Aurelien Jarno <aurelien@aurel32.net>
This commit is contained in:
parent
ea3164aafc
commit
1239b472bb
3 changed files with 5 additions and 3 deletions
|
@ -366,8 +366,7 @@ static const char * const excp_names[EXCP_LAST + 1] = {
|
|||
[EXCP_CACHE] = "cache error",
|
||||
};
|
||||
|
||||
#if !defined(CONFIG_USER_ONLY)
|
||||
static target_ulong exception_resume_pc (CPUMIPSState *env)
|
||||
target_ulong exception_resume_pc (CPUMIPSState *env)
|
||||
{
|
||||
target_ulong bad_pc;
|
||||
target_ulong isa_mode;
|
||||
|
@ -383,6 +382,7 @@ static target_ulong exception_resume_pc (CPUMIPSState *env)
|
|||
return bad_pc;
|
||||
}
|
||||
|
||||
#if !defined(CONFIG_USER_ONLY)
|
||||
static void set_hflags_for_handler (CPUMIPSState *env)
|
||||
{
|
||||
/* Exception handlers are entered in 32-bit mode. */
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue