From: "Edgar E. Iglesias" <edgar.iglesias@xilinx.com>
To: Peter Maydell <peter.maydell@linaro.org>
Cc: qemu-arm@nongnu.org, qemu-devel@nongnu.org, patches@linaro.org,
Luc Michel <luc.michel@greensocs.com>,
edgari@xilinx.com
Subject: Re: [Qemu-devel] [PATCH 10/10] target/arm: Implement support for taking exceptions to Hyp mode
Date: Wed, 15 Aug 2018 12:54:30 +0200 [thread overview]
Message-ID: <20180815105430.e6satguezkvfudf5@toto> (raw)
In-Reply-To: <20180814124254.5229-11-peter.maydell@linaro.org>
On Tue, Aug 14, 2018 at 01:42:54PM +0100, Peter Maydell wrote:
> Implement the necessary support code for taking exceptions
> to Hyp mode in AArch32.
Hi Peter,
A general comment that I think this would be a little easier
to look at if it was split into two patches, one non-functional
change to break-out take_aarch32_exception() and then another
patch to add the new logic...
Another comment inline below
>
> Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
> ---
> target/arm/helper.c | 146 +++++++++++++++++++++++++++++++++++++-------
> 1 file changed, 123 insertions(+), 23 deletions(-)
>
> diff --git a/target/arm/helper.c b/target/arm/helper.c
> index 80855302089..167203ac664 100644
> --- a/target/arm/helper.c
> +++ b/target/arm/helper.c
> @@ -8013,6 +8013,123 @@ void aarch64_sync_64_to_32(CPUARMState *env)
> env->regs[15] = env->pc;
> }
>
> +static void take_aarch32_exception(CPUARMState *env, int new_mode,
> + uint32_t mask, uint32_t offset,
> + uint32_t newpc)
> +{
> + /* Change the CPU state so as to actually take the exception. */
> + switch_mode(env, new_mode);
> + /*
> + * For exceptions taken to AArch32 we must clear the SS bit in both
> + * PSTATE and in the old-state value we save to SPSR_<mode>, so zero it now.
> + */
> + env->uncached_cpsr &= ~PSTATE_SS;
> + env->spsr = cpsr_read(env);
> + /* Clear IT bits. */
> + env->condexec_bits = 0;
> + /* Switch to the new mode, and to the correct instruction set. */
> + env->uncached_cpsr = (env->uncached_cpsr & ~CPSR_M) | new_mode;
> + /* Set new mode endianness */
> + env->uncached_cpsr &= ~CPSR_E;
> + if (env->cp15.sctlr_el[arm_current_el(env)] & SCTLR_EE) {
> + env->uncached_cpsr |= CPSR_E;
> + }
> + env->daif |= mask;
> +
> + if (new_mode == ARM_CPU_MODE_HYP) {
> + env->thumb = (env->cp15.sctlr_el[2] & SCTLR_TE) != 0;
> + env->elr_el[2] = env->regs[15];
> + } else {
> + /*
> + * this is a lie, as there was no c1_sys on V4T/V5, but who cares
> + * and we should just guard the thumb mode on V4
> + */
> + if (arm_feature(env, ARM_FEATURE_V4T)) {
> + env->thumb =
> + (A32_BANKED_CURRENT_REG_GET(env, sctlr) & SCTLR_TE) != 0;
> + }
> + env->regs[14] = env->regs[15] + offset;
> + }
> + env->regs[15] = newpc;
> +}
> +
> +static void arm_cpu_do_interrupt_aarch32_hyp(CPUState *cs)
> +{
> + /*
> + * Handle exception entry to Hyp mode; this is sufficiently
> + * different to entry to other AArch32 modes that we handle it
> + * separately here.
> + *
> + * The vector table entry used is always the 0x14 Hyp mode entry point,
> + * unless this is an UNDEF/HVC/abort taken from Hyp to Hyp.
> + * The offset applied to the preferred return address is always zero
> + * (see DDI0487C.a section G1.12.3).
> + * PSTATE A/I/F masks are set based only on the SCR.EA/IRQ/FIQ values.
> + */
> + uint32_t addr, mask;
> + ARMCPU *cpu = ARM_CPU(cs);
> + CPUARMState *env = &cpu->env;
> +
> + switch (cs->exception_index) {
> + case EXCP_UDEF:
> + addr = 0x04;
> + break;
> + case EXCP_SWI:
> + addr = 0x14;
> + break;
> + case EXCP_BKPT:
> + /* Fall through to prefetch abort. */
> + case EXCP_PREFETCH_ABORT:
> + env->cp15.ifar_s = env->exception.vaddress;
> + qemu_log_mask(CPU_LOG_INT, "...with HIFAR 0x%x\n",
> + (uint32_t)env->exception.vaddress);
> + addr = 0x0c;
> + break;
> + case EXCP_DATA_ABORT:
> + env->cp15.dfar_s = env->exception.vaddress;
> + qemu_log_mask(CPU_LOG_INT, "...with HDFAR 0x%x\n",
> + (uint32_t)env->exception.vaddress);
> + addr = 0x10;
> + break;
> + case EXCP_IRQ:
> + addr = 0x18;
> + break;
> + case EXCP_FIQ:
> + addr = 0x1c;
> + break;
> + case EXCP_HVC:
> + addr = 0x08;
> + break;
> + case EXCP_HYP_TRAP:
> + addr = 0x14;
> + default:
> + cpu_abort(cs, "Unhandled exception 0x%x\n", cs->exception_index);
> + }
> +
> + if (cs->exception_index != EXCP_IRQ && cs->exception_index != EXCP_FIQ) {
> + env->cp15.esr_el[2] = env->exception.syndrome;
> + }
> +
> + if (arm_current_el(env) != 2 && addr < 0x14) {
> + addr = 0x14;
> + }
> +
> + mask = 0;
> + if (!(env->cp15.scr_el3 & SCR_EA)) {
> + mask |= CPSR_A;
> + }
> + if (!(env->cp15.scr_el3 & SCR_IRQ)) {
> + mask |= CPSR_I;
> + }
> + if (!(env->cp15.scr_el3 & SCR_IRQ)) {a
^^^^^^^
I think this should test for SCR_FIQ.
Other than those two comments I think this looks OK!
Thanks,
Edgar
> + mask |= CPSR_F;
> + }
> +
> + addr += env->cp15.hvbar;
> +
> + take_aarch32_exception(env, ARM_CPU_MODE_HYP, mask, 0, addr);
> +}
> +
> static void arm_cpu_do_interrupt_aarch32(CPUState *cs)
> {
> ARMCPU *cpu = ARM_CPU(cs);
> @@ -8048,6 +8165,11 @@ static void arm_cpu_do_interrupt_aarch32(CPUState *cs)
> env->cp15.mdscr_el1 = deposit64(env->cp15.mdscr_el1, 2, 4, moe);
> }
>
> + if (env->exception.target_el == 2) {
> + arm_cpu_do_interrupt_aarch32_hyp(cs);
> + return;
> + }
> +
> /* TODO: Vectored interrupt controller. */
> switch (cs->exception_index) {
> case EXCP_UDEF:
> @@ -8155,29 +8277,7 @@ static void arm_cpu_do_interrupt_aarch32(CPUState *cs)
> env->cp15.scr_el3 &= ~SCR_NS;
> }
>
> - switch_mode (env, new_mode);
> - /* For exceptions taken to AArch32 we must clear the SS bit in both
> - * PSTATE and in the old-state value we save to SPSR_<mode>, so zero it now.
> - */
> - env->uncached_cpsr &= ~PSTATE_SS;
> - env->spsr = cpsr_read(env);
> - /* Clear IT bits. */
> - env->condexec_bits = 0;
> - /* Switch to the new mode, and to the correct instruction set. */
> - env->uncached_cpsr = (env->uncached_cpsr & ~CPSR_M) | new_mode;
> - /* Set new mode endianness */
> - env->uncached_cpsr &= ~CPSR_E;
> - if (env->cp15.sctlr_el[arm_current_el(env)] & SCTLR_EE) {
> - env->uncached_cpsr |= CPSR_E;
> - }
> - env->daif |= mask;
> - /* this is a lie, as the was no c1_sys on V4T/V5, but who cares
> - * and we should just guard the thumb mode on V4 */
> - if (arm_feature(env, ARM_FEATURE_V4T)) {
> - env->thumb = (A32_BANKED_CURRENT_REG_GET(env, sctlr) & SCTLR_TE) != 0;
> - }
> - env->regs[14] = env->regs[15] + offset;
> - env->regs[15] = addr;
> + take_aarch32_exception(env, new_mode, mask, offset, addr);
> }
>
> /* Handle exception entry to a target EL which is using AArch64 */
> --
> 2.18.0
>
next prev parent reply other threads:[~2018-08-15 10:54 UTC|newest]
Thread overview: 36+ messages / expand[flat|nested] mbox.gz Atom feed top
2018-08-14 12:42 [Qemu-devel] [PATCH 00/10] target/arm: Some pieces of support for 32-bit Hyp mode Peter Maydell
2018-08-14 12:42 ` [Qemu-devel] [PATCH 01/10] target/arm: Correct typo in HAMAIR1 regdef name Peter Maydell
2018-08-14 14:33 ` Edgar E. Iglesias
2018-08-15 9:02 ` Luc Michel
2018-08-14 12:42 ` [Qemu-devel] [PATCH 02/10] target/arm: Add missing .cp = 15 to HMAIR1 and HAMAIR1 regdefs Peter Maydell
2018-08-14 14:41 ` Edgar E. Iglesias
2018-08-14 14:45 ` Peter Maydell
2018-08-15 9:10 ` Luc Michel
2018-08-14 12:42 ` [Qemu-devel] [PATCH 03/10] target/arm: Implement RAZ/WI HACTLR2 Peter Maydell
2018-08-14 14:44 ` Edgar E. Iglesias
2018-08-15 12:14 ` Luc Michel
2018-08-14 12:42 ` [Qemu-devel] [PATCH 04/10] target/arm: Implement AArch32 HVBAR Peter Maydell
2018-08-14 14:46 ` Edgar E. Iglesias
2018-08-15 12:26 ` Luc Michel
2018-08-14 12:42 ` [Qemu-devel] [PATCH 05/10] target/arm: Implement AArch32 HCR and HCR2 Peter Maydell
2018-08-14 14:52 ` Edgar E. Iglesias
2018-08-16 8:55 ` Luc Michel
2018-08-16 9:02 ` Peter Maydell
2018-08-14 12:42 ` [Qemu-devel] [PATCH 06/10] target/arm: Implement AArch32 Hyp FARs Peter Maydell
2018-08-14 14:57 ` Edgar E. Iglesias
2018-08-16 9:01 ` Luc Michel
2018-08-14 12:42 ` [Qemu-devel] [PATCH 07/10] target/arm: Implement ESR_EL2/HSR for AArch32 and no-EL2 Peter Maydell
2018-08-14 14:59 ` Edgar E. Iglesias
2018-08-16 9:16 ` Luc Michel
2018-08-14 12:42 ` [Qemu-devel] [PATCH 08/10] target/arm: Permit accesses to ELR_Hyp from Hyp mode via MSR/MRS (banked) Peter Maydell
2018-08-14 15:07 ` Edgar E. Iglesias
2018-08-16 7:58 ` Luc Michel
2018-08-14 12:42 ` [Qemu-devel] [PATCH 09/10] target/arm: Implement AArch32 ERET instruction Peter Maydell
2018-08-15 11:00 ` Edgar E. Iglesias
2018-08-16 8:10 ` Luc Michel
2018-08-14 12:42 ` [Qemu-devel] [PATCH 10/10] target/arm: Implement support for taking exceptions to Hyp mode Peter Maydell
2018-08-15 10:54 ` Edgar E. Iglesias [this message]
2018-08-15 10:58 ` Peter Maydell
2018-08-15 11:04 ` [Qemu-devel] [PATCH 00/10] target/arm: Some pieces of support for 32-bit " Edgar E. Iglesias
2018-08-15 11:13 ` Peter Maydell
2018-08-17 10:15 ` [Qemu-devel] [Qemu-arm] " Peter Maydell
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=20180815105430.e6satguezkvfudf5@toto \
--to=edgar.iglesias@xilinx.com \
--cc=edgari@xilinx.com \
--cc=luc.michel@greensocs.com \
--cc=patches@linaro.org \
--cc=peter.maydell@linaro.org \
--cc=qemu-arm@nongnu.org \
--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).