[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH v4 11/14] tests/tcg/s390x: Test ICM
From: |
Ilya Leoshkevich |
Subject: |
[PATCH v4 11/14] tests/tcg/s390x: Test ICM |
Date: |
Mon, 24 Jul 2023 10:16:04 +0200 |
Add a small test to prevent regressions.
Tested-by: Thomas Huth <thuth@redhat.com>
Signed-off-by: Ilya Leoshkevich <iii@linux.ibm.com>
---
tests/tcg/s390x/Makefile.softmmu-target | 1 +
tests/tcg/s390x/icm.S | 32 +++++++++++++++++++++++++
2 files changed, 33 insertions(+)
create mode 100644 tests/tcg/s390x/icm.S
diff --git a/tests/tcg/s390x/Makefile.softmmu-target
b/tests/tcg/s390x/Makefile.softmmu-target
index 062d8e368aa..58684d7da71 100644
--- a/tests/tcg/s390x/Makefile.softmmu-target
+++ b/tests/tcg/s390x/Makefile.softmmu-target
@@ -19,6 +19,7 @@ ASM_TESTS =
\
cksm
\
clm
\
exrl-ssm-early
\
+ icm
\
sam
\
lpsw
\
lpswe-early
\
diff --git a/tests/tcg/s390x/icm.S b/tests/tcg/s390x/icm.S
new file mode 100644
index 00000000000..d24d1f52fb8
--- /dev/null
+++ b/tests/tcg/s390x/icm.S
@@ -0,0 +1,32 @@
+ .org 0x8e
+program_interruption_code:
+ .org 0x1d0 /* program new PSW */
+ .quad 0,pgm
+ .org 0x200 /* lowcore padding */
+ .globl _start
+_start:
+ lgrl %r0,op1
+ icm %r0,10,op2
+ cg %r0,exp
+ jne failure
+ lgrl %r1,bad_addr
+ icm %r0,0,0(%r1)
+failure:
+ lpswe failure_psw
+pgm:
+ chhsi program_interruption_code,5 /* addressing exception? */
+ jne failure
+ lpswe success_psw
+ .align 8
+op1:
+ .quad 0x1234567887654321
+op2:
+ .quad 0x0011223344556677
+exp:
+ .quad 0x1234567800651121
+bad_addr:
+ .quad 0xffffffff00000000
+success_psw:
+ .quad 0x2000000000000,0xfff /* see is_special_wait_psw() */
+failure_psw:
+ .quad 0x2000000000000,0 /* disabled wait */
--
2.41.0
- [PATCH v4 09/14] tests/tcg/s390x: Test CLGEBR and CGEBRA, (continued)
- [PATCH v4 09/14] tests/tcg/s390x: Test CLGEBR and CGEBRA, Ilya Leoshkevich, 2023/07/24
- [PATCH v4 02/14] target/s390x: Fix CLM with M3=0, Ilya Leoshkevich, 2023/07/24
- [PATCH v4 05/14] target/s390x: Make MC raise specification exception when class >= 16, Ilya Leoshkevich, 2023/07/24
- [PATCH v4 07/14] target/s390x: Fix assertion failure in VFMIN/VFMAX with type 13, Ilya Leoshkevich, 2023/07/24
- [PATCH v4 03/14] target/s390x: Fix CONVERT TO LOGICAL/FIXED with out-of-range inputs, Ilya Leoshkevich, 2023/07/24
- [PATCH v4 06/14] tcg/{i386, s390x}: Add earlyclobber to the op_add2's first output, Ilya Leoshkevich, 2023/07/24
- [PATCH v4 12/14] tests/tcg/s390x: Test MC, Ilya Leoshkevich, 2023/07/24
- [PATCH v4 08/14] tests/tcg/s390x: Test CKSM, Ilya Leoshkevich, 2023/07/24
- [PATCH v4 10/14] tests/tcg/s390x: Test CLM, Ilya Leoshkevich, 2023/07/24
- [PATCH v4 13/14] tests/tcg/s390x: Test STPQ, Ilya Leoshkevich, 2023/07/24
- [PATCH v4 11/14] tests/tcg/s390x: Test ICM,
Ilya Leoshkevich <=
- [PATCH v4 14/14] tests/tcg/s390x: Test VCKSM, Ilya Leoshkevich, 2023/07/24