4a3c933
diff --git a/lib/rpmrc.c b/lib/rpmrc.c
4a3c933
index 4ebefa7..920ceed 100644
4a3c933
--- a/lib/rpmrc.c
4a3c933
+++ b/lib/rpmrc.c
4a3c933
@@ -737,6 +737,80 @@ static int is_sun4v()
72d4c0c
 }
72d4c0c
 #endif
72d4c0c
 
72d4c0c
+#if defined(__linux__) && defined(__arm__)
72d4c0c
+static int has_neon()
72d4c0c
+{
72d4c0c
+        char buffer[4096], *p;
72d4c0c
+        int fd = open("/proc/cpuinfo", O_RDONLY);
72d4c0c
+        if (read(fd, &buffer, sizeof(buffer) - 1) == -1) {
72d4c0c
+                rpmlog(RPMLOG_WARNING, _("read(/proc/cpuinfo) failed\n"));
72d4c0c
+                close(fd);
72d4c0c
+                return 0;
72d4c0c
+        }
72d4c0c
+        close(fd);
72d4c0c
+
72d4c0c
+        p = strstr(buffer, "Features");
72d4c0c
+        p = strtok(p, "\n");
72d4c0c
+        p = strstr(p, "neon");
72d4c0c
+        p = strtok(p, " ");
72d4c0c
+        if (p == NULL) {
72d4c0c
+                rpmlog(RPMLOG_WARNING, _("/proc/cpuinfo has no 'Features' line\n"));
72d4c0c
+                return 0;
72d4c0c
+        } else if (strcmp(p, "neon") == 0) {
72d4c0c
+                return 1;
72d4c0c
+        }
72d4c0c
+        return 0;
72d4c0c
+}
72d4c0c
+
4a3c933
+static int has_vfpv3()
72d4c0c
+{
72d4c0c
+        char buffer[4096], *p;
72d4c0c
+        int fd = open("/proc/cpuinfo", O_RDONLY);
72d4c0c
+        if (read(fd, &buffer, sizeof(buffer) - 1) == -1) {
72d4c0c
+                rpmlog(RPMLOG_WARNING, _("read(/proc/cpuinfo) failed\n"));
72d4c0c
+                close(fd);
72d4c0c
+                return 0;
72d4c0c
+        }
72d4c0c
+        close(fd);
72d4c0c
+
72d4c0c
+        p = strstr(buffer, "Features");
72d4c0c
+        p = strtok(p, "\n");
72d4c0c
+        p = strstr(p, "vfpv3");
72d4c0c
+        p = strtok(p, " ");
72d4c0c
+        if (p == NULL) {
72d4c0c
+                rpmlog(RPMLOG_WARNING, _("/proc/cpuinfo has no 'Features' line\n"));
72d4c0c
+                return 0;
72d4c0c
+        } else if (strcmp(p, "vfpv3") == 0) {
72d4c0c
+                return 1;
72d4c0c
+        }
72d4c0c
+        return 0;
72d4c0c
+}
4a3c933
+
4a3c933
+static int has_vfp()
4a3c933
+{
4a3c933
+        char buffer[4096], *p;
4a3c933
+        int fd = open("/proc/cpuinfo", O_RDONLY);
4a3c933
+        if (read(fd, &buffer, sizeof(buffer) - 1) == -1) {
4a3c933
+                rpmlog(RPMLOG_WARNING, _("read(/proc/cpuinfo) failed\n"));
4a3c933
+                close(fd);
4a3c933
+                return 0;
4a3c933
+        }
4a3c933
+        close(fd);
4a3c933
+
4a3c933
+        p = strstr(buffer, "Features");
4a3c933
+        p = strtok(p, "\n");
4a3c933
+        p = strstr(p, "vfp");
4a3c933
+        p = strtok(p, " ");
4a3c933
+        if (p == NULL) {
4a3c933
+                rpmlog(RPMLOG_WARNING, _("/proc/cpuinfo has no 'Features' line\n"));
4a3c933
+                return 0;
4a3c933
+        } else if (strcmp(p, "vfp") == 0) {
4a3c933
+                return 1;
4a3c933
+        }
4a3c933
+        return 0;
4a3c933
+}
72d4c0c
+#endif
72d4c0c
+
72d4c0c
 
72d4c0c
 #	if defined(__linux__) && defined(__i386__)
72d4c0c
 #include <setjmp.h>
4a3c933
@@ -1147,6 +1221,20 @@ static void defaultMachine(const char ** arch,
0bacf1c
 #	endif	/* __ORDER_BIG_ENDIAN__ */
Phil Knirsch e780ef5
 #	endif	/* ppc64*-linux */
72d4c0c
 
72d4c0c
+#	if defined(__linux__) && defined(__arm__)
72d4c0c
+	{
72d4c0c
+	    if (strcmp(un.machine, "armv7l") == 0 ) {
4a3c933
+	        if (has_neon() && has_vfpv3())
72d4c0c
+                    strcpy(un.machine, "armv7hnl");
4a3c933
+                else if (has_vfpv3())
72d4c0c
+                    strcpy(un.machine, "armv7hl");
72d4c0c
+	    } else if (strcmp(un.machine, "armv6l") == 0 ) {
4a3c933
+                if (has_vfp())
72d4c0c
+                    strcpy(un.machine, "armv6hl");
72d4c0c
+	    }
72d4c0c
+	}
72d4c0c
+#	endif	/* arm*-linux */
72d4c0c
+
72d4c0c
 #	if defined(__GNUC__) && defined(__alpha__)
72d4c0c
 	{
72d4c0c
 	    unsigned long amask, implver;