aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authoreopXD <eop.chen@sifive.com>2022-06-06 06:16:56 +0000
committerAlistair Francis <alistair.francis@wdc.com>2022-06-10 09:31:43 +1000
commitb8312675d62b878d6647065f01c2c1337a74d4ee (patch)
tree48a12ede2a862f4c71308bc192dc536ab8cbdbf8
parent803963f7cb7220be0c80d9acd87a0ebea167f35e (diff)
downloadqemu-b8312675d62b878d6647065f01c2c1337a74d4ee.zip
qemu-b8312675d62b878d6647065f01c2c1337a74d4ee.tar.gz
qemu-b8312675d62b878d6647065f01c2c1337a74d4ee.tar.bz2
target/riscv: rvv: Add option 'rvv_ta_all_1s' to enable optional tail agnostic behavior
According to v-spec, tail agnostic behavior can be either kept as undisturbed or set elements' bits to all 1s. To distinguish the difference of tail policies, QEMU should be able to simulate the tail agnostic behavior as "set tail elements' bits to all 1s". There are multiple possibility for agnostic elements according to v-spec. The main intent of this patch-set tries to add option that can distinguish between tail policies. Setting agnostic elements to all 1s allows QEMU to express this. This commit adds option 'rvv_ta_all_1s' is added to enable the behavior, it is default as disabled. Signed-off-by: eop Chen <eop.chen@sifive.com> Reviewed-by: Frank Chang <frank.chang@sifive.com> Reviewed-by: Weiwei Li <liweiwei@iscas.ac.cn> Reviewed-by: Alistair Francis <alistair.francis@wdc.com> Message-Id: <165449614532.19704.7000832880482980398-16@git.sr.ht> Signed-off-by: Alistair Francis <alistair.francis@wdc.com>
-rw-r--r--target/riscv/cpu.c2
1 files changed, 2 insertions, 0 deletions
diff --git a/target/riscv/cpu.c b/target/riscv/cpu.c
index 0497af4..e5aa1e9 100644
--- a/target/riscv/cpu.c
+++ b/target/riscv/cpu.c
@@ -918,6 +918,8 @@ static Property riscv_cpu_properties[] = {
DEFINE_PROP_UINT64("resetvec", RISCVCPU, cfg.resetvec, DEFAULT_RSTVEC),
DEFINE_PROP_BOOL("short-isa-string", RISCVCPU, cfg.short_isa_string, false),
+
+ DEFINE_PROP_BOOL("rvv_ta_all_1s", RISCVCPU, cfg.rvv_ta_all_1s, false),
DEFINE_PROP_END_OF_LIST(),
};