[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH v14 02/20] target/riscv: Add zicfilp extension
From: |
Deepak Gupta |
Subject: |
[PATCH v14 02/20] target/riscv: Add zicfilp extension |
Date: |
Thu, 12 Sep 2024 16:53:02 -0700 |
zicfilp [1] riscv cpu extension enables forward control flow integrity.
If enabled, all indirect calls must land on a landing pad instruction.
This patch sets up space for zicfilp extension in cpuconfig. zicfilp
is dependend on zicsr.
[1] - https://github.com/riscv/riscv-cfi
Signed-off-by: Deepak Gupta <debug@rivosinc.com>
Co-developed-by: Jim Shu <jim.shu@sifive.com>
Co-developed-by: Andy Chiu <andy.chiu@sifive.com>
Reviewed-by: Alistair Francis <alistair.francis@wdc.com>
---
target/riscv/cpu.c | 1 +
target/riscv/cpu_cfg.h | 1 +
target/riscv/tcg/tcg-cpu.c | 5 +++++
3 files changed, 7 insertions(+)
diff --git a/target/riscv/cpu.c b/target/riscv/cpu.c
index 3538c2ae2e..ed2d8a90da 100644
--- a/target/riscv/cpu.c
+++ b/target/riscv/cpu.c
@@ -106,6 +106,7 @@ const RISCVIsaExtData isa_edata_arr[] = {
ISA_EXT_DATA_ENTRY(ziccif, PRIV_VERSION_1_11_0, has_priv_1_11),
ISA_EXT_DATA_ENTRY(zicclsm, PRIV_VERSION_1_11_0, has_priv_1_11),
ISA_EXT_DATA_ENTRY(ziccrse, PRIV_VERSION_1_11_0, has_priv_1_11),
+ ISA_EXT_DATA_ENTRY(zicfilp, PRIV_VERSION_1_12_0, ext_zicfilp),
ISA_EXT_DATA_ENTRY(zicond, PRIV_VERSION_1_12_0, ext_zicond),
ISA_EXT_DATA_ENTRY(zicntr, PRIV_VERSION_1_12_0, ext_zicntr),
ISA_EXT_DATA_ENTRY(zicsr, PRIV_VERSION_1_10_0, ext_zicsr),
diff --git a/target/riscv/cpu_cfg.h b/target/riscv/cpu_cfg.h
index 355afedfd3..fe7ad85b66 100644
--- a/target/riscv/cpu_cfg.h
+++ b/target/riscv/cpu_cfg.h
@@ -67,6 +67,7 @@ struct RISCVCPUConfig {
bool ext_zicbom;
bool ext_zicbop;
bool ext_zicboz;
+ bool ext_zicfilp;
bool ext_zicond;
bool ext_zihintntl;
bool ext_zihintpause;
diff --git a/target/riscv/tcg/tcg-cpu.c b/target/riscv/tcg/tcg-cpu.c
index dea8ab7a43..963c1c604a 100644
--- a/target/riscv/tcg/tcg-cpu.c
+++ b/target/riscv/tcg/tcg-cpu.c
@@ -623,6 +623,11 @@ void riscv_cpu_validate_set_extensions(RISCVCPU *cpu,
Error **errp)
cpu->pmu_avail_ctrs = 0;
}
+ if (cpu->cfg.ext_zicfilp && !cpu->cfg.ext_zicsr) {
+ error_setg(errp, "zicfilp extension requires zicsr extension");
+ return;
+ }
+
/*
* Disable isa extensions based on priv spec after we
* validated and set everything we need.
--
2.45.0
- [PATCH v14 00/20] riscv support for control flow integrity extensions, Deepak Gupta, 2024/09/12
- [PATCH v14 01/20] target/riscv: expose *envcfg csr and priv to qemu-user as well, Deepak Gupta, 2024/09/12
- [PATCH v14 02/20] target/riscv: Add zicfilp extension,
Deepak Gupta <=
- [PATCH v14 03/20] target/riscv: Introduce elp state and enabling controls for zicfilp, Deepak Gupta, 2024/09/12
- [PATCH v14 04/20] target/riscv: save and restore elp state on priv transitions, Deepak Gupta, 2024/09/12
- [PATCH v14 05/20] target/riscv: additional code information for sw check, Deepak Gupta, 2024/09/12
- [PATCH v14 06/20] target/riscv: tracking indirect branches (fcfi) for zicfilp, Deepak Gupta, 2024/09/12
- [PATCH v14 07/20] target/riscv: zicfilp `lpad` impl and branch tracking, Deepak Gupta, 2024/09/12
- [PATCH v14 08/20] disas/riscv: enable `lpad` disassembly, Deepak Gupta, 2024/09/12
- [PATCH v14 09/20] target/riscv: Expose zicfilp extension as a cpu property, Deepak Gupta, 2024/09/12
- [PATCH v14 10/20] target/riscv: Add zicfiss extension, Deepak Gupta, 2024/09/12
- [PATCH v14 11/20] target/riscv: introduce ssp and enabling controls for zicfiss, Deepak Gupta, 2024/09/12
- [PATCH v14 12/20] target/riscv: tb flag for shadow stack instructions, Deepak Gupta, 2024/09/12