Skip to content
This repository has been archived by the owner on Apr 13, 2019. It is now read-only.

Commit

Permalink
target/riscv/pmp: Fix address matching, granularity and debug
Browse files Browse the repository at this point in the history
- Add tracing to CSR reads and writes to pmpcfg and pmpaddr.
- Rename pmp_hart_has_priv to pmp_has_access.
- Simplify address matching rules and add tracing.
- Mask addresss writes so granularity can be detected.
- Remove redundant debugging statements
  • Loading branch information
Michael Clark committed Sep 25, 2018
1 parent 7da9309 commit e7497a5
Show file tree
Hide file tree
Showing 4 changed files with 175 additions and 279 deletions.
11 changes: 6 additions & 5 deletions target/riscv/cpu_helper.c
Original file line number Diff line number Diff line change
Expand Up @@ -452,6 +452,7 @@ int riscv_cpu_handle_mmu_fault(CPUState *cs, vaddr address, int size,
#if !defined(CONFIG_USER_ONLY)
hwaddr pa = 0;
int prot;
target_ulong tlb_entry_size = TARGET_PAGE_SIZE;
#endif
int ret = TRANSLATE_FAIL;

Expand All @@ -464,14 +465,14 @@ int riscv_cpu_handle_mmu_fault(CPUState *cs, vaddr address, int size,
qemu_log_mask(CPU_LOG_MMU,
"%s address=%" VADDR_PRIx " ret %d physical " TARGET_FMT_plx
" prot %d\n", __func__, address, ret, pa, prot);
if (riscv_feature(env, RISCV_FEATURE_PMP) &&
!pmp_hart_has_privs(env, pa, TARGET_PAGE_SIZE, 1 << rw)) {
ret = TRANSLATE_FAIL;
if (ret == TRANSLATE_SUCCESS && riscv_feature(env, RISCV_FEATURE_PMP)) {
ret = pmp_has_access(env, pa, rw, TARGET_PAGE_SIZE, &tlb_entry_size) ?
TRANSLATE_SUCCESS : TRANSLATE_FAIL;
}
if (ret == TRANSLATE_SUCCESS) {
tlb_set_page(cs, address & TARGET_PAGE_MASK, pa & TARGET_PAGE_MASK,
prot, mmu_idx, TARGET_PAGE_SIZE);
} else if (ret == TRANSLATE_FAIL) {
prot, mmu_idx, tlb_entry_size);
} else {
raise_mmu_exception(env, address, rw);
}
#else
Expand Down
Loading

0 comments on commit e7497a5

Please sign in to comment.