| 1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
 | /*
 *    HardInfo - Displays System Information
 *    Copyright (C) 2003-2006 Leandro A. F. Pereira <leandro@hardinfo.org>
 *
 *    This program is free software; you can redistribute it and/or modify
 *    it under the terms of the GNU General Public License as published by
 *    the Free Software Foundation, version 2.
 *
 *    This program is distributed in the hope that it will be useful,
 *    but WITHOUT ANY WARRANTY; without even the implied warranty of
 *    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 *    GNU General Public License for more details.
 *
 *    You should have received a copy of the GNU General Public License
 *    along with this program; if not, write to the Free Software
 *    Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301 USA
 */
#include "hardinfo.h"
#include "devices.h"
gchar *byte_order_str() {
#if G_BYTE_ORDER == G_LITTLE_ENDIAN
    return _("Little Endian");
#else
    return _("Big Endian");
#endif
}
#ifndef PROC_CPUINFO
#define PROC_CPUINFO "/proc/cpuinfo"
#endif
GSList *
processor_scan(void)
{
    Processor *processor;
    FILE *cpuinfo;
    gchar buffer[128];
    cpuinfo = fopen(PROC_CPUINFO, "r");
    if (!cpuinfo)
        return NULL;
    processor = g_new0(Processor, 1);
    while (fgets(buffer, 128, cpuinfo)) {
        gchar **tmp = g_strsplit(buffer, ":", 2);
        if (tmp[0] && tmp[1]) {
            tmp[0] = g_strstrip(tmp[0]);
            tmp[1] = g_strstrip(tmp[1]);
            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_get_info(GSList *processors)
{
    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
                        );
}
 |