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