From: Alistair Francis <alistair23@gmail.com> To: Richard Henderson <richard.henderson@linaro.org> Cc: "open list:RISC-V" <qemu-riscv@nongnu.org>, "qemu-devel@nongnu.org Developers" <qemu-devel@nongnu.org> Subject: Re: [PATCH for-6.2 09/43] target/riscv: Implement do_unaligned_access for user-only Date: Fri, 30 Jul 2021 16:13:07 +1000 [thread overview] Message-ID: <CAKmqyKMZyVZ_OUVCsdh8BEBhb0pUKzEBLHxX+W4gHV+6m-96og@mail.gmail.com> (raw) In-Reply-To: <20210729004647.282017-10-richard.henderson@linaro.org> On Thu, Jul 29, 2021 at 10:55 AM Richard Henderson <richard.henderson@linaro.org> wrote: > > Cc: qemu-riscv@nongnu.org > Signed-off-by: Richard Henderson <richard.henderson@linaro.org> Reviewed-by: Alistair Francis <alistair.francis@wdc.com> Alistair > --- > linux-user/riscv/cpu_loop.c | 7 +++++++ > target/riscv/cpu.c | 2 +- > target/riscv/cpu_helper.c | 8 +++++++- > 3 files changed, 15 insertions(+), 2 deletions(-) > > diff --git a/linux-user/riscv/cpu_loop.c b/linux-user/riscv/cpu_loop.c > index 74a9628dc9..0428140d86 100644 > --- a/linux-user/riscv/cpu_loop.c > +++ b/linux-user/riscv/cpu_loop.c > @@ -92,6 +92,13 @@ void cpu_loop(CPURISCVState *env) > sigcode = TARGET_SEGV_MAPERR; > sigaddr = env->badaddr; > break; > + case RISCV_EXCP_INST_ADDR_MIS: > + case RISCV_EXCP_LOAD_ADDR_MIS: > + case RISCV_EXCP_STORE_AMO_ADDR_MIS: > + signum = TARGET_SIGBUS; > + sigcode = TARGET_BUS_ADRALN; > + sigaddr = env->badaddr; > + break; > case RISCV_EXCP_SEMIHOST: > env->gpr[xA0] = do_common_semihosting(cs); > env->pc += 4; > diff --git a/target/riscv/cpu.c b/target/riscv/cpu.c > index 991a6bb760..591d17e62d 100644 > --- a/target/riscv/cpu.c > +++ b/target/riscv/cpu.c > @@ -644,11 +644,11 @@ static const struct TCGCPUOps riscv_tcg_ops = { > .synchronize_from_tb = riscv_cpu_synchronize_from_tb, > .cpu_exec_interrupt = riscv_cpu_exec_interrupt, > .tlb_fill = riscv_cpu_tlb_fill, > + .do_unaligned_access = riscv_cpu_do_unaligned_access, > > #ifndef CONFIG_USER_ONLY > .do_interrupt = riscv_cpu_do_interrupt, > .do_transaction_failed = riscv_cpu_do_transaction_failed, > - .do_unaligned_access = riscv_cpu_do_unaligned_access, > #endif /* !CONFIG_USER_ONLY */ > }; > > diff --git a/target/riscv/cpu_helper.c b/target/riscv/cpu_helper.c > index 968cb8046f..a440b2834f 100644 > --- a/target/riscv/cpu_helper.c > +++ b/target/riscv/cpu_helper.c > @@ -727,6 +727,7 @@ void riscv_cpu_do_transaction_failed(CPUState *cs, hwaddr physaddr, > riscv_cpu_two_stage_lookup(mmu_idx); > riscv_raise_exception(&cpu->env, cs->exception_index, retaddr); > } > +#endif /* !CONFIG_USER_ONLY */ > > void riscv_cpu_do_unaligned_access(CPUState *cs, vaddr addr, > MMUAccessType access_type, int mmu_idx, > @@ -734,6 +735,7 @@ void riscv_cpu_do_unaligned_access(CPUState *cs, vaddr addr, > { > RISCVCPU *cpu = RISCV_CPU(cs); > CPURISCVState *env = &cpu->env; > + > switch (access_type) { > case MMU_INST_FETCH: > cs->exception_index = RISCV_EXCP_INST_ADDR_MIS; > @@ -748,11 +750,15 @@ void riscv_cpu_do_unaligned_access(CPUState *cs, vaddr addr, > g_assert_not_reached(); > } > env->badaddr = addr; > + > +#ifdef CONFIG_USER_ONLY > + cpu_loop_exit_restore(cs, retaddr); > +#else > env->two_stage_lookup = riscv_cpu_virt_enabled(env) || > riscv_cpu_two_stage_lookup(mmu_idx); > riscv_raise_exception(env, cs->exception_index, retaddr); > +#endif > } > -#endif /* !CONFIG_USER_ONLY */ > > bool riscv_cpu_tlb_fill(CPUState *cs, vaddr address, int size, > MMUAccessType access_type, int mmu_idx, > -- > 2.25.1 > >
WARNING: multiple messages have this Message-ID (diff)
From: Alistair Francis <alistair23@gmail.com> To: Richard Henderson <richard.henderson@linaro.org> Cc: "qemu-devel@nongnu.org Developers" <qemu-devel@nongnu.org>, "open list:RISC-V" <qemu-riscv@nongnu.org> Subject: Re: [PATCH for-6.2 09/43] target/riscv: Implement do_unaligned_access for user-only Date: Fri, 30 Jul 2021 16:13:07 +1000 [thread overview] Message-ID: <CAKmqyKMZyVZ_OUVCsdh8BEBhb0pUKzEBLHxX+W4gHV+6m-96og@mail.gmail.com> (raw) In-Reply-To: <20210729004647.282017-10-richard.henderson@linaro.org> On Thu, Jul 29, 2021 at 10:55 AM Richard Henderson <richard.henderson@linaro.org> wrote: > > Cc: qemu-riscv@nongnu.org > Signed-off-by: Richard Henderson <richard.henderson@linaro.org> Reviewed-by: Alistair Francis <alistair.francis@wdc.com> Alistair > --- > linux-user/riscv/cpu_loop.c | 7 +++++++ > target/riscv/cpu.c | 2 +- > target/riscv/cpu_helper.c | 8 +++++++- > 3 files changed, 15 insertions(+), 2 deletions(-) > > diff --git a/linux-user/riscv/cpu_loop.c b/linux-user/riscv/cpu_loop.c > index 74a9628dc9..0428140d86 100644 > --- a/linux-user/riscv/cpu_loop.c > +++ b/linux-user/riscv/cpu_loop.c > @@ -92,6 +92,13 @@ void cpu_loop(CPURISCVState *env) > sigcode = TARGET_SEGV_MAPERR; > sigaddr = env->badaddr; > break; > + case RISCV_EXCP_INST_ADDR_MIS: > + case RISCV_EXCP_LOAD_ADDR_MIS: > + case RISCV_EXCP_STORE_AMO_ADDR_MIS: > + signum = TARGET_SIGBUS; > + sigcode = TARGET_BUS_ADRALN; > + sigaddr = env->badaddr; > + break; > case RISCV_EXCP_SEMIHOST: > env->gpr[xA0] = do_common_semihosting(cs); > env->pc += 4; > diff --git a/target/riscv/cpu.c b/target/riscv/cpu.c > index 991a6bb760..591d17e62d 100644 > --- a/target/riscv/cpu.c > +++ b/target/riscv/cpu.c > @@ -644,11 +644,11 @@ static const struct TCGCPUOps riscv_tcg_ops = { > .synchronize_from_tb = riscv_cpu_synchronize_from_tb, > .cpu_exec_interrupt = riscv_cpu_exec_interrupt, > .tlb_fill = riscv_cpu_tlb_fill, > + .do_unaligned_access = riscv_cpu_do_unaligned_access, > > #ifndef CONFIG_USER_ONLY > .do_interrupt = riscv_cpu_do_interrupt, > .do_transaction_failed = riscv_cpu_do_transaction_failed, > - .do_unaligned_access = riscv_cpu_do_unaligned_access, > #endif /* !CONFIG_USER_ONLY */ > }; > > diff --git a/target/riscv/cpu_helper.c b/target/riscv/cpu_helper.c > index 968cb8046f..a440b2834f 100644 > --- a/target/riscv/cpu_helper.c > +++ b/target/riscv/cpu_helper.c > @@ -727,6 +727,7 @@ void riscv_cpu_do_transaction_failed(CPUState *cs, hwaddr physaddr, > riscv_cpu_two_stage_lookup(mmu_idx); > riscv_raise_exception(&cpu->env, cs->exception_index, retaddr); > } > +#endif /* !CONFIG_USER_ONLY */ > > void riscv_cpu_do_unaligned_access(CPUState *cs, vaddr addr, > MMUAccessType access_type, int mmu_idx, > @@ -734,6 +735,7 @@ void riscv_cpu_do_unaligned_access(CPUState *cs, vaddr addr, > { > RISCVCPU *cpu = RISCV_CPU(cs); > CPURISCVState *env = &cpu->env; > + > switch (access_type) { > case MMU_INST_FETCH: > cs->exception_index = RISCV_EXCP_INST_ADDR_MIS; > @@ -748,11 +750,15 @@ void riscv_cpu_do_unaligned_access(CPUState *cs, vaddr addr, > g_assert_not_reached(); > } > env->badaddr = addr; > + > +#ifdef CONFIG_USER_ONLY > + cpu_loop_exit_restore(cs, retaddr); > +#else > env->two_stage_lookup = riscv_cpu_virt_enabled(env) || > riscv_cpu_two_stage_lookup(mmu_idx); > riscv_raise_exception(env, cs->exception_index, retaddr); > +#endif > } > -#endif /* !CONFIG_USER_ONLY */ > > bool riscv_cpu_tlb_fill(CPUState *cs, vaddr address, int size, > MMUAccessType access_type, int mmu_idx, > -- > 2.25.1 > >
next prev parent reply other threads:[~2021-07-30 6:14 UTC|newest] Thread overview: 102+ messages / expand[flat|nested] mbox.gz Atom feed top 2021-07-29 0:46 [PATCH for-6.2 00/43] Unaligned accesses for user-only Richard Henderson 2021-07-29 0:46 ` [PATCH for-6.2 01/43] hw/core: Make do_unaligned_access available to user-only Richard Henderson 2021-07-29 6:14 ` Philippe Mathieu-Daudé 2021-07-29 6:19 ` Philippe Mathieu-Daudé 2021-07-29 17:51 ` Richard Henderson 2021-07-29 13:05 ` Peter Maydell 2021-07-29 0:46 ` [PATCH for-6.2 02/43] target/alpha: Implement do_unaligned_access for user-only Richard Henderson 2021-07-29 13:05 ` Peter Maydell 2021-07-29 0:46 ` [PATCH for-6.2 03/43] target/arm: " Richard Henderson 2021-07-29 13:14 ` Peter Maydell 2021-07-29 18:51 ` Richard Henderson 2021-07-29 0:46 ` [PATCH for-6.2 04/43] target/hppa: " Richard Henderson 2021-07-29 13:15 ` Peter Maydell 2021-07-29 17:55 ` Richard Henderson 2021-07-29 0:46 ` [PATCH for-6.2 05/43] target/microblaze: " Richard Henderson 2021-07-29 8:26 ` Philippe Mathieu-Daudé 2021-07-29 13:26 ` Peter Maydell 2021-07-29 18:00 ` Richard Henderson 2021-07-29 18:44 ` Edgar E. Iglesias 2021-07-29 0:46 ` [PATCH for-6.2 06/43] target/mips: " Richard Henderson 2021-07-29 0:46 ` [PATCH for-6.2 07/43] target/ppc: Set fault address in ppc_cpu_do_unaligned_access Richard Henderson 2021-07-29 13:44 ` Peter Maydell 2021-07-29 18:05 ` Richard Henderson 2021-07-30 17:13 ` Cédric Le Goater 2021-07-30 17:23 ` Cédric Le Goater 2021-07-30 16:58 ` Cédric Le Goater 2021-07-29 0:46 ` [PATCH for-6.2 08/43] target/ppc: Implement do_unaligned_access for user-only Richard Henderson 2021-07-29 0:46 ` [PATCH for-6.2 09/43] target/riscv: " Richard Henderson 2021-07-30 6:13 ` Alistair Francis [this message] 2021-07-30 6:13 ` Alistair Francis 2021-07-29 0:46 ` [PATCH for-6.2 10/43] target/s390x: " Richard Henderson 2021-07-29 8:03 ` David Hildenbrand 2021-07-29 0:46 ` [PATCH for-6.2 11/43] target/sh4: Set fault address in superh_cpu_do_unaligned_access Richard Henderson 2021-07-29 6:15 ` Philippe Mathieu-Daudé 2021-07-29 0:46 ` [PATCH for-6.2 12/43] target/sh4: Implement do_unaligned_access for user-only Richard Henderson 2021-07-29 13:52 ` Peter Maydell 2021-07-30 0:01 ` Richard Henderson 2021-07-30 20:54 ` Rob Landley 2021-07-29 0:46 ` [PATCH for-6.2 13/43] target/sparc: Remove DEBUG_UNALIGNED Richard Henderson 2021-07-29 6:16 ` Philippe Mathieu-Daudé 2021-07-29 0:46 ` [PATCH for-6.2 14/43] target/sparc: Set fault address in sparc_cpu_do_unaligned_access Richard Henderson 2021-07-29 14:51 ` Peter Maydell 2021-08-01 15:56 ` Mark Cave-Ayland 2021-08-01 15:59 ` Peter Maydell 2021-08-01 16:13 ` Mark Cave-Ayland 2021-07-29 0:46 ` [PATCH for-6.2 15/43] target/sparc: Implement do_unaligned_access for user-only Richard Henderson 2021-07-29 9:40 ` Philippe Mathieu-Daudé 2021-07-29 18:20 ` Richard Henderson 2021-07-29 0:46 ` [PATCH for-6.2 16/43] target/xtensa: " Richard Henderson 2021-07-29 8:10 ` Philippe Mathieu-Daudé 2021-07-29 14:55 ` Peter Maydell 2021-07-29 18:22 ` Richard Henderson 2021-07-29 0:46 ` [PATCH for-6.2 17/43] accel/tcg: Report unaligned atomics " Richard Henderson 2021-07-29 15:02 ` Peter Maydell 2021-07-29 19:55 ` Philippe Mathieu-Daudé 2021-07-29 0:46 ` [PATCH for-6.2 18/43] accel/tcg: Drop signness in tracing in cputlb.c Richard Henderson 2021-07-29 0:46 ` [PATCH for-6.2 19/43] tcg: Expand MO_SIZE to 3 bits Richard Henderson 2021-07-29 6:23 ` Philippe Mathieu-Daudé 2021-07-29 0:46 ` [PATCH for-6.2 20/43] tcg: Rename TCGMemOpIdx to MemOpIdx Richard Henderson 2021-07-29 6:27 ` Philippe Mathieu-Daudé 2021-07-29 0:46 ` [PATCH for-6.2 21/43] tcg: Split out MemOpIdx to exec/memopidx.h Richard Henderson 2021-07-29 6:27 ` Philippe Mathieu-Daudé 2021-07-29 0:46 ` [PATCH for-6.2 22/43] trace/mem: Pass MemOpIdx to trace_mem_get_info Richard Henderson 2021-07-29 0:46 ` [PATCH for-6.2 23/43] accel/tcg: Remove double bswap for helper_atomic_sto_*_mmu Richard Henderson 2021-07-29 6:29 ` [PATCH for-6.1? " Philippe Mathieu-Daudé 2021-07-29 18:37 ` Richard Henderson 2021-07-29 0:46 ` [PATCH for-6.2 24/43] accel/tcg: Pass MemOpIdx to atomic_trace_*_post Richard Henderson 2021-07-29 6:31 ` Philippe Mathieu-Daudé 2021-07-29 0:46 ` [PATCH for-6.2 25/43] plugins: Reorg arguments to qemu_plugin_vcpu_mem_cb Richard Henderson 2021-08-30 21:26 ` Philippe Mathieu-Daudé 2021-07-29 0:46 ` [PATCH for-6.2 26/43] trace: Split guest_mem_before Richard Henderson 2021-07-29 0:46 ` [PATCH for-6.2 27/43] target/arm: Use MO_128 for 16 byte atomics Richard Henderson 2021-07-29 6:32 ` Philippe Mathieu-Daudé 2021-07-29 0:46 ` [PATCH for-6.2 28/43] target/i386: " Richard Henderson 2021-07-29 0:46 ` [PATCH for-6.2 29/43] target/ppc: " Richard Henderson 2021-07-29 6:34 ` Philippe Mathieu-Daudé 2021-07-29 0:46 ` [PATCH for-6.2 30/43] target/s390x: " Richard Henderson 2021-07-29 6:33 ` Philippe Mathieu-Daudé 2021-07-29 8:04 ` David Hildenbrand 2021-07-29 0:46 ` [PATCH for-6.2 31/43] target/hexagon: Implement cpu_mmu_index Richard Henderson 2021-07-29 2:37 ` Taylor Simpson 2021-07-29 6:35 ` Philippe Mathieu-Daudé 2021-07-29 0:46 ` [PATCH for-6.2 32/43] accel/tcg: Add cpu_{ld,st}*_mmu interfaces Richard Henderson 2021-07-29 0:46 ` [PATCH for-6.2 33/43] accel/tcg: Move cpu_atomic decls to exec/cpu_ldst.h Richard Henderson 2021-07-29 7:36 ` Philippe Mathieu-Daudé 2021-07-29 0:46 ` [PATCH for-6.2 34/43] target/mips: Use cpu_*_data_ra for msa load/store Richard Henderson 2021-07-29 7:38 ` Philippe Mathieu-Daudé 2021-07-29 0:46 ` [PATCH for-6.2 35/43] target/mips: Use 8-byte memory ops " Richard Henderson 2021-07-29 0:46 ` [PATCH for-6.2 36/43] target/s390x: Use cpu_*_mmu instead of helper_*_mmu Richard Henderson 2021-07-29 7:39 ` Philippe Mathieu-Daudé 2021-07-29 0:46 ` [PATCH for-6.2 37/43] target/sparc: " Richard Henderson 2021-07-29 0:46 ` [PATCH for-6.2 38/43] target/arm: " Richard Henderson 2021-07-29 7:41 ` Philippe Mathieu-Daudé 2021-07-29 0:46 ` [PATCH for-6.2 39/43] tcg: Move helper_*_mmu decls to tcg/tcg-ldst.h Richard Henderson 2021-07-29 7:42 ` Philippe Mathieu-Daudé 2021-07-29 0:46 ` [PATCH for-6.2 40/43] linux-user/alpha: Remove TARGET_ALIGNED_ONLY Richard Henderson 2021-07-29 0:46 ` [PATCH for-6.2 41/43] tcg: Add helper_unaligned_mmu for user-only sigbus Richard Henderson 2021-07-29 0:46 ` [PATCH for-6.2 42/43] tcg/i386: Support raising sigbus for user-only Richard Henderson 2021-07-29 0:46 ` [PATCH for-6.2 43/43] tests/tcg/multiarch: Add sigbus.c Richard Henderson 2021-07-29 6:14 ` [PATCH for-6.2 00/43] Unaligned accesses for user-only Philippe Mathieu-Daudé 2021-07-29 14:01 ` Claudio Fontana 2021-08-02 13:14 ` 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=CAKmqyKMZyVZ_OUVCsdh8BEBhb0pUKzEBLHxX+W4gHV+6m-96og@mail.gmail.com \ --to=alistair23@gmail.com \ --cc=qemu-devel@nongnu.org \ --cc=qemu-riscv@nongnu.org \ --cc=richard.henderson@linaro.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: linkBe sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes, see mirroring instructions on how to clone and mirror all data and code used by this external index.