From: Janis Schoetterl-Glausch Date: Thu, 30 Jun 2022 09:43:40 +0000 (+0200) Subject: target/s390x/tcg: SPX: check validity of new prefix X-Git-Tag: v7.1.0-rc0~32^2~17 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=f8333de27933b201b73a6c9830afbf1b48ac5dbe;p=thirdparty%2Fqemu.git target/s390x/tcg: SPX: check validity of new prefix According to the architecture, SET PREFIX must try to access the new prefix area and recognize an addressing exception if the area is not accessible. For qemu this check prevents a crash in cpu_map_lowcore after an inaccessible prefix area has been set. Signed-off-by: Janis Schoetterl-Glausch Reviewed-by: David Hildenbrand Message-Id: <20220630094340.3646279-1-scgl@linux.ibm.com> Signed-off-by: Thomas Huth --- diff --git a/target/s390x/tcg/misc_helper.c b/target/s390x/tcg/misc_helper.c index aab9c47747e..10dadb002a8 100644 --- a/target/s390x/tcg/misc_helper.c +++ b/target/s390x/tcg/misc_helper.c @@ -158,6 +158,13 @@ void HELPER(spx)(CPUS390XState *env, uint64_t a1) if (prefix == old_prefix) { return; } + /* + * Since prefix got aligned to 8k and memory increments are a multiple of + * 8k checking the first page is sufficient + */ + if (!mmu_absolute_addr_valid(prefix, true)) { + tcg_s390_program_interrupt(env, PGM_ADDRESSING, GETPC()); + } env->psa = prefix; HELPER_LOG("prefix: %#x\n", prefix);