mirror of
https://github.com/RPCSX/llvm.git
synced 2025-02-13 00:11:56 +00:00
[yaml2obj][ELF] Allow expressing undefined symbols.
Previously we unconditionally enforced that section references in symbols in the YAML had a name that was a section name present in the object, and linked the references to that section. Now, permit empty section names (already the default, if the `Section` key is not provided) to indicate SHN_UNDEF. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@184513 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
552d7cd31a
commit
326c193e0a
@ -26,6 +26,7 @@ Sections:
|
||||
Section: .text
|
||||
Value: 0x1
|
||||
Size: 2
|
||||
- Name: undefined_symbol
|
||||
|
||||
# CHECK: Symbols [
|
||||
# CHECK-NEXT: Symbol {
|
||||
@ -37,6 +38,9 @@ Sections:
|
||||
# CHECK: Binding: Global
|
||||
# CHECK-NEXT: Type: Function
|
||||
# CHECK: Section: .text
|
||||
# CHECK: Symbol {
|
||||
# CHECK: Name: undefined_symbol
|
||||
# CHECK: Section: (0x0)
|
||||
|
||||
# DISASSEMBLY: Disassembly of section .text:
|
||||
# DISASSEMBLY-NEXT: main:
|
||||
|
@ -184,13 +184,15 @@ addSymbols(const std::vector<ELFYAML::Symbol> &Symbols, ELFState<ELFT> &State,
|
||||
if (!Sym.Name.empty())
|
||||
Symbol.st_name = State.getStringTable().addString(Sym.Name);
|
||||
Symbol.setBindingAndType(SymbolBinding, Sym.Type);
|
||||
unsigned Index;
|
||||
if (State.getSN2I().lookupSection(Sym.Section, Index)) {
|
||||
errs() << "error: Unknown section referenced: '" << Sym.Section
|
||||
<< "' by YAML symbol " << Sym.Name << ".\n";
|
||||
exit(1);
|
||||
}
|
||||
Symbol.st_shndx = Index;
|
||||
if (!Sym.Section.empty()) {
|
||||
unsigned Index;
|
||||
if (State.getSN2I().lookupSection(Sym.Section, Index)) {
|
||||
errs() << "error: Unknown section referenced: '" << Sym.Section
|
||||
<< "' by YAML symbol " << Sym.Name << ".\n";
|
||||
exit(1);
|
||||
}
|
||||
Symbol.st_shndx = Index;
|
||||
} // else Symbol.st_shndex == SHN_UNDEF (== 0), since it was zero'd earlier.
|
||||
Symbol.st_value = Sym.Value;
|
||||
Symbol.st_size = Sym.Size;
|
||||
Syms.push_back(Symbol);
|
||||
|
Loading…
x
Reference in New Issue
Block a user