linux-user: Don't allow guest to block SIGSEGV
authorPeter Maydell <peter.maydell@linaro.org>
Fri, 14 Mar 2014 14:36:56 +0000 (14:36 +0000)
committerRiku Voipio <riku.voipio@linaro.org>
Mon, 17 Mar 2014 09:44:32 +0000 (11:44 +0200)
commita7ec0f98e3a37a4d31c832cfa14dc2c1c0890421
treee444ff239a0d3947bc2207ae6c4544f2d270eb79
parent1c275925bfbbc2de84a8f0e09d1dd70bbefb6da3
linux-user: Don't allow guest to block SIGSEGV

Don't allow the linux-user guest to block SIGSEGV -- QEMU needs this
signal to detect accesses to pages which it has marked read-only
because it has cached translated code from them.

We implement this by making the do_sigprocmask() wrapper suppress
SIGSEGV when doing the host process signal mask manipulation; instead
we store the current state of SIGSEGV in the TaskState struct.

If we get a SIGSEGV for the guest when the guest has blocked the
signal, we treat it as if the default SEGV handler was in place,
as the kernel does for forced SIGSEGV delivery.

This patch is based on an idea by Alex Barcelo, but rather than
simply lying to the guest about the SIGSEGV state we track it.

Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
Reported-by: Alex Barcelo <abarcelo@ac.upc.edu>
Signed-off-by: Riku Voipio <riku.voipio@linaro.org>
linux-user/qemu.h
linux-user/signal.c