As mentioned in the PR, since
4656461585bfd0b9 implicit_section
was not set to false when set_section was called with the argument
equal to NULL.
gcc/ChangeLog:
PR ipa/98057
* symtab.c (symtab_node::set_section_for_node): Drop
implicit_section if x_section is NULL.
gcc/testsuite/ChangeLog:
PR ipa/98057
* g++.dg/ipa/pr98057.C: New test.
if (other.x_section)
x_section = retain_section_hash_entry (other.x_section);
else
- x_section = NULL;
+ {
+ x_section = NULL;
+ implicit_section = false;
+ }
}
/* Workers for set_section. */
--- /dev/null
+/* PR ipa/98057 */
+/* { dg-do compile } */
+/* { dg-options "-O3 -ffunction-sections" } */
+
+class JITSymbolResolver {
+ virtual void anchor();
+};
+class MemoryManager {
+ virtual void anchor();
+};
+class MCJITMemoryManager : MemoryManager {
+ void anchor();
+};
+class RTDyldMemoryManager : MCJITMemoryManager, JITSymbolResolver {
+ void anchor();
+};
+void RTDyldMemoryManager::anchor() {}
+void MCJITMemoryManager::anchor() {}