[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[PATCH for-9.0 v11 11/18] target/riscv/tcg: add MISA user options hash
From: |
Daniel Henrique Barboza |
Subject: |
[PATCH for-9.0 v11 11/18] target/riscv/tcg: add MISA user options hash |
Date: |
Thu, 23 Nov 2023 15:51:15 -0300 |
We already track user choice for multi-letter extensions because we
needed to honor user choice when enabling/disabling extensions during
realize(). We refrained from adding the same mechanism for MISA
extensions since we didn't need it.
Profile support requires tne need to check for user choice for MISA
extensions, so let's add the corresponding hash now. It works like the
existing multi-letter hash (multi_ext_user_opts) but tracking MISA bits
options in the cpu_set_misa_ext_cfg() callback.
Note that we can't re-use the same hash from multi-letter extensions
because that hash uses cpu->cfg offsets as keys, while for MISA
extensions we're using MISA bits as keys.
After adding the user hash in cpu_set_misa_ext_cfg(), setting default
values with object_property_set_bool() in add_misa_properties() will end
up marking the user choice hash with them. Set the default value
manually to avoid it.
Signed-off-by: Daniel Henrique Barboza <dbarboza@ventanamicro.com>
Reviewed-by: Alistair Francis <alistair.francis@wdc.com>
Reviewed-by: LIU Zhiwei <zhiwei_liu@linux.alibaba.com>
Reviewed-by: Andrew Jones <ajones@ventanamicro.com>
---
target/riscv/tcg/tcg-cpu.c | 15 ++++++++++++++-
1 file changed, 14 insertions(+), 1 deletion(-)
diff --git a/target/riscv/tcg/tcg-cpu.c b/target/riscv/tcg/tcg-cpu.c
index f26dc7748d..930aa7465b 100644
--- a/target/riscv/tcg/tcg-cpu.c
+++ b/target/riscv/tcg/tcg-cpu.c
@@ -34,6 +34,7 @@
/* Hash that stores user set extensions */
static GHashTable *multi_ext_user_opts;
+static GHashTable *misa_ext_user_opts;
static bool cpu_cfg_ext_is_user_set(uint32_t ext_offset)
{
@@ -807,6 +808,10 @@ static void cpu_set_misa_ext_cfg(Object *obj, Visitor *v,
const char *name,
return;
}
+ g_hash_table_insert(misa_ext_user_opts,
+ GUINT_TO_POINTER(misa_bit),
+ (gpointer)value);
+
prev_val = env->misa_ext & misa_bit;
if (value == prev_val) {
@@ -878,6 +883,7 @@ static const RISCVCPUMisaExtConfig misa_ext_cfgs[] = {
*/
static void riscv_cpu_add_misa_properties(Object *cpu_obj)
{
+ CPURISCVState *env = &RISCV_CPU(cpu_obj)->env;
bool use_def_vals = riscv_cpu_is_generic(cpu_obj);
int i;
@@ -898,7 +904,13 @@ static void riscv_cpu_add_misa_properties(Object *cpu_obj)
NULL, (void *)misa_cfg);
object_property_set_description(cpu_obj, name, desc);
if (use_def_vals) {
- object_property_set_bool(cpu_obj, name, misa_cfg->enabled, NULL);
+ if (misa_cfg->enabled) {
+ env->misa_ext |= bit;
+ env->misa_ext_mask |= bit;
+ } else {
+ env->misa_ext &= ~bit;
+ env->misa_ext_mask &= ~bit;
+ }
}
}
}
@@ -1147,6 +1159,7 @@ static void tcg_cpu_instance_init(CPUState *cs)
RISCVCPU *cpu = RISCV_CPU(cs);
Object *obj = OBJECT(cpu);
+ misa_ext_user_opts = g_hash_table_new(NULL, g_direct_equal);
multi_ext_user_opts = g_hash_table_new(NULL, g_direct_equal);
riscv_cpu_add_user_properties(obj);
--
2.41.0
- [PATCH for-9.0 v11 02/18] target/riscv/tcg: do not use "!generic" CPU checks, (continued)
- [PATCH for-9.0 v11 02/18] target/riscv/tcg: do not use "!generic" CPU checks, Daniel Henrique Barboza, 2023/11/23
- [PATCH for-9.0 v11 03/18] target/riscv/tcg: update priv_ver on user_set extensions, Daniel Henrique Barboza, 2023/11/23
- [PATCH for-9.0 v11 06/18] target/riscv/tcg: add 'zic64b' support, Daniel Henrique Barboza, 2023/11/23
- [PATCH for-9.0 v11 04/18] target/riscv: add rv64i CPU, Daniel Henrique Barboza, 2023/11/23
- [PATCH for-9.0 v11 05/18] target/riscv: add zicbop extension flag, Daniel Henrique Barboza, 2023/11/23
- [PATCH for-9.0 v11 07/18] riscv-qmp-cmds.c: expose named features in cpu_model_expansion, Daniel Henrique Barboza, 2023/11/23
- [PATCH for-9.0 v11 09/18] target/riscv/kvm: add 'rva22u64' flag as unavailable, Daniel Henrique Barboza, 2023/11/23
- [PATCH for-9.0 v11 11/18] target/riscv/tcg: add MISA user options hash,
Daniel Henrique Barboza <=
- [PATCH for-9.0 v11 12/18] target/riscv/tcg: add riscv_cpu_write_misa_bit(), Daniel Henrique Barboza, 2023/11/23
- [PATCH for-9.0 v11 08/18] target/riscv: add rva22u64 profile definition, Daniel Henrique Barboza, 2023/11/23
- [PATCH for-9.0 v11 10/18] target/riscv/tcg: add user flag for profile support, Daniel Henrique Barboza, 2023/11/23
- [PATCH for-9.0 v11 15/18] target/riscv/tcg: honor user choice for G MISA bits, Daniel Henrique Barboza, 2023/11/23
- [PATCH for-9.0 v11 13/18] target/riscv/tcg: handle profile MISA bits, Daniel Henrique Barboza, 2023/11/23
- [PATCH for-9.0 v11 14/18] target/riscv/tcg: add hash table insert helpers, Daniel Henrique Barboza, 2023/11/23
- [PATCH for-9.0 v11 16/18] target/riscv/tcg: validate profiles during finalize, Daniel Henrique Barboza, 2023/11/23
- [PATCH for-9.0 v11 17/18] riscv-qmp-cmds.c: add profile flags in cpu-model-expansion, Daniel Henrique Barboza, 2023/11/23
- [PATCH for-9.0 v11 18/18] target/riscv: add 'rva22u64' CPU, Daniel Henrique Barboza, 2023/11/23