mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-11 03:24:58 -06:00
tests/tcg/s390x: Add PSW modification tests
Add several small tests that check the PSW modification instructions: * lpsw.S checks whether LPSW works correctly in the "happy" case. * lpswe-early.S checks whether early exceptions are recognized and whether the correct ILC and old PSW are stored when they happen. * ssm-early.S, stosm-early.S and exrl-ssm-early.S check the special handling of SSM and STOSM with respect to early exceptions. Signed-off-by: Ilya Leoshkevich <iii@linux.ibm.com> Message-Id: <20230315020408.384766-4-iii@linux.ibm.com> Signed-off-by: Thomas Huth <thuth@redhat.com>
This commit is contained in:
parent
199c42a6a1
commit
a1465c8b5b
6 changed files with 204 additions and 0 deletions
|
@ -9,3 +9,8 @@ QEMU_OPTS=-action panic=exit-failure -kernel
|
||||||
TESTS += unaligned-lowcore
|
TESTS += unaligned-lowcore
|
||||||
TESTS += bal
|
TESTS += bal
|
||||||
TESTS += sam
|
TESTS += sam
|
||||||
|
TESTS += lpsw
|
||||||
|
TESTS += lpswe-early
|
||||||
|
TESTS += ssm-early
|
||||||
|
TESTS += stosm-early
|
||||||
|
TESTS += exrl-ssm-early
|
||||||
|
|
43
tests/tcg/s390x/exrl-ssm-early.S
Normal file
43
tests/tcg/s390x/exrl-ssm-early.S
Normal file
|
@ -0,0 +1,43 @@
|
||||||
|
/*
|
||||||
|
* Test early exception recognition using EXRL + SSM.
|
||||||
|
*
|
||||||
|
* SPDX-License-Identifier: GPL-2.0-or-later
|
||||||
|
*/
|
||||||
|
.org 0x8d
|
||||||
|
ilc:
|
||||||
|
.org 0x8e
|
||||||
|
program_interruption_code:
|
||||||
|
.org 0x150
|
||||||
|
program_old_psw:
|
||||||
|
.org 0x1D0 /* program new PSW */
|
||||||
|
.quad 0,pgm
|
||||||
|
.org 0x200 /* lowcore padding */
|
||||||
|
|
||||||
|
.globl _start
|
||||||
|
_start:
|
||||||
|
exrl %r0,ssm
|
||||||
|
expected_pswa:
|
||||||
|
j failure
|
||||||
|
ssm:
|
||||||
|
ssm ssm_op
|
||||||
|
|
||||||
|
pgm:
|
||||||
|
chhsi program_interruption_code,0x6 /* specification exception? */
|
||||||
|
jne failure
|
||||||
|
cli ilc,6 /* ilc for EXRL? */
|
||||||
|
jne failure
|
||||||
|
clc program_old_psw(16),expected_old_psw /* correct old PSW? */
|
||||||
|
jne failure
|
||||||
|
lpswe success_psw
|
||||||
|
failure:
|
||||||
|
lpswe failure_psw
|
||||||
|
|
||||||
|
ssm_op:
|
||||||
|
.byte 0x08 /* bit 4 set */
|
||||||
|
.align 8
|
||||||
|
expected_old_psw:
|
||||||
|
.quad 0x0800000180000000,expected_pswa /* bit 2 set */
|
||||||
|
success_psw:
|
||||||
|
.quad 0x2000000000000,0xfff /* see is_special_wait_psw() */
|
||||||
|
failure_psw:
|
||||||
|
.quad 0x2000000000000,0 /* disabled wait */
|
36
tests/tcg/s390x/lpsw.S
Normal file
36
tests/tcg/s390x/lpsw.S
Normal file
|
@ -0,0 +1,36 @@
|
||||||
|
/*
|
||||||
|
* Test the LPSW instruction.
|
||||||
|
*
|
||||||
|
* SPDX-License-Identifier: GPL-2.0-or-later
|
||||||
|
*/
|
||||||
|
.org 0x140
|
||||||
|
svc_old_psw:
|
||||||
|
.org 0x1c0 /* supervisor call new PSW */
|
||||||
|
.quad 0x80000000,svc /* 31-bit mode */
|
||||||
|
.org 0x200 /* lowcore padding */
|
||||||
|
|
||||||
|
.globl _start
|
||||||
|
_start:
|
||||||
|
lpsw short_psw
|
||||||
|
lpsw_target:
|
||||||
|
svc 0
|
||||||
|
expected_pswa:
|
||||||
|
j failure
|
||||||
|
|
||||||
|
svc:
|
||||||
|
clc svc_old_psw(16),expected_psw /* correct full PSW? */
|
||||||
|
jne failure
|
||||||
|
lpswe success_psw
|
||||||
|
failure:
|
||||||
|
lpswe failure_psw
|
||||||
|
|
||||||
|
.align 8
|
||||||
|
short_psw:
|
||||||
|
.long 0x90001,0x80000000+lpsw_target /* problem state,
|
||||||
|
64-bit mode */
|
||||||
|
expected_psw:
|
||||||
|
.quad 0x1000180000000,expected_pswa /* corresponds to short_psw */
|
||||||
|
success_psw:
|
||||||
|
.quad 0x2000000000000,0xfff /* see is_special_wait_psw() */
|
||||||
|
failure_psw:
|
||||||
|
.quad 0x2000000000000,0 /* disabled wait */
|
38
tests/tcg/s390x/lpswe-early.S
Normal file
38
tests/tcg/s390x/lpswe-early.S
Normal file
|
@ -0,0 +1,38 @@
|
||||||
|
/*
|
||||||
|
* Test early exception recognition using LPSWE.
|
||||||
|
*
|
||||||
|
* SPDX-License-Identifier: GPL-2.0-or-later
|
||||||
|
*/
|
||||||
|
.org 0x8d
|
||||||
|
ilc:
|
||||||
|
.org 0x8e
|
||||||
|
program_interruption_code:
|
||||||
|
.org 0x150
|
||||||
|
program_old_psw:
|
||||||
|
.org 0x1D0 /* program new PSW */
|
||||||
|
.quad 0,pgm
|
||||||
|
.org 0x200 /* lowcore padding */
|
||||||
|
|
||||||
|
.globl _start
|
||||||
|
_start:
|
||||||
|
lpswe bad_psw
|
||||||
|
j failure
|
||||||
|
|
||||||
|
pgm:
|
||||||
|
chhsi program_interruption_code,0x6 /* specification exception? */
|
||||||
|
jne failure
|
||||||
|
cli ilc,0 /* ilc zero? */
|
||||||
|
jne failure
|
||||||
|
clc program_old_psw(16),bad_psw /* correct old PSW? */
|
||||||
|
jne failure
|
||||||
|
lpswe success_psw
|
||||||
|
failure:
|
||||||
|
lpswe failure_psw
|
||||||
|
|
||||||
|
.align 8
|
||||||
|
bad_psw:
|
||||||
|
.quad 0x8000000000000000,0xfedcba9876543210 /* bit 0 set */
|
||||||
|
success_psw:
|
||||||
|
.quad 0x2000000000000,0xfff /* see is_special_wait_psw() */
|
||||||
|
failure_psw:
|
||||||
|
.quad 0x2000000000000,0 /* disabled wait */
|
41
tests/tcg/s390x/ssm-early.S
Normal file
41
tests/tcg/s390x/ssm-early.S
Normal file
|
@ -0,0 +1,41 @@
|
||||||
|
/*
|
||||||
|
* Test early exception recognition using SSM.
|
||||||
|
*
|
||||||
|
* SPDX-License-Identifier: GPL-2.0-or-later
|
||||||
|
*/
|
||||||
|
.org 0x8d
|
||||||
|
ilc:
|
||||||
|
.org 0x8e
|
||||||
|
program_interruption_code:
|
||||||
|
.org 0x150
|
||||||
|
program_old_psw:
|
||||||
|
.org 0x1D0 /* program new PSW */
|
||||||
|
.quad 0,pgm
|
||||||
|
.org 0x200 /* lowcore padding */
|
||||||
|
|
||||||
|
.globl _start
|
||||||
|
_start:
|
||||||
|
ssm ssm_op
|
||||||
|
expected_pswa:
|
||||||
|
j failure
|
||||||
|
|
||||||
|
pgm:
|
||||||
|
chhsi program_interruption_code,0x6 /* specification exception? */
|
||||||
|
jne failure
|
||||||
|
cli ilc,4 /* ilc for SSM? */
|
||||||
|
jne failure
|
||||||
|
clc program_old_psw(16),expected_old_psw /* correct old PSW? */
|
||||||
|
jne failure
|
||||||
|
lpswe success_psw
|
||||||
|
failure:
|
||||||
|
lpswe failure_psw
|
||||||
|
|
||||||
|
ssm_op:
|
||||||
|
.byte 0x20 /* bit 2 set */
|
||||||
|
.align 8
|
||||||
|
expected_old_psw:
|
||||||
|
.quad 0x2000000180000000,expected_pswa /* bit 2 set */
|
||||||
|
success_psw:
|
||||||
|
.quad 0x2000000000000,0xfff /* see is_special_wait_psw() */
|
||||||
|
failure_psw:
|
||||||
|
.quad 0x2000000000000,0 /* disabled wait */
|
41
tests/tcg/s390x/stosm-early.S
Normal file
41
tests/tcg/s390x/stosm-early.S
Normal file
|
@ -0,0 +1,41 @@
|
||||||
|
/*
|
||||||
|
* Test early exception recognition using STOSM.
|
||||||
|
*
|
||||||
|
* SPDX-License-Identifier: GPL-2.0-or-later
|
||||||
|
*/
|
||||||
|
.org 0x8d
|
||||||
|
ilc:
|
||||||
|
.org 0x8e
|
||||||
|
program_interruption_code:
|
||||||
|
.org 0x150
|
||||||
|
program_old_psw:
|
||||||
|
.org 0x1D0 /* program new PSW */
|
||||||
|
.quad 0,pgm
|
||||||
|
.org 0x200 /* lowcore padding */
|
||||||
|
|
||||||
|
.globl _start
|
||||||
|
_start:
|
||||||
|
stosm ssm_op,0x10 /* bit 3 set */
|
||||||
|
expected_pswa:
|
||||||
|
j failure
|
||||||
|
|
||||||
|
pgm:
|
||||||
|
chhsi program_interruption_code,0x6 /* specification exception? */
|
||||||
|
jne failure
|
||||||
|
cli ilc,4 /* ilc for STOSM? */
|
||||||
|
jne failure
|
||||||
|
clc program_old_psw(16),expected_old_psw /* correct old PSW? */
|
||||||
|
jne failure
|
||||||
|
lpswe success_psw
|
||||||
|
failure:
|
||||||
|
lpswe failure_psw
|
||||||
|
|
||||||
|
ssm_op:
|
||||||
|
.byte 0
|
||||||
|
.align 8
|
||||||
|
expected_old_psw:
|
||||||
|
.quad 0x1000000180000000,expected_pswa /* bit 3 set */
|
||||||
|
success_psw:
|
||||||
|
.quad 0x2000000000000,0xfff /* see is_special_wait_psw() */
|
||||||
|
failure_psw:
|
||||||
|
.quad 0x2000000000000,0 /* disabled wait */
|
Loading…
Add table
Add a link
Reference in a new issue