8e0f4e6086
Update to v2.10.1 a stable, bug-fix-only release Also needed one more fix for qemu-testsuite OBS-URL: https://build.opensuse.org/request/show/531017 OBS-URL: https://build.opensuse.org/package/show/Virtualization/qemu?expand=0&rev=367
62 lines
2.0 KiB
Diff
62 lines
2.0 KiB
Diff
From 66ea32c79be3274c9325d0063604fc881e4d1dfb Mon Sep 17 00:00:00 2001
|
|
From: Alexander Graf <agraf@suse.de>
|
|
Date: Mon, 23 Jul 2012 10:24:14 +0200
|
|
Subject: [PATCH] linux-user: Fake /proc/cpuinfo
|
|
MIME-Version: 1.0
|
|
Content-Type: text/plain; charset=UTF-8
|
|
Content-Transfer-Encoding: 8bit
|
|
|
|
Fedora 17 for ARM reads /proc/cpuinfo and fails if it doesn't contain
|
|
ARM related contents. This patch implements a quick hack to expose real
|
|
/proc/cpuinfo data taken from a real world machine.
|
|
|
|
The real fix would be to generate at least the flags automatically based
|
|
on the selected CPU. Please do not submit this patch upstream until this
|
|
has happened.
|
|
|
|
Signed-off-by: Alexander Graf <agraf@suse.de>
|
|
[AF: Rebased for v1.6 and v1.7]
|
|
Signed-off-by: Andreas Färber <afaerber@suse.de>
|
|
---
|
|
linux-user/syscall.c | 20 ++++++++++++++++++++
|
|
1 file changed, 20 insertions(+)
|
|
|
|
diff --git a/linux-user/syscall.c b/linux-user/syscall.c
|
|
index 1802aec4cb..cf22c5b96a 100644
|
|
--- a/linux-user/syscall.c
|
|
+++ b/linux-user/syscall.c
|
|
@@ -7472,6 +7472,25 @@ static int open_self_stat(void *cpu_env, int fd)
|
|
return 0;
|
|
}
|
|
|
|
+static int open_cpuinfo(void *cpu_env, int fd)
|
|
+{
|
|
+ dprintf(fd,
|
|
+"Processor : ARMv7 Processor rev 5 (v7l)\n"
|
|
+"BogoMIPS : 799.53\n"
|
|
+"Features : swp half thumb fastmult vfp edsp thumbee neon vfpv3\n"
|
|
+"CPU implementer : 0x41\n"
|
|
+"CPU architecture: 7\n"
|
|
+"CPU variant : 0x2\n"
|
|
+"CPU part : 0xc08\n"
|
|
+"CPU revision : 5\n"
|
|
+"\n"
|
|
+"Hardware : Genesi Efika MX (Smarttop)\n"
|
|
+"Revision : 51030\n"
|
|
+"Serial : 0000000000000000\n");
|
|
+
|
|
+ return 0;
|
|
+}
|
|
+
|
|
static int open_self_auxv(void *cpu_env, int fd)
|
|
{
|
|
CPUState *cpu = ENV_GET_CPU((CPUArchState *)cpu_env);
|
|
@@ -7586,6 +7605,7 @@ static int do_openat(void *cpu_env, int dirfd, const char *pathname, int flags,
|
|
#if defined(HOST_WORDS_BIGENDIAN) != defined(TARGET_WORDS_BIGENDIAN)
|
|
{ "/proc/net/route", open_net_route, is_proc },
|
|
#endif
|
|
+ { "cpuinfo", open_cpuinfo, is_proc_myself },
|
|
{ NULL, NULL, NULL }
|
|
};
|
|
|