re PR ipa/65318 (wrong code at -Os and above on x86_64-linux-gnu)
authorMartin Liska <mliska@suse.cz>
Thu, 5 Mar 2015 17:49:49 +0000 (18:49 +0100)
committerJan Hubicka <hubicka@gcc.gnu.org>
Thu, 5 Mar 2015 17:49:49 +0000 (17:49 +0000)
PR ipa/65318
* ipa-icf.c (sem_variable::equals): Compare variables types.
* gcc.dg/ipa/pr65318.c: New test.

From-SVN: r221221

gcc/ChangeLog
gcc/ipa-icf.c
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.dg/ipa/pr65318.c [new file with mode: 0644]

index 73a346a5f4ae7f0264664b92736511edac2560f0..f78091957da115ee2244d1ea57b362beaaff51da 100644 (file)
@@ -1,3 +1,8 @@
+2015-03-05  Martin Liska  <mliska@suse.cz>
+
+       PR ipa/65318
+       * ipa-icf.c (sem_variable::equals): Compare variables types.
+
 2015-03-05  Alex Velenko  <alex.velenko@arm.com>
 
        * config/arm/arm.c (arm_function_in_section_p): Fix predicate to
index c55a09f72810a0a9fffa6c9ad7a5dc37abcd3482..a7f19d6fd8d69ed0312dc815bb7289a824ce27cd 100644 (file)
@@ -1501,6 +1501,11 @@ sem_variable::equals (sem_item *item,
   if (DECL_INITIAL (item->decl) == error_mark_node && in_lto_p)
     dyn_cast <varpool_node *>(item->node)->get_constructor ();
 
+  /* As seen in PR ipa/65303 we have to compare variables types.  */
+  if (!func_checker::compatible_types_p (TREE_TYPE (decl),
+                                        TREE_TYPE (item->decl)))
+    return return_false_with_msg ("variables types are different");
+
   ret = sem_variable::equals (DECL_INITIAL (decl),
                              DECL_INITIAL (item->node->decl));
   if (dump_file && (dump_flags & TDF_DETAILS))
index 4f853ee4ca94a7986d428ebe9c88adc469eb1b86..09d42b3d851b43b38cb51d2ed1fe7372ff603725 100644 (file)
@@ -1,3 +1,8 @@
+2015-03-05  Martin Liska  <mliska@suse.cz>
+
+       PR ipa/65318
+       * gcc.dg/ipa/pr65318.c: New test.
+
 2015-03-05  Marek Polacek  <polacek@redhat.com>
 
        * c-c++-common/ubsan/bounds-6.c: Use dg-do run.
diff --git a/gcc/testsuite/gcc.dg/ipa/pr65318.c b/gcc/testsuite/gcc.dg/ipa/pr65318.c
new file mode 100644 (file)
index 0000000..f23b3a2
--- /dev/null
@@ -0,0 +1,18 @@
+/* { dg-do compile } */
+/* { dg-options "-O2 -fdump-ipa-icf-details"  } */
+
+static short a = 0;
+short b = -1;
+static unsigned short c = 0;
+
+int
+main ()
+{
+  if (a <= b)
+   return 1;
+
+  return 0;
+}
+
+/* { dg-final { scan-ipa-dump "Equal symbols: 0" "icf"  } } */
+/* { dg-final { cleanup-ipa-dump "icf" } } */