]> git.ipfire.org Git - thirdparty/qemu.git/commitdiff
include/exec: Introduce env_cpu_const()
authorIlya Leoshkevich <iii@linux.ibm.com>
Thu, 12 Sep 2024 09:28:20 +0000 (11:28 +0200)
committerRichard Henderson <richard.henderson@linaro.org>
Sun, 13 Oct 2024 17:05:51 +0000 (10:05 -0700)
It's the same as env_cpu(), but for const objects.

Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
Signed-off-by: Ilya Leoshkevich <iii@linux.ibm.com>
Message-ID: <20240912093012.402366-2-iii@linux.ibm.com>
Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
include/exec/cpu-common.h
linux-user/elfload.c

index 2e1b499cb71c3c090e3a84894eeb51aa7c96501b..638dc806a5feff268d629535c132a2c6b334f324 100644 (file)
@@ -238,6 +238,17 @@ static inline ArchCPU *env_archcpu(CPUArchState *env)
     return (void *)env - sizeof(CPUState);
 }
 
+/**
+ * env_cpu_const(env)
+ * @env: The architecture environment
+ *
+ * Return the CPUState associated with the environment.
+ */
+static inline const CPUState *env_cpu_const(const CPUArchState *env)
+{
+    return (void *)env - sizeof(CPUState);
+}
+
 /**
  * env_cpu(env)
  * @env: The architecture environment
@@ -246,7 +257,7 @@ static inline ArchCPU *env_archcpu(CPUArchState *env)
  */
 static inline CPUState *env_cpu(CPUArchState *env)
 {
-    return (void *)env - sizeof(CPUState);
+    return (CPUState *)env_cpu_const(env);
 }
 
 #ifndef CONFIG_USER_ONLY
index 52c88a68a90f070470d8028f30792a9b5d33cad3..352960b771ded04bbf8ef1ce8d09a99b948cb750 100644 (file)
@@ -4314,7 +4314,7 @@ static int wmr_write_region(void *opaque, target_ulong start,
  */
 static int elf_core_dump(int signr, const CPUArchState *env)
 {
-    const CPUState *cpu = env_cpu((CPUArchState *)env);
+    const CPUState *cpu = env_cpu_const(env);
     const TaskState *ts = (const TaskState *)get_task_state((CPUState *)cpu);
     struct rlimit dumpsize;
     CountAndSizeRegions css;