[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PULL 8/8] linux-user/host/s390: Treat EX and EXRL as writes
From: |
Laurent Vivier |
Subject: |
[PULL 8/8] linux-user/host/s390: Treat EX and EXRL as writes |
Date: |
Wed, 25 May 2022 12:40:57 +0200 |
From: Ilya Leoshkevich <iii@linux.ibm.com>
clang-built s390x branch-relative-long test fails on clang-built s390x
QEMU due to the following sequence of events:
- The test zeroes out a code page, clang generates exrl+xc for this.
- do_helper_xc() is called. Clang generates exrl+xc there as well.
- Since there already exists a TB for the code in question, its page is
read-only and SIGSEGV is raised.
- host_signal_handler() calls host_signal_write() and the latter does
not recognize exrl as a write. Therefore page_unprotect() is not
called and the signal is forwarded to the test.
Fix by treating EXRL (and EX, just in case) as writes. There may be
false positives, but they will lead only to an extra page_unprotect()
call.
Reported-by: Thomas Huth <thuth@redhat.com>
Signed-off-by: Ilya Leoshkevich <iii@linux.ibm.com>
Tested-by: Thomas Huth <thuth@redhat.com>
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
Message-Id: <20220504114819.1729737-1-iii@linux.ibm.com>
Signed-off-by: Laurent Vivier <laurent@vivier.eu>
---
linux-user/include/host/s390/host-signal.h | 7 +++++++
1 file changed, 7 insertions(+)
diff --git a/linux-user/include/host/s390/host-signal.h
b/linux-user/include/host/s390/host-signal.h
index 6f191e64d7b5..25fefa00bd48 100644
--- a/linux-user/include/host/s390/host-signal.h
+++ b/linux-user/include/host/s390/host-signal.h
@@ -50,6 +50,7 @@ static inline bool host_signal_write(siginfo_t *info,
host_sigcontext *uc)
case 0x50: /* ST */
case 0x42: /* STC */
case 0x40: /* STH */
+ case 0x44: /* EX */
case 0xba: /* CS */
case 0xbb: /* CDS */
return true;
@@ -61,6 +62,12 @@ static inline bool host_signal_write(siginfo_t *info,
host_sigcontext *uc)
return true;
}
break;
+ case 0xc6: /* RIL-b format insns */
+ switch (pinsn[0] & 0xf) {
+ case 0x0: /* EXRL */
+ return true;
+ }
+ break;
case 0xc8: /* SSF format insns */
switch (pinsn[0] & 0xf) {
case 0x2: /* CSST */
--
2.36.1
- [PULL 0/8] Linux user for 7.1 patches, Laurent Vivier, 2022/05/25
- [PULL 2/8] linux-user/syscall.c: fix build without RLIMIT_RTTIME, Laurent Vivier, 2022/05/25
- [PULL 1/8] linux-user: Clean up arg_start/arg_end confusion, Laurent Vivier, 2022/05/25
- [PULL 7/8] tests/tcg/s390x: Test unwinding from signal handlers, Laurent Vivier, 2022/05/25
- [PULL 4/8] linux-user: Have do_syscall() use CPUArchState* instead of void*, Laurent Vivier, 2022/05/25
- [PULL 6/8] linux-user/s390x: Fix unwinding from signal handlers, Laurent Vivier, 2022/05/25
- [PULL 3/8] linux-user/elfload: Remove pointless non-const CPUArchState cast, Laurent Vivier, 2022/05/25
- [PULL 8/8] linux-user/host/s390: Treat EX and EXRL as writes,
Laurent Vivier <=
- [PULL 5/8] linux-user: Remove pointless CPU{ARCH}State casts, Laurent Vivier, 2022/05/25
- Re: [PULL 0/8] Linux user for 7.1 patches, Richard Henderson, 2022/05/25