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