unicorn/qemu
Claudio Fontana 11ae599cb8 target/arm: do not use cc->do_interrupt for KVM directly
cc->do_interrupt is in theory a TCG callback used in accel/tcg only,
to prepare the emulated architecture to take an interrupt as defined
in the hardware specifications,

but in reality the _do_interrupt style of functions in targets are
also occasionally reused by KVM to prepare the architecture state in a
similar way where userspace code has identified that it needs to
deliver an exception to the guest.

In the case of ARM, that includes:

1) the vcpu thread got a SIGBUS indicating a memory error,
and we need to deliver a Synchronous External Abort to the guest to
let it know about the error.
2) the kernel told us about a debug exception (breakpoint, watchpoint)
but it is not for one of QEMU's own gdbstub breakpoints/watchpoints
so it must be a breakpoint the guest itself has set up, therefore
we need to deliver it to the guest.

So in order to reuse code, the same arm_do_interrupt function is used.
This is all fine, but we need to avoid calling it using the callback
registered in CPUClass, since that one is now TCG-only.

Fortunately this is easily solved by replacing calls to
CPUClass::do_interrupt() with explicit calls to arm_do_interrupt().

Backports 853bfef4e6d60244fd131ec55bbf1e7caa52599b. We don't support
KVM, so we just bring the comment addition over.
2021-03-04 16:33:23 -05:00
..
accel tcg: Restart code generation when we run out of temps 2021-03-04 15:37:05 -05:00
crypto crypto: Clean up includes 2018-02-19 00:47:40 -05:00
default-configs target/riscv: Initial introduction of the RISC-V target 2019-03-08 21:46:10 -05:00
docs docs/devel/memory.txt: Document _with_attrs accessors 2018-10-04 04:46:26 -04:00
fpu softfloat: Define misc operations for bfloat16 2021-02-27 16:41:46 -05:00
hw target/arm: Set instance_align on CPUARM TypeInfo 2021-03-01 18:58:44 -05:00
include qemu/compiler: Split out qemu_build_not_reached_always 2021-03-04 15:23:27 -05:00
qapi qapi: Rewrite string-input-visitor's integer and list parsing 2018-12-18 04:57:25 -05:00
qobject qstring: Move qstring_from_substr()'s @end one to the right 2018-08-02 21:24:19 -04:00
qom target/arm: Set instance_align on CPUARM TypeInfo 2021-03-01 18:58:44 -05:00
scripts decodetree: Open files with encoding='utf-8' 2021-03-04 13:34:08 -05:00
target target/arm: do not use cc->do_interrupt for KVM directly 2021-03-04 16:33:23 -05:00
tcg tcg: Remove TCG_TARGET_CON_SET_H 2021-03-04 16:29:16 -05:00
util util/cutils: Turn FIXME comment into QEMU_BUILD_BUG_ON() 2020-01-14 08:04:30 -05:00
aarch64.h qemu/compiler: Split out qemu_build_not_reached_always 2021-03-04 15:23:27 -05:00
aarch64eb.h qemu/compiler: Split out qemu_build_not_reached_always 2021-03-04 15:23:27 -05:00
accel.c target/arm: Set instance_align on CPUARM TypeInfo 2021-03-01 18:58:44 -05:00
arm.h qemu/compiler: Split out qemu_build_not_reached_always 2021-03-04 15:23:27 -05:00
armeb.h qemu/compiler: Split out qemu_build_not_reached_always 2021-03-04 15:23:27 -05:00
CODING_STYLE.rst docs: split the CODING_STYLE doc into distinct groups 2019-11-28 02:54:44 -05:00
configure configure: Support -static-pie if requested 2020-04-30 07:09:34 -04:00
COPYING
COPYING.LIB
cpus.c Include qapi/error.h exactly where needed 2018-03-07 12:26:38 -05:00
exec.c Memory: Enable writeback for given memory region 2020-01-14 07:44:24 -05:00
gen_all_header.sh
glib_compat.c tcg: Introduce TYPE_CONST temporaries 2021-03-03 21:29:40 -05:00
header_gen.py qemu/compiler: Split out qemu_build_not_reached_always 2021-03-04 15:23:27 -05:00
ioport.c hw: remove pio_addr_t 2018-02-24 02:43:16 -05:00
LICENSE
m68k.h qemu/compiler: Split out qemu_build_not_reached_always 2021-03-04 15:23:27 -05:00
Makefile Makefile: Rename targets for make recursion 2019-08-08 17:26:49 -04:00
Makefile.objs qapi: Move qapi-schema.json to qapi/, rename generated files 2018-03-09 11:35:11 -05:00
Makefile.target configure: Remove old -fno-gcse workaround for GCC 4.6.x and 4.7.[012] 2018-12-18 03:52:36 -05:00
memory.c target/arm: Set instance_align on CPUARM TypeInfo 2021-03-01 18:58:44 -05:00
memory_ldst.inc.c memory: Single byte swap along the I/O path 2020-01-07 19:12:04 -05:00
memory_mapping.c include/qemu/osdep.h: Don't include qapi/error.h 2018-02-21 23:08:18 -05:00
mips.h qemu/compiler: Split out qemu_build_not_reached_always 2021-03-04 15:23:27 -05:00
mips64.h qemu/compiler: Split out qemu_build_not_reached_always 2021-03-04 15:23:27 -05:00
mips64el.h qemu/compiler: Split out qemu_build_not_reached_always 2021-03-04 15:23:27 -05:00
mipsel.h qemu/compiler: Split out qemu_build_not_reached_always 2021-03-04 15:23:27 -05:00
powerpc.h qemu/compiler: Split out qemu_build_not_reached_always 2021-03-04 15:23:27 -05:00
qemu-timer.c timer/cpus: fix some typos and update some comments 2018-02-25 23:21:57 -05:00
riscv32.h qemu/compiler: Split out qemu_build_not_reached_always 2021-03-04 15:23:27 -05:00
riscv64.h qemu/compiler: Split out qemu_build_not_reached_always 2021-03-04 15:23:27 -05:00
rules.mak build-sys: silence make by default or V=0 2018-03-06 08:58:03 -05:00
sparc.h qemu/compiler: Split out qemu_build_not_reached_always 2021-03-04 15:23:27 -05:00
sparc64.h qemu/compiler: Split out qemu_build_not_reached_always 2021-03-04 15:23:27 -05:00
unicorn_common.h tcg: Move sorted_args into TCGArgConstraint.sort_index 2021-03-01 19:33:45 -05:00
VERSION Open 6.0 development tree 2021-03-02 13:39:05 -05:00
vl.c Use cpu_create(type) instead of cpu_init(cpu_model) 2018-03-20 14:20:30 -04:00
vl.h
x86_64.h qemu/compiler: Split out qemu_build_not_reached_always 2021-03-04 15:23:27 -05:00