aboutsummaryrefslogtreecommitdiff
path: root/util/cpuinfo-loongarch.c
diff options
context:
space:
mode:
authorRichard Henderson <richard.henderson@linaro.org>2023-09-16 15:01:47 -0700
committerRichard Henderson <richard.henderson@linaro.org>2023-11-06 08:27:21 -0800
commit0885f1221e0add5529dada1e7948d2c00189cb8b (patch)
treea84e97244b914cb2c0f7c8ccffe60f6d023d50ec /util/cpuinfo-loongarch.c
parent2b2ae0a42e67a85273c0976466f1a634ede084dc (diff)
downloadqemu-0885f1221e0add5529dada1e7948d2c00189cb8b.zip
qemu-0885f1221e0add5529dada1e7948d2c00189cb8b.tar.gz
qemu-0885f1221e0add5529dada1e7948d2c00189cb8b.tar.bz2
util: Add cpuinfo for loongarch64
Signed-off-by: Richard Henderson <richard.henderson@linaro.org> Reviewed-by: Jiajie Chen <c@jia.je> Message-Id: <20230916220151.526140-4-richard.henderson@linaro.org>
Diffstat (limited to 'util/cpuinfo-loongarch.c')
-rw-r--r--util/cpuinfo-loongarch.c35
1 files changed, 35 insertions, 0 deletions
diff --git a/util/cpuinfo-loongarch.c b/util/cpuinfo-loongarch.c
new file mode 100644
index 0000000..08b6d74
--- /dev/null
+++ b/util/cpuinfo-loongarch.c
@@ -0,0 +1,35 @@
+/*
+ * SPDX-License-Identifier: GPL-2.0-or-later
+ * Host specific cpu identification for LoongArch.
+ */
+
+#include "qemu/osdep.h"
+#include "host/cpuinfo.h"
+
+#ifdef CONFIG_GETAUXVAL
+# include <sys/auxv.h>
+#else
+# include "elf.h"
+#endif
+#include <asm/hwcap.h>
+
+unsigned cpuinfo;
+
+/* Called both as constructor and (possibly) via other constructors. */
+unsigned __attribute__((constructor)) cpuinfo_init(void)
+{
+ unsigned info = cpuinfo;
+ unsigned long hwcap;
+
+ if (info) {
+ return info;
+ }
+
+ hwcap = qemu_getauxval(AT_HWCAP);
+
+ info = CPUINFO_ALWAYS;
+ info |= (hwcap & HWCAP_LOONGARCH_LSX ? CPUINFO_LSX : 0);
+
+ cpuinfo = info;
+ return info;
+}