[lld] 0a7e56f - [lld-macho] Mark weak symbols in symbol table
Jez Ng via llvm-commits
llvm-commits at lists.llvm.org
Sun Sep 20 20:43:50 PDT 2020
Author: Jez Ng
Date: 2020-09-20T20:43:14-07:00
New Revision: 0a7e56f74c2adde9a4bc2c1163e7ed3aff984584
URL: https://github.com/llvm/llvm-project/commit/0a7e56f74c2adde9a4bc2c1163e7ed3aff984584
DIFF: https://github.com/llvm/llvm-project/commit/0a7e56f74c2adde9a4bc2c1163e7ed3aff984584.diff
LOG: [lld-macho] Mark weak symbols in symbol table
Reviewed By: #lld-macho, smeenai
Differential Revision: https://reviews.llvm.org/D86908
Added:
Modified:
lld/MachO/SyntheticSections.cpp
lld/test/MachO/symtab.s
Removed:
################################################################################
diff --git a/lld/MachO/SyntheticSections.cpp b/lld/MachO/SyntheticSections.cpp
index 66dcbdecea29..0106426f5ddc 100644
--- a/lld/MachO/SyntheticSections.cpp
+++ b/lld/MachO/SyntheticSections.cpp
@@ -473,10 +473,11 @@ void SymtabSection::writeTo(uint8_t *buf) const {
for (const SymtabEntry &entry : symbols) {
nList->n_strx = entry.strx;
// TODO support other symbol types
- // TODO populate n_desc
+ // TODO populate n_desc with more flags
if (auto *defined = dyn_cast<Defined>(entry.sym)) {
nList->n_type = MachO::N_EXT | MachO::N_SECT;
nList->n_sect = defined->isec->parent->index;
+ nList->n_desc |= defined->isWeakDef() ? MachO::N_WEAK_DEF : 0;
// For the N_SECT symbol type, n_value is the address of the symbol
nList->n_value = defined->value + defined->isec->getVA();
}
diff --git a/lld/test/MachO/symtab.s b/lld/test/MachO/symtab.s
index 44a016912bd6..1efa7a2e1dd4 100644
--- a/lld/test/MachO/symtab.s
+++ b/lld/test/MachO/symtab.s
@@ -20,7 +20,8 @@
# CHECK-NEXT: Type: Section (0xE)
# CHECK-NEXT: Section: __text (0x1)
# CHECK-NEXT: RefType:
-# CHECK-NEXT: Flags [ (0x0)
+# CHECK-NEXT: Flags [ (0x80)
+# CHECK-NEXT: WeakDef (0x80)
# CHECK-NEXT: ]
# CHECK-NEXT: Value:
# CHECK-NEXT: }
@@ -42,6 +43,7 @@ foo:
.asciz "Hello world!\n"
.text
+.weak_definition bar
.global bar
.global _main
More information about the llvm-commits
mailing list