5244b2
diff -urNp coreutils-8.2-orig/src/uname.c coreutils-8.2/src/uname.c
5244b2
--- coreutils-8.2-orig/src/uname.c	2009-09-23 10:25:44.000000000 +0200
5244b2
+++ coreutils-8.2/src/uname.c	2009-12-19 09:09:11.663607110 +0100
5244b2
@@ -301,7 +301,7 @@ main (int argc, char **argv)
5244b2
 
5244b2
   if (toprint & PRINT_PROCESSOR)
5244b2
     {
5244b2
-      char const *element = unknown;
5244b2
+      char *element = unknown;
5244b2
 #if HAVE_SYSINFO && defined SI_ARCHITECTURE
5244b2
       {
5244b2
         static char processor[257];
5244b2
@@ -308,6 +308,12 @@ main (int argc, char **argv)
5244b2
         if (0 <= sysinfo (SI_ARCHITECTURE, processor, sizeof processor))
5244b2
           element = processor;
5244b2
       }
5244b2
+#else
5244b2
+      {
5244b2
+	static struct utsname u;
5244b2
+	uname(&u);
5244b2
+	element = u.machine;
5244b2
+      }
5244b2
 #endif
5244b2
 #ifdef UNAME_PROCESSOR
5244b2
       if (element == unknown)
5244b2
@@ -351,7 +357,7 @@ main (int argc, char **argv)
5244b2
 
5244b2
   if (toprint & PRINT_HARDWARE_PLATFORM)
5244b2
     {
5244b2
-      char const *element = unknown;
5244b2
+      char *element = unknown;
5244b2
 #if HAVE_SYSINFO && defined SI_PLATFORM
5244b2
       {
5244b2
         static char hardware_platform[257];
5244b2
@@ -353,6 +359,14 @@ main (int argc, char **argv)
5244b2
                           hardware_platform, sizeof hardware_platform))
5244b2
           element = hardware_platform;
5244b2
       }
5244b2
+#else
5244b2
+      {
5244b2
+	static struct utsname u;
5244b2
+	uname(&u);
5244b2
+	element = u.machine;
5244b2
+	if(strlen(element)==4 && element[0]=='i' && element[2]=='8' && element[3]=='6')
5244b2
+		element[1]='3';
5244b2
+      }
5244b2
 #endif
5244b2
 #ifdef UNAME_HARDWARE_PLATFORM
5244b2
       if (element == unknown)