aboutsummaryrefslogtreecommitdiff
path: root/modules/devices/m68k/processor.c
diff options
context:
space:
mode:
authorSimon Quigley <tsimonq2@ubuntu.com>2017-08-16 04:32:39 -0500
committerSimon Quigley <tsimonq2@ubuntu.com>2017-08-16 04:32:39 -0500
commit82306ca849c0710209e5a39754f446d0335a276d (patch)
tree8d297400e5c36357b9147401631e653e035283d3 /modules/devices/m68k/processor.c
parent21a53faf18b01a65a341115000e97d70b37c750c (diff)
parent9a9db98089717990cd5e0eef529f6bb0819ebe46 (diff)
Updated version 0.5.1+git20170815 from 'upstream/0.5.1+git20170815'
with Debian dir 36bf8e7e43d9f6621a63c79a597af2f4f76271b7
Diffstat (limited to 'modules/devices/m68k/processor.c')
-rw-r--r--modules/devices/m68k/processor.c75
1 files changed, 44 insertions, 31 deletions
diff --git a/modules/devices/m68k/processor.c b/modules/devices/m68k/processor.c
index d9902428..e030732a 100644
--- a/modules/devices/m68k/processor.c
+++ b/modules/devices/m68k/processor.c
@@ -18,6 +18,7 @@
#include "hardinfo.h"
#include "devices.h"
+#include "cpu_util.h"
GSList *
processor_scan(void)
@@ -26,54 +27,66 @@ processor_scan(void)
FILE *cpuinfo;
gchar buffer[128];
- cpuinfo = fopen("/proc/cpuinfo", "r");
+ cpuinfo = fopen(PROC_CPUINFO, "r");
if (!cpuinfo)
- return NULL;
+ return NULL;
processor = g_new0(Processor, 1);
while (fgets(buffer, 128, cpuinfo)) {
- gchar **tmp = g_strsplit(buffer, ":", 2);
+ gchar **tmp = g_strsplit(buffer, ":", 2);
- if (tmp[0] && tmp[1]) {
- tmp[0] = g_strstrip(tmp[0]);
- tmp[1] = g_strstrip(tmp[1]);
+ if (tmp[0] && tmp[1]) {
+ tmp[0] = g_strstrip(tmp[0]);
+ tmp[1] = g_strstrip(tmp[1]);
- get_str("CPU", processor->model_name);
- get_float("Clocking", processor->cpu_mhz);
- get_float("bogomips", processor->bogomips);
-
- get_str("FPU", processor->has_fpu);
- }
- g_strfreev(tmp);
+ get_str("CPU", processor->model_name);
+ get_str("MMU", processor->mmu_name);
+ get_str("FPU", processor->fpu_name);
+ get_float("Clocking", processor->cpu_mhz);
+ get_float("BogoMips", processor->bogomips);
+ get_str("Calibration", processor->calibration);
+ }
+ g_strfreev(tmp);
}
-
+
gchar *tmp;
tmp = g_strconcat("Motorola ", processor->model_name, NULL);
g_free(processor->model_name);
processor->model_name = tmp;
-
+
fclose(cpuinfo);
return g_slist_append(NULL, processor);
}
+gchar *processor_name(GSList * processors) {
+ return processor_name_default(processors);
+}
+
+gchar *processor_describe(GSList * processors) {
+ return processor_describe_default(processors);
+}
+
gchar *
processor_get_info(GSList *processors)
{
- Processor *processor = (Processor *)processors->data;
-
- return g_strdup_printf("[Processor]\n"
- "Name=%s\n"
- "Frequency=%.2fMHz\n"
- "BogoMips=%.2f\n"
- "Byte Order=%s\n",
- processor->model_name,
- processor->cpu_mhz,
- processor->bogomips,
-#if G_BYTE_ORDER == G_LITTLE_ENDIAN
- "Little Endian"
-#else
- "Big Endian"
-#endif
- );
+ Processor *processor = (Processor *)processors->data;
+
+ return g_strdup_printf("[%s]\n"
+ "%s=%s\n" /* cpu */
+ "%s=%s\n" /* mmu */
+ "%s=%s\n" /* fpu */
+ "%s=%.2f %s\n" /* frequency */
+ "%s=%.2f\n" /* bogomips */
+ "%s=%s\n" /* byte order */
+ "%s=%s\n", /* calibration */
+ _("Processor"),
+ _("Model"), processor->model_name,
+ _("MMU"), processor->mmu_name,
+ _("FPU"), processor->fpu_name,
+ _("Frequency"), processor->cpu_mhz, _("MHz"),
+ _("BogoMips"), processor->bogomips,
+ _("Byte Order"), byte_order_str(),
+ _("Calibration"), processor->calibration
+ );
}