|
Tim Waugh |
12a600 |
--- coreutils-5.97/src/uname.c.sysinfo 2005-09-15 20:57:04.000000000 +0100
|
|
Tim Waugh |
12a600 |
+++ coreutils-5.97/src/uname.c 2006-08-24 17:15:56.000000000 +0100
|
|
Ondrej Vasik |
0363d6 |
@@ -263,7 +263,7 @@
|
|
Ondrej Vasik |
0363d6 |
int
|
|
Tim Waugh |
12a600 |
main (int argc, char **argv)
|
|
Tim Waugh |
12a600 |
{
|
|
Tim Waugh |
12a600 |
- static char const unknown[] = "unknown";
|
|
Tim Waugh |
12a600 |
+ static char unknown[] = "unknown";
|
|
Tim Waugh |
12a600 |
|
|
Tim Waugh |
12a600 |
/* Mask indicating which elements to print. */
|
|
Tim Waugh |
12a600 |
unsigned int toprint = 0;
|
|
Ondrej Vasik |
0363d6 |
@@ -306,13 +306,35 @@
|
|
Tim Waugh |
12a600 |
|
|
Tim Waugh |
12a600 |
if (toprint & PRINT_PROCESSOR)
|
|
Tim Waugh |
12a600 |
{
|
|
Tim Waugh |
12a600 |
- char const *element = unknown;
|
|
Tim Waugh |
12a600 |
+ char *element = unknown;
|
|
Tim Waugh |
12a600 |
#if HAVE_SYSINFO && defined SI_ARCHITECTURE
|
|
Tim Waugh |
12a600 |
{
|
|
Tim Waugh |
12a600 |
static char processor[257];
|
|
cvsdist |
de6548 |
if (0 <= sysinfo (SI_ARCHITECTURE, processor, sizeof processor))
|
|
cvsdist |
de6548 |
element = processor;
|
|
cvsdist |
de6548 |
}
|
|
cvsdist |
de6548 |
+#else
|
|
cvsdist |
de6548 |
+ {
|
|
cvsdist |
de6548 |
+ struct utsname u;
|
|
cvsdist |
de6548 |
+ uname(&u);
|
|
cvsdist |
de6548 |
+ element = u.machine;
|
|
cvsdist |
de6548 |
+#ifdef linux
|
|
cvsdist |
de6548 |
+ if(!strcmp(element, "i686")) { /* Check for Athlon */
|
|
cvsdist |
de6548 |
+ char cinfo[1024];
|
|
cvsdist |
de6548 |
+ FILE *f=fopen("/proc/cpuinfo", "r");
|
|
cvsdist |
de6548 |
+ if(f) {
|
|
cvsdist |
de6548 |
+ while(fgets(cinfo, 1024, f)) {
|
|
cvsdist |
de6548 |
+ if(!strncmp(cinfo, "vendor_id", 9)) {
|
|
cvsdist |
de6548 |
+ if(strstr(cinfo, "AuthenticAMD"))
|
|
cvsdist |
de6548 |
+ element="athlon";
|
|
cvsdist |
de6548 |
+ break;
|
|
cvsdist |
de6548 |
+ }
|
|
cvsdist |
de6548 |
+ }
|
|
cvsdist |
de6548 |
+ fclose(f);
|
|
cvsdist |
de6548 |
+ }
|
|
cvsdist |
de6548 |
+ }
|
|
cvsdist |
de6548 |
+#endif
|
|
cvsdist |
de6548 |
+ }
|
|
cvsdist |
de6548 |
#endif
|
|
cvsdist |
de6548 |
#ifdef UNAME_PROCESSOR
|
|
cvsdist |
de6548 |
if (element == unknown)
|
|
Ondrej Vasik |
0363d6 |
@@ -348,7 +370,7 @@
|
|
Tim Waugh |
12a600 |
|
|
Tim Waugh |
12a600 |
if (toprint & PRINT_HARDWARE_PLATFORM)
|
|
Tim Waugh |
12a600 |
{
|
|
Tim Waugh |
12a600 |
- char const *element = unknown;
|
|
Tim Waugh |
12a600 |
+ char *element = unknown;
|
|
Tim Waugh |
12a600 |
#if HAVE_SYSINFO && defined SI_PLATFORM
|
|
Tim Waugh |
12a600 |
{
|
|
Tim Waugh |
12a600 |
static char hardware_platform[257];
|
|
Ondrej Vasik |
0363d6 |
@@ -356,6 +378,14 @@
|
|
cvsdist |
de6548 |
hardware_platform, sizeof hardware_platform))
|
|
cvsdist |
de6548 |
element = hardware_platform;
|
|
cvsdist |
de6548 |
}
|
|
cvsdist |
de6548 |
+#else
|
|
cvsdist |
de6548 |
+ {
|
|
cvsdist |
de6548 |
+ struct utsname u;
|
|
cvsdist |
de6548 |
+ uname(&u);
|
|
cvsdist |
de6548 |
+ element = u.machine;
|
|
cvsdist |
de6548 |
+ if(strlen(element)==4 && element[0]=='i' && element[2]=='8' && element[3]=='6')
|
|
cvsdist |
de6548 |
+ element[1]='3';
|
|
cvsdist |
de6548 |
+ }
|
|
cvsdist |
de6548 |
#endif
|
|
cvsdist |
de6548 |
#ifdef UNAME_HARDWARE_PLATFORM
|
|
cvsdist |
de6548 |
if (element == unknown)
|