[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PULL 45/47] target/riscv32: Fix masking of physical address
From: |
Alistair Francis |
Subject: |
[PULL 45/47] target/riscv32: Fix masking of physical address |
Date: |
Thu, 12 Sep 2024 15:29:50 +1000 |
From: Andrew Jones <ajones@ventanamicro.com>
C doesn't extend the sign bit for unsigned types since there isn't a
sign bit to extend. This means a promotion of a u32 to a u64 results
in the upper 32 bits of the u64 being zero. If that result is then
used as a mask on another u64 the upper 32 bits will be cleared. rv32
physical addresses may be up to 34 bits wide, so we don't want to
clear the high bits while page aligning the address. The fix is to
use hwaddr for the mask, which, even on rv32, is 64-bits wide.
Fixes: af3fc195e3c8 ("target/riscv: Change the TLB page size depends on PMP
entries.")
Signed-off-by: Andrew Jones <ajones@ventanamicro.com>
Reviewed-by: Alistair Francis <alistair.francis@wdc.com>
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
Message-ID: <20240909083241.43836-2-ajones@ventanamicro.com>
Signed-off-by: Alistair Francis <alistair.francis@wdc.com>
---
target/riscv/cpu_helper.c | 6 +++---
1 file changed, 3 insertions(+), 3 deletions(-)
diff --git a/target/riscv/cpu_helper.c b/target/riscv/cpu_helper.c
index 395a1d9140..4b2c72780c 100644
--- a/target/riscv/cpu_helper.c
+++ b/target/riscv/cpu_helper.c
@@ -1323,7 +1323,7 @@ bool riscv_cpu_tlb_fill(CPUState *cs, vaddr address, int
size,
int ret = TRANSLATE_FAIL;
int mode = mmuidx_priv(mmu_idx);
/* default TLB page size */
- target_ulong tlb_size = TARGET_PAGE_SIZE;
+ hwaddr tlb_size = TARGET_PAGE_SIZE;
env->guest_phys_fault_addr = 0;
@@ -1375,7 +1375,7 @@ bool riscv_cpu_tlb_fill(CPUState *cs, vaddr address, int
size,
qemu_log_mask(CPU_LOG_MMU,
"%s PMP address=" HWADDR_FMT_plx " ret %d prot"
- " %d tlb_size " TARGET_FMT_lu "\n",
+ " %d tlb_size %" HWADDR_PRIu "\n",
__func__, pa, ret, prot_pmp, tlb_size);
prot &= prot_pmp;
@@ -1409,7 +1409,7 @@ bool riscv_cpu_tlb_fill(CPUState *cs, vaddr address, int
size,
qemu_log_mask(CPU_LOG_MMU,
"%s PMP address=" HWADDR_FMT_plx " ret %d prot"
- " %d tlb_size " TARGET_FMT_lu "\n",
+ " %d tlb_size %" HWADDR_PRIu "\n",
__func__, pa, ret, prot_pmp, tlb_size);
prot &= prot_pmp;
--
2.46.0
- [PULL 38/47] bsd-user: Define RISC-V signal handling structures and constants, (continued)
- [PULL 38/47] bsd-user: Define RISC-V signal handling structures and constants, Alistair Francis, 2024/09/12
- [PULL 32/47] bsd-user: Add RISC-V signal trampoline setup function, Alistair Francis, 2024/09/12
- [PULL 34/47] bsd-user: Add RISC-V thread setup and initialization support, Alistair Francis, 2024/09/12
- [PULL 46/47] target/riscv/cpu_helper: Fix linking problem with semihosting disabled, Alistair Francis, 2024/09/12
- [PULL 43/47] hw/riscv: Respect firmware ELF entry point, Alistair Francis, 2024/09/12
- [PULL 39/47] bsd-user: Implement RISC-V signal trampoline setup functions, Alistair Francis, 2024/09/12
- [PULL 37/47] bsd-user: Add generic RISC-V64 target definitions, Alistair Francis, 2024/09/12
- [PULL 40/47] bsd-user: Implement 'get_mcontext' for RISC-V, Alistair Francis, 2024/09/12
- [PULL 45/47] target/riscv32: Fix masking of physical address,
Alistair Francis <=
- [PULL 47/47] hw/intc: riscv-imsic: Fix interrupt state updates., Alistair Francis, 2024/09/12
- [PULL 42/47] bsd-user: Add RISC-V 64-bit Target Configuration and Debug XML Files, Alistair Francis, 2024/09/12
- [PULL 41/47] bsd-user: Implement set_mcontext and get_ucontext_sigreturn for RISCV, Alistair Francis, 2024/09/12
- [PULL 44/47] target: riscv: Add Svvptc extension support, Alistair Francis, 2024/09/12
- Re: [PULL 00/47] riscv-to-apply queue, Peter Maydell, 2024/09/13