target/riscv: Hoist second stage mode change to callers
Move the check from the top of get_physical_address to the two callers, where passing mmu_idx makes no sense. Signed-off-by: Richard Henderson <richard.henderson@linaro.org> Reviewed-by: Alistair Francis <alistair.francis@wdc.com> Reviewed-by: Weiwei Li <liweiwei@iscas.ac.cn> Tested-by: Daniel Henrique Barboza <dbarboza@ventanamicro.com> Message-Id: <20230325105429.1142530-19-richard.henderson@linaro.org> Message-Id: <20230412114333.118895-19-richard.henderson@linaro.org> Signed-off-by: Alistair Francis <alistair.francis@wdc.com>
This commit is contained in:
parent
eaecd473ca
commit
a427c83633
@ -777,14 +777,6 @@ static int get_physical_address(CPURISCVState *env, hwaddr *physical,
|
|||||||
use_background = true;
|
use_background = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (first_stage == false) {
|
|
||||||
/*
|
|
||||||
* We are in stage 2 translation, this is similar to stage 1.
|
|
||||||
* Stage 2 is always taken as U-mode
|
|
||||||
*/
|
|
||||||
mode = PRV_U;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (mode == PRV_M || !riscv_cpu_cfg(env)->mmu) {
|
if (mode == PRV_M || !riscv_cpu_cfg(env)->mmu) {
|
||||||
*physical = addr;
|
*physical = addr;
|
||||||
*prot = PAGE_READ | PAGE_WRITE | PAGE_EXEC;
|
*prot = PAGE_READ | PAGE_WRITE | PAGE_EXEC;
|
||||||
@ -890,7 +882,7 @@ restart:
|
|||||||
/* Do the second stage translation on the base PTE address. */
|
/* Do the second stage translation on the base PTE address. */
|
||||||
int vbase_ret = get_physical_address(env, &vbase, &vbase_prot,
|
int vbase_ret = get_physical_address(env, &vbase, &vbase_prot,
|
||||||
base, NULL, MMU_DATA_LOAD,
|
base, NULL, MMU_DATA_LOAD,
|
||||||
mmu_idx, false, true,
|
MMUIdx_U, false, true,
|
||||||
is_debug);
|
is_debug);
|
||||||
|
|
||||||
if (vbase_ret != TRANSLATE_SUCCESS) {
|
if (vbase_ret != TRANSLATE_SUCCESS) {
|
||||||
@ -1271,7 +1263,7 @@ bool riscv_cpu_tlb_fill(CPUState *cs, vaddr address, int size,
|
|||||||
im_address = pa;
|
im_address = pa;
|
||||||
|
|
||||||
ret = get_physical_address(env, &pa, &prot2, im_address, NULL,
|
ret = get_physical_address(env, &pa, &prot2, im_address, NULL,
|
||||||
access_type, mmu_idx, false, true,
|
access_type, MMUIdx_U, false, true,
|
||||||
false);
|
false);
|
||||||
|
|
||||||
qemu_log_mask(CPU_LOG_MMU,
|
qemu_log_mask(CPU_LOG_MMU,
|
||||||
|
Loading…
Reference in New Issue
Block a user