Patch ieee128-lib-patch001b
authorMichael Meissner <Michael Meissner meissner@linux.ibm.com>
Tue, 5 May 2020 16:28:48 +0000 (12:28 -0400)
committerMichael Meissner <Michael Meissner meissner@linux.ibm.com>
Tue, 5 May 2020 16:28:48 +0000 (12:28 -0400)
gcc/ChangeLog.meissner
gcc/config/rs6000/rs6000.c

index 98683f4355447c7bd1743d767964e72d467bf53f..332f5ead10b6ebfaa8bea404ac3deab397fe740b 100644 (file)
@@ -1,3 +1,11 @@
+2020-05-05  Michael Meissner  <meissner@linux.ibm.com>
+
+       (ieee128-lib-patch001b)
+       PR target/94630
+       * config/rs6000/rs6000.c (rs6000_mangle_decl_assembler_name): Do
+       the mapping for <name>l to <name>f128 when the long double default
+       is IEEE 128-bit.
+
 2020-05-05   Michael Meissner  <meissner@linux.ibm.com>
 
        Clone branch
index 355aea8628def909bef27e6baaed8bbeae887207..abc1b8909eb587f022498b4ad2011d4204c0508c 100644 (file)
@@ -26326,13 +26326,15 @@ rs6000_globalize_decl_name (FILE * stream, tree decl)
    library before you can switch the real*16 type at compile time.
 
    We use the TARGET_MANGLE_DECL_ASSEMBLER_NAME hook to change this name.  We
-   only do this if the default is that long double is IBM extended double, and
-   the user asked for IEEE 128-bit.  */
+   only do this transformation if the __float128 type is enabled.  This
+   prevents us from doing the transformation on older 32-bit parts that might
+   have enabled using IEEE 128-bit floating point as the default long double
+   type.  */
 
 static tree
 rs6000_mangle_decl_assembler_name (tree decl, tree id)
 {
-  if (!TARGET_IEEEQUAD_DEFAULT && TARGET_IEEEQUAD && TARGET_LONG_DOUBLE_128
+  if (TARGET_FLOAT128_TYPE && TARGET_IEEEQUAD && TARGET_LONG_DOUBLE_128
       && TREE_CODE (decl) == FUNCTION_DECL && DECL_IS_BUILTIN (decl) )
     {
       size_t len = IDENTIFIER_LENGTH (id);