Tested and committed as obvious.

---

I missed a null check for asm_node when introducing toplevel_node.

        PR lto/122603

gcc/lto/ChangeLog:

        * lto-partition.cc (split_partition_into_nodes): Null check for
          possible asm_node.

gcc/testsuite/ChangeLog:

        * gcc.dg/lto/pr122603_0.c: New test.
---
 gcc/lto/lto-partition.cc              | 4 ++--
 gcc/testsuite/gcc.dg/lto/pr122603_0.c | 6 ++++++
 2 files changed, 8 insertions(+), 2 deletions(-)
 create mode 100644 gcc/testsuite/gcc.dg/lto/pr122603_0.c

diff --git a/gcc/lto/lto-partition.cc b/gcc/lto/lto-partition.cc
index baeafc7fafd..8c6ec6f8338 100644
--- a/gcc/lto/lto-partition.cc
+++ b/gcc/lto/lto-partition.cc
@@ -548,8 +548,8 @@ split_partition_into_nodes (ltrans_partition part)
       toplevel_node *node = lsei_node (lsei);
 
       symtab_node *snode = dyn_cast <symtab_node*> (node);
-      if (snode->get_partitioning_class () != SYMBOL_PARTITION
-         || symbol_partitioned_p (snode))
+      if (snode && (snode->get_partitioning_class () != SYMBOL_PARTITION
+                   || symbol_partitioned_p (snode)))
        continue;
 
       ltrans_partition new_part = new_partition_no_push (part->name);
diff --git a/gcc/testsuite/gcc.dg/lto/pr122603_0.c 
b/gcc/testsuite/gcc.dg/lto/pr122603_0.c
new file mode 100644
index 00000000000..127aeb70316
--- /dev/null
+++ b/gcc/testsuite/gcc.dg/lto/pr122603_0.c
@@ -0,0 +1,6 @@
+/* PR lto/122603 */
+/* { dg-lto-do link } */
+/* { dg-lto-options { "-O0 -flto -flto-partition=cache 
--param=lto-min-partition=1" } } */
+
+int main() {}
+asm("");
-- 
2.51.0


Reply via email to