On 3/17/25 21:51, Pierrick Bouvier wrote:
Including "cpu.h" from code that is not compiled per target is ambiguous
by definition. Thus we introduce a conditional include, to allow every
architecture to set this, to point to the correct definition.
hw/X or target/X will now include directly "target/X/cpu.h", and
"target/X/cpu.h" will define CPU_INCLUDE to itself.
We already do this change for arm cpu as part of this commit.
Signed-off-by: Pierrick Bouvier <pierrick.bouv...@linaro.org>
---
include/exec/cpu-all.h | 4 ++++
target/arm/cpu.h | 2 ++
2 files changed, 6 insertions(+)
diff --git a/include/exec/cpu-all.h b/include/exec/cpu-all.h
index 7c6c47c43ed..1a756c0cfb3 100644
--- a/include/exec/cpu-all.h
+++ b/include/exec/cpu-all.h
@@ -46,7 +46,11 @@
CPUArchState *cpu_copy(CPUArchState *env);
+#ifdef CPU_INCLUDE
+#include CPU_INCLUDE
+#else
#include "cpu.h"
+#endif
#ifdef CONFIG_USER_ONLY
diff --git a/target/arm/cpu.h b/target/arm/cpu.h
index a8177c6c2e8..7aeb012428c 100644
--- a/target/arm/cpu.h
+++ b/target/arm/cpu.h
@@ -31,6 +31,8 @@
#include "target/arm/multiprocessing.h"
#include "target/arm/gtimer.h"
+#define CPU_INCLUDE "target/arm/cpu.h"
+
#ifdef TARGET_AARCH64
#define KVM_HAVE_MCE_INJECTION 1
#endif
This doesn't make any sense to me. CPU_INCLUDE is defined within the very file that
you're trying to include by avoiding "cpu.h".
r~