diff options
author | Giuseppe Musacchio <thatlemon@gmail.com> | 2019-10-01 18:39:52 +0200 |
---|---|---|
committer | Palmer Dabbelt <palmer@sifive.com> | 2019-10-28 07:47:27 -0700 |
commit | 2921343b3df93e4848034ec615c01ee221212c3a (patch) | |
tree | 10146679519bfe9eade69487326f6aa6fb0a2c27 /include/hw/riscv | |
parent | c3a28b5d04f3b177befa1235e95e7bb09023f859 (diff) | |
download | qemu-2921343b3df93e4848034ec615c01ee221212c3a.zip qemu-2921343b3df93e4848034ec615c01ee221212c3a.tar.gz qemu-2921343b3df93e4848034ec615c01ee221212c3a.tar.bz2 |
linux-user/riscv: Propagate fault address
The CPU loop tagged all the queued signals as QEMU_SI_KILL while it was
filling the `_sigfault` part of `siginfo`: this caused QEMU to copy the
wrong fields over to the userspace program.
Make sure the fault address recorded by the MMU is is stored in the CPU
environment structure.
In case of memory faults store the exception address into `siginfo`.
Signed-off-by: Giuseppe Musacchio <thatlemon@gmail.com>
Reviewed-by: Palmer Dabbelt <palmer@sifive.com>
Signed-off-by: Palmer Dabbelt <palmer@sifive.com>
Diffstat (limited to 'include/hw/riscv')
0 files changed, 0 insertions, 0 deletions