mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-04 00:03:54 -06:00
armv7m: VECTCLRACTIVE and VECTRESET are UNPREDICTABLE
The VECTCLRACTIVE and VECTRESET bits in the AIRCR are both documented as UNPREDICTABLE if you write a 1 to them when the processor is not halted in Debug state (ie stopped and under the control of an external JTAG debugger). Since we don't implement Debug state or emulated JTAG these bits are always UNPREDICTABLE for us. Instead of logging them as unimplemented we can simply log writes as guest errors and ignore them. Signed-off-by: Michael Davidsaver <mdavidsaver@gmail.com> [PMM: change extracted from another patch; commit message constructed from scratch] Signed-off-by: Peter Maydell <peter.maydell@linaro.org> Reviewed-by: Philippe Mathieu-Daudé <f4bug@amsat.org> Reviewed-by: Alex Bennée <alex.bennee@linaro.org>
This commit is contained in:
parent
a25dc805e2
commit
14790f730a
1 changed files with 6 additions and 2 deletions
|
@ -716,10 +716,14 @@ static void nvic_writel(NVICState *s, uint32_t offset, uint32_t value)
|
|||
qemu_irq_pulse(s->sysresetreq);
|
||||
}
|
||||
if (value & 2) {
|
||||
qemu_log_mask(LOG_UNIMP, "VECTCLRACTIVE unimplemented\n");
|
||||
qemu_log_mask(LOG_GUEST_ERROR,
|
||||
"Setting VECTCLRACTIVE when not in DEBUG mode "
|
||||
"is UNPREDICTABLE\n");
|
||||
}
|
||||
if (value & 1) {
|
||||
qemu_log_mask(LOG_UNIMP, "AIRCR system reset unimplemented\n");
|
||||
qemu_log_mask(LOG_GUEST_ERROR,
|
||||
"Setting VECTRESET when not in DEBUG mode "
|
||||
"is UNPREDICTABLE\n");
|
||||
}
|
||||
s->prigroup = extract32(value, 8, 3);
|
||||
nvic_irq_update(s);
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue