hw/core: Add TCGCPUOps.record_sigsegv
Add a new user-only interface for updating cpu state before raising a signal. This will replace tlb_fill for user-only and should result in less boilerplate for each guest. Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org> Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
This commit is contained in:
parent
04de121aaf
commit
09e94676ad
@ -111,6 +111,32 @@ struct TCGCPUOps {
|
|||||||
*/
|
*/
|
||||||
bool (*io_recompile_replay_branch)(CPUState *cpu,
|
bool (*io_recompile_replay_branch)(CPUState *cpu,
|
||||||
const TranslationBlock *tb);
|
const TranslationBlock *tb);
|
||||||
|
#else
|
||||||
|
/**
|
||||||
|
* record_sigsegv:
|
||||||
|
* @cpu: cpu context
|
||||||
|
* @addr: faulting guest address
|
||||||
|
* @access_type: access was read/write/execute
|
||||||
|
* @maperr: true for invalid page, false for permission fault
|
||||||
|
* @ra: host pc for unwinding
|
||||||
|
*
|
||||||
|
* We are about to raise SIGSEGV with si_code set for @maperr,
|
||||||
|
* and si_addr set for @addr. Record anything further needed
|
||||||
|
* for the signal ucontext_t.
|
||||||
|
*
|
||||||
|
* If the emulated kernel does not provide anything to the signal
|
||||||
|
* handler with anything besides the user context registers, and
|
||||||
|
* the siginfo_t, then this hook need do nothing and may be omitted.
|
||||||
|
* Otherwise, record the data and return; the caller will raise
|
||||||
|
* the signal, unwind the cpu state, and return to the main loop.
|
||||||
|
*
|
||||||
|
* If it is simpler to re-use the sysemu tlb_fill code, @ra is provided
|
||||||
|
* so that a "normal" cpu exception can be raised. In this case,
|
||||||
|
* the signal must be raised by the architecture cpu_loop.
|
||||||
|
*/
|
||||||
|
void (*record_sigsegv)(CPUState *cpu, vaddr addr,
|
||||||
|
MMUAccessType access_type,
|
||||||
|
bool maperr, uintptr_t ra);
|
||||||
#endif /* CONFIG_SOFTMMU */
|
#endif /* CONFIG_SOFTMMU */
|
||||||
#endif /* NEED_CPU_H */
|
#endif /* NEED_CPU_H */
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user