[PATCH 0/7] target/riscv: Add support for PC-relative translation

Weiwei Li posted 7 patches 1 year ago
Patches applied successfully (tree, apply log)
git fetch https://github.com/patchew-project/qemu tags/patchew/20230409105306.28575-1-liweiwei@iscas.ac.cn
Maintainers: Palmer Dabbelt <palmer@dabbelt.com>, Alistair Francis <alistair.francis@wdc.com>, Bin Meng <bin.meng@windriver.com>, Weiwei Li <liweiwei@iscas.ac.cn>, Daniel Henrique Barboza <dbarboza@ventanamicro.com>, Liu Zhiwei <zhiwei_liu@linux.alibaba.com>, Christoph Muellner <christoph.muellner@vrull.eu>
There is a newer version of this series
target/riscv/cpu.c                            | 31 +++++--
.../riscv/insn_trans/trans_privileged.c.inc   |  2 +-
target/riscv/insn_trans/trans_rvi.c.inc       | 43 ++++++---
target/riscv/insn_trans/trans_rvv.c.inc       |  4 +-
target/riscv/insn_trans/trans_rvzawrs.c.inc   |  2 +-
target/riscv/insn_trans/trans_xthead.c.inc    |  2 +-
target/riscv/translate.c                      | 92 +++++++++++++------
7 files changed, 117 insertions(+), 59 deletions(-)
[PATCH 0/7] target/riscv: Add support for PC-relative translation
Posted by Weiwei Li 1 year ago
This patchset tries to add support for PC-relative translation.

The existence of CF_PCREL can improve performance with the guest
kernel's address space randomization.  Each guest process maps libc.so
(et al) at a different virtual address, and this allows those
translations to be shared.

And support of PC-relative translation is the precondition to support
pointer mask for instruction.

The port is available here:
https://github.com/plctlab/plct-qemu/tree/plct-pcrel-upstream

Weiwei Li (7):
  target/riscv: Fix target address to update badaddr
  target/riscv: Introduce cur_insn_len into DisasContext
  target/riscv: Change gen_goto_tb to work on displacements
  target/riscv: Change gen_set_pc_imm to gen_update_pc
  target/riscv: Use true diff for gen_pc_plus_diff
  target/riscv: Enable PC-relative translation
  target/riscv: Remove pc_succ_insn from DisasContext

 target/riscv/cpu.c                            | 31 +++++--
 .../riscv/insn_trans/trans_privileged.c.inc   |  2 +-
 target/riscv/insn_trans/trans_rvi.c.inc       | 43 ++++++---
 target/riscv/insn_trans/trans_rvv.c.inc       |  4 +-
 target/riscv/insn_trans/trans_rvzawrs.c.inc   |  2 +-
 target/riscv/insn_trans/trans_xthead.c.inc    |  2 +-
 target/riscv/translate.c                      | 92 +++++++++++++------
 7 files changed, 117 insertions(+), 59 deletions(-)

-- 
2.25.1