Add to same comdate group only if set (PR middle-end/90899)
authorMartin Liska <mliska@suse.cz>
Wed, 3 Jul 2019 08:31:35 +0000 (10:31 +0200)
committerMartin Liska <marxin@gcc.gnu.org>
Wed, 3 Jul 2019 08:31:35 +0000 (08:31 +0000)
2019-07-03  Martin Liska  <mliska@suse.cz>

PR middle-end/90899
* multiple_target.c (create_dispatcher_calls): Add to comdat
group only if set for ifunc.
2019-07-03  Martin Liska  <mliska@suse.cz>

PR middle-end/90899
* gcc.target/i386/pr90899.c: New test.

From-SVN: r272992

gcc/ChangeLog
gcc/multiple_target.c
gcc/testsuite/ChangeLog
gcc/testsuite/gcc.target/i386/pr90899.c [new file with mode: 0644]

index 3d1a07acb4010b195a36131e936b6cd7c623b415..f2f69905f76b75b62d581fbe87b931f03e330295 100644 (file)
@@ -1,3 +1,9 @@
+2019-07-03  Martin Liska  <mliska@suse.cz>
+
+       PR middle-end/90899
+       * multiple_target.c (create_dispatcher_calls): Add to comdat
+       group only if set for ifunc.
+
 2019-07-03  Martin Liska  <mliska@suse.cz>
 
        PR target/88056
index fa194d416fe00eee1892cd8293ab5fd254c9f192..7aea684a40a1f0f2c6b0a03cc126a835c9501d3a 100644 (file)
@@ -158,7 +158,8 @@ create_dispatcher_calls (struct cgraph_node *node)
            {
              symtab_node *source = ref->referring;
              source->create_reference (inode, IPA_REF_ALIAS);
-             source->add_to_same_comdat_group (inode);
+             if (inode->get_comdat_group ())
+               source->add_to_same_comdat_group (inode);
            }
          else
            gcc_unreachable ();
index fc960bb7e1fde42f09699b1637ff8dc2e348de30..512e86cf2cbf590b6de1b232975a36be7c1b9291 100644 (file)
@@ -1,3 +1,8 @@
+2019-07-03  Martin Liska  <mliska@suse.cz>
+
+       PR middle-end/90899
+       * gcc.target/i386/pr90899.c: New test.
+
 2019-07-03  Jakub Jelinek  <jakub@redhat.com>
 
        PR tree-optimization/91033
diff --git a/gcc/testsuite/gcc.target/i386/pr90899.c b/gcc/testsuite/gcc.target/i386/pr90899.c
new file mode 100644 (file)
index 0000000..e0e2d5a
--- /dev/null
@@ -0,0 +1,6 @@
+/* PR middle-end/90899 */
+/* { dg-do compile } */
+/* { dg-require-ifunc "" } */
+
+__attribute__ ((target_clones ("default", "arch=slm"))) static int f () { return 0; }
+__attribute__ ((alias ("f"))) __typeof (f) g;