aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorIain Sandoe <iain@sandoe.co.uk>2022-05-02 19:42:49 +0100
committerIain Sandoe <iain@sandoe.co.uk>2022-05-03 19:38:34 +0100
commitecd5727c0a662a8fea6b5f8eac6f3f15bf5ef851 (patch)
tree511ab0f555e15f7b331bfd02a307fee3c67e6860
parent25389f3de489c25a6983db96428a6bf06aedc829 (diff)
downloadgcc-ecd5727c0a662a8fea6b5f8eac6f3f15bf5ef851.zip
gcc-ecd5727c0a662a8fea6b5f8eac6f3f15bf5ef851.tar.gz
gcc-ecd5727c0a662a8fea6b5f8eac6f3f15bf5ef851.tar.bz2
Objective-C, NeXT: Adjust symbol marking to match host tools.
Current host tools mark some additional symbols as 'no dead strip' and also expose one additional group to the linker. This does not affect older Darwin versions or x86_64, but omitting these changes results in link errors for aarch64. Signed-off-by: Iain Sandoe <iain@sandoe.co.uk> gcc/ChangeLog: * config/darwin.cc (darwin_label_is_anonymous_local_objc_name): Make protocol class methods linker-visible. gcc/objc/ChangeLog: * objc-next-runtime-abi-02.cc (next_runtime_abi_02_protocol_decl): Do not dead-strip the runtime meta-data symbols. (build_v2_classrefs_table): Likewise. (build_v2_protocol_list_address_table): Likewise.
-rw-r--r--gcc/config/darwin.cc2
-rw-r--r--gcc/objc/objc-next-runtime-abi-02.cc6
2 files changed, 6 insertions, 2 deletions
diff --git a/gcc/config/darwin.cc b/gcc/config/darwin.cc
index f065a13..1b3de33 100644
--- a/gcc/config/darwin.cc
+++ b/gcc/config/darwin.cc
@@ -1936,6 +1936,8 @@ darwin_label_is_anonymous_local_objc_name (const char *name)
}
else if (startswith ((const char *)p, "ClassMethods"))
return false;
+ else if (startswith ((const char *)p, "ClassProtocols"))
+ return false;
else if (startswith ((const char *)p, "Instance"))
{
if (p[8] == 'I' || p[8] == 'M')
diff --git a/gcc/objc/objc-next-runtime-abi-02.cc b/gcc/objc/objc-next-runtime-abi-02.cc
index e50ca6e..9ea63b1 100644
--- a/gcc/objc/objc-next-runtime-abi-02.cc
+++ b/gcc/objc/objc-next-runtime-abi-02.cc
@@ -1033,6 +1033,7 @@ next_runtime_abi_02_protocol_decl (tree p)
else
decl = start_var_decl (objc_v2_protocol_template, buf);
OBJCMETA (decl, objc_meta, meta_protocol);
+ DECL_PRESERVE_P (decl) = 1;
return decl;
}
@@ -2115,8 +2116,8 @@ build_v2_classrefs_table (void)
expr = convert (objc_class_type, build_fold_addr_expr (expr));
}
/* The runtime wants this, even if it appears unused, so we must force the
- output.
- DECL_PRESERVE_P (decl) = 1; */
+ output. */
+ DECL_PRESERVE_P (decl) = 1;
finish_var_decl (decl, expr);
}
}
@@ -2318,6 +2319,7 @@ build_v2_protocol_list_address_table (void)
expr = convert (objc_protocol_type, build_fold_addr_expr (ref->refdecl));
OBJCMETA (decl, objc_meta, meta_label_protocollist);
finish_var_decl (decl, expr);
+ DECL_PRESERVE_P (decl) = 1;
}
/* TODO: delete the vec. */