gcc/
authorienkovich <ienkovich@138bc75d-0d04-0410-961f-82ee72b054a4>
Wed, 13 May 2015 08:29:14 +0000 (08:29 +0000)
committerienkovich <ienkovich@138bc75d-0d04-0410-961f-82ee72b054a4>
Wed, 13 May 2015 08:29:14 +0000 (08:29 +0000)
PR target/65103
* config/i386/i386.c (ix86_rtx_costs): We want to propagate
link time constants into adress expressions and therefore set
their cost to 0.

gcc/testsuite/

PR target/65103
* gcc.target/i386/pr65103-3.c: New.

git-svn-id: svn+ssh://gcc.gnu.org/svn/gcc/trunk@223119 138bc75d-0d04-0410-961f-82ee72b054a4

gcc/ChangeLog
gcc/config/i386/i386.c
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.target/i386/pr65103-3.c [new file with mode: 0644]

index 1906845..2bb07a5 100644 (file)
@@ -1,3 +1,10 @@
+2015-05-13  Ilya Enkovich  <ilya.enkovich@intel.com>
+
+       PR target/65103
+       * config/i386/i386.c (ix86_rtx_costs): We want to propagate
+       link time constants into adress expressions and therefore set
+       their cost to 0.
+
 2015-05-13  Jakub Jelinek  <jakub@redhat.com>
 
        PR target/66112
index bda3257..de333d8 100644 (file)
@@ -42006,7 +42006,9 @@ ix86_rtx_costs (rtx x, int code_i, int outer_code_i, int opno, int *total,
               && !(TARGET_64BIT
                    && (GET_CODE (x) == LABEL_REF
                        || (GET_CODE (x) == SYMBOL_REF
-                           && SYMBOL_REF_LOCAL_P (x)))))
+                           && SYMBOL_REF_LOCAL_P (x))))
+              /* Use 0 cost for CONST to improve its propagation.  */
+              && (TARGET_64BIT || GET_CODE (x) != CONST))
        *total = 1;
       else
        *total = 0;
index 0f6b188..b5f96f3 100644 (file)
@@ -1,3 +1,8 @@
+2015-05-13  Ilya Enkovich  <ilya.enkovich@intel.com>
+
+       PR target/65103
+       * gcc.target/i386/pr65103-3.c: New.
+
 2015-05-13  Martin Liska  <mliska@suse.cz>
 
        * g++.dg/ipa/pr65557.C: Remove unnecessary dump flag.
diff --git a/gcc/testsuite/gcc.target/i386/pr65103-3.c b/gcc/testsuite/gcc.target/i386/pr65103-3.c
new file mode 100644 (file)
index 0000000..eddf20b
--- /dev/null
@@ -0,0 +1,19 @@
+/* { dg-do compile { target ia32 } } */
+/* { dg-require-effective-target pie } */
+/* { dg-options "-O2 -fPIE" } */
+/* { dg-final { scan-assembler-not "GOTOFF," } } */
+
+static int *data[100];
+
+void test (long a, long b)
+{
+  do
+    {
+      if( a < b )
+        {
+         data[a] = data[b];
+         a++;
+        }
+    }
+  while (a <= b);
+}