target/arm: Use set/clear_helper_retaddr in helper-a64.c
Use these in helper_dc_dva and the FEAT_MOPS routines to avoid a race condition with munmap in another thread. Reviewed-by: Peter Maydell <peter.maydell@linaro.org> Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
This commit is contained in:
parent
3d75856d1a
commit
8009519b30
@ -928,6 +928,8 @@ uint32_t HELPER(sqrt_f16)(uint32_t a, void *fpstp)
|
|||||||
|
|
||||||
void HELPER(dc_zva)(CPUARMState *env, uint64_t vaddr_in)
|
void HELPER(dc_zva)(CPUARMState *env, uint64_t vaddr_in)
|
||||||
{
|
{
|
||||||
|
uintptr_t ra = GETPC();
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Implement DC ZVA, which zeroes a fixed-length block of memory.
|
* Implement DC ZVA, which zeroes a fixed-length block of memory.
|
||||||
* Note that we do not implement the (architecturally mandated)
|
* Note that we do not implement the (architecturally mandated)
|
||||||
@ -948,8 +950,6 @@ void HELPER(dc_zva)(CPUARMState *env, uint64_t vaddr_in)
|
|||||||
|
|
||||||
#ifndef CONFIG_USER_ONLY
|
#ifndef CONFIG_USER_ONLY
|
||||||
if (unlikely(!mem)) {
|
if (unlikely(!mem)) {
|
||||||
uintptr_t ra = GETPC();
|
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Trap if accessing an invalid page. DC_ZVA requires that we supply
|
* Trap if accessing an invalid page. DC_ZVA requires that we supply
|
||||||
* the original pointer for an invalid page. But watchpoints require
|
* the original pointer for an invalid page. But watchpoints require
|
||||||
@ -971,7 +971,9 @@ void HELPER(dc_zva)(CPUARMState *env, uint64_t vaddr_in)
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
set_helper_retaddr(ra);
|
||||||
memset(mem, 0, blocklen);
|
memset(mem, 0, blocklen);
|
||||||
|
clear_helper_retaddr();
|
||||||
}
|
}
|
||||||
|
|
||||||
void HELPER(unaligned_access)(CPUARMState *env, uint64_t addr,
|
void HELPER(unaligned_access)(CPUARMState *env, uint64_t addr,
|
||||||
@ -1120,7 +1122,9 @@ static uint64_t set_step(CPUARMState *env, uint64_t toaddr,
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
/* Easy case: just memset the host memory */
|
/* Easy case: just memset the host memory */
|
||||||
|
set_helper_retaddr(ra);
|
||||||
memset(mem, data, setsize);
|
memset(mem, data, setsize);
|
||||||
|
clear_helper_retaddr();
|
||||||
return setsize;
|
return setsize;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1163,7 +1167,9 @@ static uint64_t set_step_tags(CPUARMState *env, uint64_t toaddr,
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
/* Easy case: just memset the host memory */
|
/* Easy case: just memset the host memory */
|
||||||
|
set_helper_retaddr(ra);
|
||||||
memset(mem, data, setsize);
|
memset(mem, data, setsize);
|
||||||
|
clear_helper_retaddr();
|
||||||
mte_mops_set_tags(env, toaddr, setsize, *mtedesc);
|
mte_mops_set_tags(env, toaddr, setsize, *mtedesc);
|
||||||
return setsize;
|
return setsize;
|
||||||
}
|
}
|
||||||
@ -1497,7 +1503,9 @@ static uint64_t copy_step(CPUARMState *env, uint64_t toaddr, uint64_t fromaddr,
|
|||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
/* Easy case: just memmove the host memory */
|
/* Easy case: just memmove the host memory */
|
||||||
|
set_helper_retaddr(ra);
|
||||||
memmove(wmem, rmem, copysize);
|
memmove(wmem, rmem, copysize);
|
||||||
|
clear_helper_retaddr();
|
||||||
return copysize;
|
return copysize;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1572,7 +1580,9 @@ static uint64_t copy_step_rev(CPUARMState *env, uint64_t toaddr,
|
|||||||
* Easy case: just memmove the host memory. Note that wmem and
|
* Easy case: just memmove the host memory. Note that wmem and
|
||||||
* rmem here point to the *last* byte to copy.
|
* rmem here point to the *last* byte to copy.
|
||||||
*/
|
*/
|
||||||
|
set_helper_retaddr(ra);
|
||||||
memmove(wmem - (copysize - 1), rmem - (copysize - 1), copysize);
|
memmove(wmem - (copysize - 1), rmem - (copysize - 1), copysize);
|
||||||
|
clear_helper_retaddr();
|
||||||
return copysize;
|
return copysize;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user