Blame SOURCES/coreutils-8.2-uname-processortype.patch

f5e30c
diff --git a/src/uname.c b/src/uname.c
f5e30c
index 6371ca2..1ad8fd7 100644
f5e30c
--- a/src/uname.c
f5e30c
+++ b/src/uname.c
f5e30c
@@ -300,13 +300,19 @@ main (int argc, char **argv)
f5e30c
 
f5e30c
   if (toprint & PRINT_PROCESSOR)
f5e30c
     {
f5e30c
-      char const *element = unknown;
f5e30c
+      char *element = unknown;
f5e30c
 #if HAVE_SYSINFO && defined SI_ARCHITECTURE
f5e30c
       {
f5e30c
         static char processor[257];
f5e30c
         if (0 <= sysinfo (SI_ARCHITECTURE, processor, sizeof processor))
f5e30c
           element = processor;
f5e30c
       }
f5e30c
+#else
f5e30c
+      {
f5e30c
+	static struct utsname u;
f5e30c
+	uname(&u);
f5e30c
+	element = u.machine;
f5e30c
+      }
f5e30c
 #endif
f5e30c
 #ifdef UNAME_PROCESSOR
f5e30c
       if (element == unknown)
f5e30c
@@ -344,7 +350,7 @@ main (int argc, char **argv)
f5e30c
 
f5e30c
   if (toprint & PRINT_HARDWARE_PLATFORM)
f5e30c
     {
f5e30c
-      char const *element = unknown;
f5e30c
+      char *element = unknown;
f5e30c
 #if HAVE_SYSINFO && defined SI_PLATFORM
f5e30c
       {
f5e30c
         static char hardware_platform[257];
f5e30c
@@ -352,6 +358,14 @@ main (int argc, char **argv)
f5e30c
                           hardware_platform, sizeof hardware_platform))
f5e30c
           element = hardware_platform;
f5e30c
       }
f5e30c
+#else
f5e30c
+      {
f5e30c
+	static struct utsname u;
f5e30c
+	uname(&u);
f5e30c
+	element = u.machine;
f5e30c
+	if(strlen(element)==4 && element[0]=='i' && element[2]=='8' && element[3]=='6')
f5e30c
+		element[1]='3';
f5e30c
+      }
f5e30c
 #endif
f5e30c
 #ifdef UNAME_HARDWARE_PLATFORM
f5e30c
       if (element == unknown)