gcc: add ARM codegen fix from PR 65932
authorFelix Fietkau <nbd@openwrt.org>
Thu, 3 Sep 2015 13:14:44 +0000 (13:14 +0000)
committerFelix Fietkau <nbd@openwrt.org>
Thu, 3 Sep 2015 13:14:44 +0000 (13:14 +0000)
Signed-off-by: Felix Fietkau <nbd@openwrt.org>
SVN-Revision: 46774

toolchain/gcc/Config.in
toolchain/gcc/patches/5.2.0/030-fix-arm-codegen-PR-65932.patch [new file with mode: 0644]

index f5de52db6f10891ed1dcf85c6a36156e51ee0417..8a68056e9acb50121376a005160f9cc227e44c4d 100644 (file)
@@ -23,7 +23,6 @@ choice
        config GCC_USE_VERSION_5
                select GCC_VERSION_5
                bool "gcc 5.x"
        config GCC_USE_VERSION_5
                select GCC_VERSION_5
                bool "gcc 5.x"
-               depends on BROKEN
 
 endchoice
 
 
 endchoice
 
diff --git a/toolchain/gcc/patches/5.2.0/030-fix-arm-codegen-PR-65932.patch b/toolchain/gcc/patches/5.2.0/030-fix-arm-codegen-PR-65932.patch
new file mode 100644 (file)
index 0000000..7f0b43c
--- /dev/null
@@ -0,0 +1,21 @@
+Fix from https://gcc.gnu.org/bugzilla/show_bug.cgi?id=65932
+
+--- a/gcc/config/arm/arm.h
++++ b/gcc/config/arm/arm.h
+@@ -628,16 +628,10 @@ extern int arm_arch_crc;
+    type, but kept valid in the wider mode.  The signedness of the
+    extension may differ from that of the type.  */
+-/* It is far faster to zero extend chars than to sign extend them */
+-
+ #define PROMOTE_MODE(MODE, UNSIGNEDP, TYPE)   \
+   if (GET_MODE_CLASS (MODE) == MODE_INT               \
+       && GET_MODE_SIZE (MODE) < 4)            \
+     {                                         \
+-      if (MODE == QImode)                     \
+-      UNSIGNEDP = 1;                          \
+-      else if (MODE == HImode)                        \
+-      UNSIGNEDP = 1;                          \
+       (MODE) = SImode;                                \
+     }