From: Richard Henderson <richard.henderson@linaro.org>
To: qemu-devel@nongnu.org
Cc: david@redhat.com
Subject: [PATCH v5 13/18] target/s390x: Rely on unwinding in s390_cpu_tlb_fill
Date: Tue, 1 Oct 2019 10:16:09 -0700 [thread overview]
Message-ID: <20191001171614.8405-14-richard.henderson@linaro.org> (raw)
In-Reply-To: <20191001171614.8405-1-richard.henderson@linaro.org>
We currently set ilen to AUTO, then overwrite that during
unwinding, then overwrite that for the code access case.
This can be simplified to setting ilen to our arbitrary
value for the (undefined) code access case, then rely on
unwinding to overwrite that with the correct value for
the data access case.
Reviewed-by: David Hildenbrand <david@redhat.com>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
---
target/s390x/excp_helper.c | 23 +++++++----------------
1 file changed, 7 insertions(+), 16 deletions(-)
diff --git a/target/s390x/excp_helper.c b/target/s390x/excp_helper.c
index 98a1ee8317..8ce992e639 100644
--- a/target/s390x/excp_helper.c
+++ b/target/s390x/excp_helper.c
@@ -96,7 +96,7 @@ bool s390_cpu_tlb_fill(CPUState *cs, vaddr address, int size,
{
S390CPU *cpu = S390_CPU(cs);
- trigger_pgm_exception(&cpu->env, PGM_ADDRESSING, ILEN_AUTO);
+ trigger_pgm_exception(&cpu->env, PGM_ADDRESSING, ILEN_UNWIND);
/* On real machines this value is dropped into LowMem. Since this
is userland, simply put this someplace that cpu_loop can find it. */
cpu->env.__excp_addr = address;
@@ -179,24 +179,15 @@ bool s390_cpu_tlb_fill(CPUState *cs, vaddr address, int size,
stq_phys(env_cpu(env)->as,
env->psa + offsetof(LowCore, trans_exc_code), tec);
}
- trigger_pgm_exception(env, excp, ILEN_AUTO);
- cpu_restore_state(cs, retaddr, true);
/*
- * The ILC value for code accesses is undefined. The important
- * thing here is to *not* leave env->int_pgm_ilen set to ILEN_AUTO,
- * which would cause do_program_interrupt to attempt to read from
- * env->psw.addr again. C.f. the condition in trigger_page_fault,
- * but is not universally applied.
- *
- * ??? If we remove ILEN_AUTO, by moving the computation of ILEN
- * into cpu_restore_state, then we may remove this entirely.
+ * For data accesses, ILEN will be filled in from the unwind info,
+ * within cpu_loop_exit_restore. For code accesses, retaddr == 0,
+ * and so unwinding will not occur. However, ILEN is also undefined
+ * for that case -- we choose to set ILEN = 2.
*/
- if (access_type == MMU_INST_FETCH) {
- env->int_pgm_ilen = 2;
- }
-
- cpu_loop_exit(cs);
+ trigger_pgm_exception(env, excp, 2);
+ cpu_loop_exit_restore(cs, retaddr);
}
static void do_program_interrupt(CPUS390XState *env)
--
2.17.1
next prev parent reply other threads:[~2019-10-01 17:35 UTC|newest]
Thread overview: 20+ messages / expand[flat|nested] mbox.gz Atom feed top
2019-10-01 17:15 [PATCH v5 00/18] target/s390: Use tcg unwinding for ilen Richard Henderson
2019-10-01 17:15 ` [PATCH v5 01/18] target/s390x: Add ilen to unwind data Richard Henderson
2019-10-01 17:15 ` [PATCH v5 02/18] target/s390x: Remove ilen parameter from tcg_s390_program_interrupt Richard Henderson
2019-10-01 17:15 ` [PATCH v5 03/18] target/s390x: Remove ilen parameter from s390_program_interrupt Richard Henderson
2019-10-01 17:16 ` [PATCH v5 04/18] target/s390x: Use tcg_s390_program_interrupt in TCG helpers Richard Henderson
2019-10-01 17:16 ` [PATCH v5 05/18] target/s390x: Push trigger_pgm_exception lower in s390_cpu_tlb_fill Richard Henderson
2019-10-01 17:16 ` [PATCH v5 06/18] target/s390x: Handle tec " Richard Henderson
2019-10-01 17:16 ` [PATCH v5 07/18] target/s390x: Return exception from mmu_translate_real Richard Henderson
2019-10-01 17:16 ` [PATCH v5 08/18] target/s390x: Remove exc argument to mmu_translate_asce Richard Henderson
2019-10-01 17:16 ` [PATCH v5 09/18] target/s390x: Return exception from mmu_translate Richard Henderson
2019-10-01 17:16 ` [PATCH v5 10/18] target/s390x: Return exception from translate_pages Richard Henderson
2019-10-01 17:16 ` [PATCH v5 11/18] target/s390x: Remove fail variable from s390_cpu_tlb_fill Richard Henderson
2019-10-01 17:16 ` [PATCH v5 12/18] target/s390x: Simplify helper_lra Richard Henderson
2019-10-01 17:16 ` Richard Henderson [this message]
2019-10-01 17:16 ` [PATCH v5 14/18] target/s390x: Rely on unwinding in s390_cpu_virt_mem_rw Richard Henderson
2019-10-01 17:16 ` [PATCH v5 15/18] target/s390x: Remove ILEN_AUTO Richard Henderson
2019-10-01 17:16 ` [PATCH v5 16/18] target/s390x: Remove ilen argument from trigger_access_exception Richard Henderson
2019-10-01 17:16 ` [PATCH v5 17/18] target/s390x: Remove ilen argument from trigger_pgm_exception Richard Henderson
2019-10-01 17:16 ` [PATCH v5 18/18] target/s390x: Remove ILEN_UNWIND Richard Henderson
2019-10-09 12:46 ` [PATCH v5 00/18] target/s390: Use tcg unwinding for ilen David Hildenbrand
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=20191001171614.8405-14-richard.henderson@linaro.org \
--to=richard.henderson@linaro.org \
--cc=david@redhat.com \
--cc=qemu-devel@nongnu.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).