public inbox for linux-kernel@vger.kernel.org
 help / color / mirror / Atom feed
* [PATCH] s390/test_unwind: use raw opcode instead of invalid instruction
@ 2021-11-17 17:48 Ilie Halip
  2021-11-19  1:10 ` Nick Desaulniers
  0 siblings, 1 reply; 9+ messages in thread
From: Ilie Halip @ 2021-11-17 17:48 UTC (permalink / raw)
  To: linux-kernel
  Cc: Ilie Halip, Nick Desaulniers, Heiko Carstens, Vasily Gorbik,
	Christian Borntraeger, Alexander Gordeev, Nathan Chancellor,
	Mete Durlu, Sven Schnelle, linux-s390, llvm

Building with clang & LLVM_IAS=1 leads to an error:
    arch/s390/lib/test_unwind.c:179:4: error: invalid register pair
                        "       mvcl    %%r1,%%r1\n"
                        ^

The test creates an invalid instruction that would trap at runtime, but the
LLVM inline assembler tries to validate it at compile time too.

Use the raw instruction opcode instead.

Link: https://github.com/ClangBuiltLinux/linux/issues/1421
Reported-by: Nick Desaulniers <ndesaulniers@google.com>
Signed-off-by: Ilie Halip <ilie.halip@gmail.com>
---
 arch/s390/lib/test_unwind.c | 2 +-
 1 file changed, 1 insertion(+), 1 deletion(-)

diff --git a/arch/s390/lib/test_unwind.c b/arch/s390/lib/test_unwind.c
index cfc5f5557c06..d342bc884b94 100644
--- a/arch/s390/lib/test_unwind.c
+++ b/arch/s390/lib/test_unwind.c
@@ -176,7 +176,7 @@ static noinline int unwindme_func4(struct unwindme *u)
 		 * trigger specification exception
 		 */
 		asm volatile(
-			"	mvcl	%%r1,%%r1\n"
+			"	.insn e,0x0e11\n"	/* mvcl	%%r1,%%r1" */
 			"0:	nopr	%%r7\n"
 			EX_TABLE(0b, 0b)
 			:);
-- 
2.25.1


^ permalink raw reply related	[flat|nested] 9+ messages in thread

end of thread, other threads:[~2021-11-19 15:15 UTC | newest]

Thread overview: 9+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2021-11-17 17:48 [PATCH] s390/test_unwind: use raw opcode instead of invalid instruction Ilie Halip
2021-11-19  1:10 ` Nick Desaulniers
2021-11-19  9:39   ` Christian Borntraeger
2021-11-19  9:44     ` Christian Borntraeger
2021-11-19 10:54     ` Heiko Carstens
2021-11-19 10:57       ` Christian Borntraeger
2021-11-19 11:09         ` Heiko Carstens
2021-11-19 14:12           ` Christian Borntraeger
2021-11-19 15:15             ` Heiko Carstens

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox