v8: --- * pick up several r-bs * fix kerneldoc style (thanks Claudio) * assert no pgm int code is there before entering SIE (thanks Janosch) * do not reference future commit (thanks Janosch) * check fauling address in TEID (thanks Claudio) * test_page -> test_pages (thanks Claudio) * add memory barriers (thanks Heiko) v7: --- * pick up r-bs * fixup unneeded linebreak (thanks Janosch) * remove outdated comments (thanks Janosch) * remove unneeded includes (thanks Janosch) v6: --- * add commit "s390x: add test source dir to include paths" and share define with number of pages between snippet and test (Thomas) * add commit "lib: s390x: interrupt: remove TEID_ASCE defines" * rename dat -> use_dat (thanks Thomas) * remove IRQ_DAT_ON/_OFF defines (thanks Thomas) * add a comment to explain why we switch to home space when entering SIE (thanks Thomas) * clarify register_ext_cleanup_func() doesn't touch address space mode when DAT is off (thanks Thomas) * convert address space defines to enum (thanks Thomas) * switch bitfield member to uint64_t (thanks Claudio) * upercase hex number * in selftest, set the bitfield value to a define and then assert on the bitfield (thanks Thomas) v5: --- * fix a big oopsie in irq_set_dat_mode() which caused parts of lowcore being overwritten (thanks Claudio) v4: --- - add static assert for PSW bitfield (Janosch, Claudio) - remove unneeded includes (Janosch) - move variable decls to function start (Janosch) - remove unneeded imports (Janosch) - lowerocase hex (Janosch) - remove unneeded attr (Janosch) - tyop :-) fixes (Janosch) v3: --- * introduce bitfield for the PSW to make handling less clumsy * some variable renames (Claudio) * remove unneeded barriers (Claudio) * remove rebase leftover sie_had_pgm_int (Claudio) * move read_pgm_int_code to header (Claudio) * squash include fix commit into the one causing the issue (Claudio) v2: --- * add function to change DAT/AS mode for all irq handlers (Janosch, Claudio) * instead of a new flag in PROG0C, check the pgm int code in lowcore (Janosch) * fix indents, comments (Nina) Right now, all SIE tests in kvm-unit-tests (i.e. where kvm-unit-test is the hypervisor) run using MSO/MSL. This is convenient, because it's simple. But it also comes with disadvantages, for example some features are unavailabe with MSO/MSL. This series adds support for running guests without MSO/MSL with dedicated guest page tables for the GPA->HPA translation. Since SIE implicitly uses the primary space mode for the guest, the host can't run in the primary space mode, too. To avoid moving all tests to the home space mode, only switch to home space mode when it is actually needed. This series also comes with various bugfixes that were caught while develoing this. Nico Boehr (8): lib: s390x: introduce bitfield for PSW mask s390x: add function to set DAT mode for all interrupts s390x: sie: switch to home space mode before entering SIE s390x: lib: don't forward PSW when handling exception in SIE s390x: lib: sie: don't reenter SIE on pgm int s390x: add test source dir to include paths s390x: add a test for SIE without MSO/MSL lib: s390x: interrupt: remove TEID_ASCE defines lib/s390x/asm/arch_def.h | 36 ++++++++++-- lib/s390x/asm/interrupt.h | 21 +++++-- lib/s390x/asm/mem.h | 1 + lib/s390x/interrupt.c | 36 ++++++++++++ lib/s390x/mmu.c | 5 +- lib/s390x/sie.c | 33 ++++++++++- s390x/Makefile | 4 +- s390x/selftest.c | 34 ++++++++++++ s390x/sie-dat.c | 111 +++++++++++++++++++++++++++++++++++++ s390x/snippets/c/sie-dat.c | 57 +++++++++++++++++++ s390x/snippets/c/sie-dat.h | 2 + s390x/unittests.cfg | 3 + 12 files changed, 329 insertions(+), 14 deletions(-) create mode 100644 s390x/sie-dat.c create mode 100644 s390x/snippets/c/sie-dat.c create mode 100644 s390x/snippets/c/sie-dat.h -- 2.41.0