diff options
author | Peter Maydell <peter.maydell@linaro.org> | 2021-08-13 14:18:07 +0100 |
---|---|---|
committer | Laurent Vivier <laurent@vivier.eu> | 2021-09-23 14:42:55 +0200 |
commit | af7969605eed067320fe9eca80f1aa35b67ec46d (patch) | |
tree | b128e6c1be5d673bb7ecb2e5f84acfc7a49679df /linux-user/linux_loop.h | |
parent | 819121b9b08a41ccfcde2e18eb782f8f6b2912f1 (diff) | |
download | qemu-af7969605eed067320fe9eca80f1aa35b67ec46d.zip qemu-af7969605eed067320fe9eca80f1aa35b67ec46d.tar.gz qemu-af7969605eed067320fe9eca80f1aa35b67ec46d.tar.bz2 |
linux-user: Provide new force_sig_fault() function
In many places in the linux-user code we need to queue a signal for
the guest using the QEMU_SI_FAULT si_type. This requires that the
caller sets up and passes us a target_siginfo, including setting the
appropriate part of the _sifields union for the si_type. In a number
of places the code forgets to set the _sifields union field.
Provide a new force_sig_fault() function, which does the same thing
as the Linux kernel function of that name -- it takes the signal
number, the si_code value and the address to use in
_sifields._sigfault, and assembles the target_siginfo itself. This
makes the callsites simpler and means it's harder to forget to pass
in an address value.
We follow force_sig() and the kernel's force_sig_fault() in not
requiring the caller to pass in the CPU pointer but always acting
on the CPU of the current thread.
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
Message-Id: <20210813131809.28655-6-peter.maydell@linaro.org>
Signed-off-by: Laurent Vivier <laurent@vivier.eu>
Diffstat (limited to 'linux-user/linux_loop.h')
0 files changed, 0 insertions, 0 deletions