qemu-devel.nongnu.org archive mirror
 help / color / mirror / Atom feed
* [PATCH v3 0/7] target/riscv: Fix PMP related problem
@ 2023-04-19  3:27 Weiwei Li
  2023-04-19  3:27 ` [PATCH v3 1/7] target/riscv: Update pmp_get_tlb_size() Weiwei Li
                   ` (6 more replies)
  0 siblings, 7 replies; 17+ messages in thread
From: Weiwei Li @ 2023-04-19  3:27 UTC (permalink / raw)
  To: qemu-riscv, qemu-devel
  Cc: palmer, alistair.francis, bin.meng, dbarboza, zhiwei_liu,
	richard.henderson, wangjunqiang, lazyparser, Weiwei Li

This patchset tries to fix the PMP bypass problem issue https://gitlab.com/qemu-project/qemu/-/issues/1542:

TLB will be cached if the matched PMP entry cover the whole page.  However PMP entries with higher priority may cover part of the page (but not match the access address), which means different regions in this page may have different permission rights. So it also cannot be cached (patch 1).

Writing to pmpaddr didn't trigger tlb flush (patch 3). 

We set the tlb_size to 1 to make the TLB_INVALID_MASK set, and and the next access will again go through tlb_fill. However, this way will not work in tb_gen_code() => get_page_addr_code_hostp(): the TLB host address will be cached, and the following instructions can use this host address directly which may lead to the bypass of PMP related check (patch 6).

The port is available here:
https://github.com/plctlab/plct-qemu/tree/plct-pmp-fix-v3

v2:

Update commit message for patch 1

Add default tlb_size when pmp is diabled or there is no rules and only get the tlb size when translation success in patch 2

Update get_page_addr_code_hostp instead of probe_access_internal to fix the cached host address for instruction fetch in patch 6

Add patch 7 to make the short up really work in pmp_hart_has_privs

Add patch 8 to use pmp_update_rule_addr() and pmp_update_rule_nums() separately

v3:

Ignore disabled PMP entry in pmp_get_tlb_size() in Patch 1

Drop Patch 5, since tb jmp cache have been flushed in tlb_flush, so flush tb seems unnecessary.

Fix commit message problems in Patch 8 (Patch 7 in new patchset)

Weiwei Li (7):
  target/riscv: Update pmp_get_tlb_size()
  target/riscv: Move pmp_get_tlb_size apart from
    get_physical_address_pmp
  target/riscv: Flush TLB when pmpaddr is updated
  target/riscv: Flush TLB only when pmpcfg/pmpaddr really changes
  accel/tcg: Uncache the host address for instruction fetch when tlb
    size < 1
  target/riscv: Make the short cut really work in pmp_hart_has_privs
  target/riscv: Separate pmp_update_rule() in pmpcfg_csr_write

 accel/tcg/cputlb.c        |   5 +
 target/riscv/cpu_helper.c |  24 +--
 target/riscv/pmp.c        | 318 ++++++++++++++++++++------------------
 target/riscv/pmp.h        |   3 +-
 4 files changed, 183 insertions(+), 167 deletions(-)

-- 
2.25.1



^ permalink raw reply	[flat|nested] 17+ messages in thread

end of thread, other threads:[~2023-04-20 13:55 UTC | newest]

Thread overview: 17+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
2023-04-19  3:27 [PATCH v3 0/7] target/riscv: Fix PMP related problem Weiwei Li
2023-04-19  3:27 ` [PATCH v3 1/7] target/riscv: Update pmp_get_tlb_size() Weiwei Li
2023-04-20 11:58   ` LIU Zhiwei
2023-04-20 12:27     ` Weiwei Li
2023-04-19  3:27 ` [PATCH v3 2/7] target/riscv: Move pmp_get_tlb_size apart from get_physical_address_pmp Weiwei Li
2023-04-20 13:19   ` LIU Zhiwei
2023-04-20 13:46     ` Weiwei Li
2023-04-19  3:27 ` [PATCH v3 3/7] target/riscv: Flush TLB when pmpaddr is updated Weiwei Li
2023-04-20 13:21   ` LIU Zhiwei
2023-04-19  3:27 ` [PATCH v3 4/7] target/riscv: Flush TLB only when pmpcfg/pmpaddr really changes Weiwei Li
2023-04-20 13:23   ` LIU Zhiwei
2023-04-19  3:27 ` [PATCH v3 5/7] accel/tcg: Uncache the host address for instruction fetch when tlb size < 1 Weiwei Li
2023-04-19  5:45   ` Richard Henderson
2023-04-19  3:27 ` [PATCH v3 6/7] target/riscv: Make the short cut really work in pmp_hart_has_privs Weiwei Li
2023-04-20 13:33   ` LIU Zhiwei
2023-04-20 13:53     ` Weiwei Li
2023-04-19  3:27 ` [PATCH v3 7/7] target/riscv: Separate pmp_update_rule() in pmpcfg_csr_write Weiwei Li

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).