ipa: Adjust cgraph verifier to materialization on demand (PR 98222)
authorMartin Jambor <mjambor@suse.cz>
Sun, 17 Jan 2021 21:31:09 +0000 (22:31 +0100)
committerMartin Jambor <mjambor@suse.cz>
Sun, 17 Jan 2021 21:32:11 +0000 (22:32 +0100)
after switching to materialization of clones on demand, the verifier
can happen to see edges leading to a clone of a materialized clone.
This means its clone_of is NULL and former_clone_of needs to be
checked in order to verify that the callee is a clone of the original
decl, which it did not do and reported edges to pointing to a wrong
place.

Fixed with the following patch, which has been pre-approved by Honza.
Bootstrapped and tested on x86_64-linux, pushed to master.

Martin

gcc/ChangeLog:

2021-01-15  Martin Jambor  <mjambor@suse.cz>

PR ipa/98222
* cgraph.c (clone_of_p): Check also former_clone_of as we climb
the clone tree.

gcc/testsuite/ChangeLog:

2021-01-15  Martin Jambor  <mjambor@suse.cz>

PR ipa/98222
* gcc.dg/ipa/pr98222.c: New test.

gcc/cgraph.c
gcc/testsuite/gcc.dg/ipa/pr98222.c [new file with mode: 0644]

index d0d785b3438d20fb7e75eb916b6827458f929499..db038306e1999c97a115a388eb10013008c3eedc 100644 (file)
@@ -3081,7 +3081,9 @@ clone_of_p (cgraph_node *node, cgraph_node *node2)
 
   if (!node->thunk && !node->former_thunk_p ())
     {
-      while (node2 && node->decl != node2->decl)
+      while (node2
+            && node->decl != node2->decl
+            && node->decl != node2->former_clone_of)
        node2 = node2->clone_of;
       return node2 != NULL;
     }
diff --git a/gcc/testsuite/gcc.dg/ipa/pr98222.c b/gcc/testsuite/gcc.dg/ipa/pr98222.c
new file mode 100644 (file)
index 0000000..92e857c
--- /dev/null
@@ -0,0 +1,19 @@
+/* { dg-do compile } */
+/* { dg-options "-O3"  } */
+
+int a, b, *c;
+
+int f (int j, int k) {
+  b = k / j;
+  if (a)
+    f(0, 0);
+  *c = f(b & a, 0);
+  return 0;
+}
+
+int main() {
+  if (a)
+    while (1)
+      f(0, 0);
+  return 0;
+}