]> git.ipfire.org Git - thirdparty/gcc.git/commitdiff
rs6000: Disable mode promotion for pseudos
authorHaochen Gui <guihaoc@gcc.gnu.org>
Fri, 4 Jun 2021 06:38:53 +0000 (14:38 +0800)
committerSegher Boessenkool <segher@kernel.crashing.org>
Mon, 30 Aug 2021 09:36:57 +0000 (09:36 +0000)
rs6000 has instructions that can do almost everything 32 bit
at least as efficiently as corresponding 64 bit things. The
mode promotion can be defered to when a wide mode is necessary.
So it helps a lot not promote mode for pseudos. SPECint test
shows that the overall performance improvement (by geomean) is
more than 2% with this patch.

testsuite/gcc.target/powerpc/not-promote-mode.c illustrates how
the patch eliminates the redundant extensions and do further
optimization by disabling mode promotion for pseduos.

gcc/ChangeLog

* config/rs6000/rs6000.h (PROMOTE_MODE): Remove.

gcc/testsuite/ChangeLog:

* gcc.target/powerpc/not-promote-mode.c: New.

(cherry picked from commit 9080a3bf23297885fdc47221da37a71d6dec93c5)

gcc/config/rs6000/rs6000.h
gcc/testsuite/gcc.target/powerpc/not-promote-mode.c [new file with mode: 0644]

index a7953fad965a3510920900de8953fd5fd2f37feb..4ca6372435d68df53822c6462d2da9c64e339876 100644 (file)
@@ -667,17 +667,6 @@ extern unsigned char rs6000_recip_bits[];
 \f
 /* Target machine storage layout.  */
 
-/* Define this macro if it is advisable to hold scalars in registers
-   in a wider mode than that declared by the program.  In such cases,
-   the value is constrained to be within the bounds of the declared
-   type, but kept valid in the wider mode.  The signedness of the
-   extension may differ from that of the type.  */
-
-#define PROMOTE_MODE(MODE,UNSIGNEDP,TYPE)      \
-  if (GET_MODE_CLASS (MODE) == MODE_INT                \
-      && GET_MODE_SIZE (MODE) < (TARGET_32BIT ? 4 : 8)) \
-    (MODE) = TARGET_32BIT ? SImode : DImode;
-
 /* Define this if most significant bit is lowest numbered
    in instructions that operate on numbered bit-fields.  */
 /* That is true on RS/6000.  */
diff --git a/gcc/testsuite/gcc.target/powerpc/not-promote-mode.c b/gcc/testsuite/gcc.target/powerpc/not-promote-mode.c
new file mode 100644 (file)
index 0000000..29af1f8
--- /dev/null
@@ -0,0 +1,13 @@
+/* { dg-do compile { target { lp64 } } } */
+/* { dg-options "-O2" } */
+
+extern void bar ();
+
+void foo ()
+{
+  int i;
+  for (i = 0; i < 10000; i++)
+    bar ();
+}
+
+/* { dg-final { scan-assembler-not   {\mrldicl\M} } } */