aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPhilippe Mathieu-Daudé <philmd@linaro.org>2025-02-09 22:11:46 +0100
committerPhilippe Mathieu-Daudé <philmd@linaro.org>2025-03-06 15:46:18 +0100
commit05769aae6288a69ba04b0162ed0a15b08b2b7878 (patch)
tree06af96214089f9131ae2d78e9d5ba38f3abbe4fa
parent1e6fbd637bbbfdd8ff13ed665b5294fab4771862 (diff)
downloadqemu-05769aae6288a69ba04b0162ed0a15b08b2b7878.zip
qemu-05769aae6288a69ba04b0162ed0a15b08b2b7878.tar.gz
qemu-05769aae6288a69ba04b0162ed0a15b08b2b7878.tar.bz2
target/xtensa: Finalize config in xtensa_register_core()
Make XtensaConfigList::config not const. Only modify XtensaConfig within xtensa_register_core(), when the class is registered, not when it is initialized. Signed-off-by: Philippe Mathieu-Daudé <philmd@linaro.org> Reviewed-by: Richard Henderson <richard.henderson@linaro.org> Acked-by: Max Filippov <jcmvbkbc@gmail.com> Message-Id: <20250210133134.90879-4-philmd@linaro.org>
-rw-r--r--target/xtensa/cpu.h2
-rw-r--r--target/xtensa/helper.c5
2 files changed, 4 insertions, 3 deletions
diff --git a/target/xtensa/cpu.h b/target/xtensa/cpu.h
index 0e6302c..8d70bfc 100644
--- a/target/xtensa/cpu.h
+++ b/target/xtensa/cpu.h
@@ -490,7 +490,7 @@ typedef struct XtensaConfig {
} XtensaConfig;
typedef struct XtensaConfigList {
- const XtensaConfig *config;
+ XtensaConfig *config;
struct XtensaConfigList *next;
} XtensaConfigList;
diff --git a/target/xtensa/helper.c b/target/xtensa/helper.c
index 2978c47..f64699b 100644
--- a/target/xtensa/helper.c
+++ b/target/xtensa/helper.c
@@ -173,9 +173,8 @@ static void xtensa_core_class_init(ObjectClass *oc, void *data)
{
CPUClass *cc = CPU_CLASS(oc);
XtensaCPUClass *xcc = XTENSA_CPU_CLASS(oc);
- XtensaConfig *config = data;
+ const XtensaConfig *config = data;
- xtensa_finalize_config(config);
xcc->config = config;
/*
@@ -195,6 +194,8 @@ void xtensa_register_core(XtensaConfigList *node)
.class_data = (void *)node->config,
};
+ xtensa_finalize_config(node->config);
+
node->next = xtensa_cores;
xtensa_cores = node;
type.name = g_strdup_printf(XTENSA_CPU_TYPE_NAME("%s"), node->config->name);