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
       {
Ondrej Vasik 250517
         static char processor[257];
Ondrej Vasik 250517
         if (0 <= sysinfo (SI_ARCHITECTURE, processor, sizeof processor))
Ondrej Vasik 250517
           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
       {
Ondrej Vasik 250517
         static char hardware_platform[257];
Ondrej Vasik 0363d6
@@ -356,6 +378,14 @@
Ondrej Vasik 250517
                           hardware_platform, sizeof hardware_platform))
Ondrej Vasik 250517
           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)