forked from OSchip/llvm-project
Produce STV_DEFAULT for symbols in shared libraries.
The spec says: If a symbol definition with STV_PROTECTED visibility from a shared object is taken as resolving a reference from an executable or another shared object, the SHN_UNDEF symbol table entry created has STV_DEFAULT visibility. llvm-svn: 265792
This commit is contained in:
parent
badd397aa7
commit
b729b2131d
|
@ -1458,6 +1458,12 @@ void SymbolTableSection<ELFT>::writeLocalSymbols(uint8_t *&Buf) {
|
|||
}
|
||||
}
|
||||
|
||||
static uint8_t getSymbolVisibility(SymbolBody *Body) {
|
||||
if (Body->isShared())
|
||||
return STV_DEFAULT;
|
||||
return Body->getVisibility();
|
||||
}
|
||||
|
||||
template <class ELFT>
|
||||
void SymbolTableSection<ELFT>::writeGlobalSymbols(uint8_t *Buf) {
|
||||
// Write the internal symbol table contents to the output symbol table
|
||||
|
@ -1473,7 +1479,7 @@ void SymbolTableSection<ELFT>::writeGlobalSymbols(uint8_t *Buf) {
|
|||
ESym->setBindingAndType(getSymbolBinding(Body), Type);
|
||||
ESym->st_size = Size;
|
||||
ESym->st_name = StrOff;
|
||||
ESym->setVisibility(Body->getVisibility());
|
||||
ESym->setVisibility(getSymbolVisibility(Body));
|
||||
ESym->st_value = Body->getVA<ELFT>();
|
||||
|
||||
if (const OutputSectionBase<ELFT> *OutSec = getOutputSection(Body))
|
||||
|
|
|
@ -0,0 +1,3 @@
|
|||
.global foo
|
||||
.protected foo
|
||||
foo:
|
|
@ -0,0 +1,18 @@
|
|||
// REQUIRES: x86
|
||||
// RUN: llvm-mc -filetype=obj -triple=x86_64-pc-linux %s -o %t.o
|
||||
// RUN: llvm-mc -filetype=obj -triple=x86_64-pc-linux %p/Inputs/protected-shared.s -o %t2.o
|
||||
// RUN: ld.lld -shared %t2.o -o %t2.so
|
||||
// RUN: ld.lld %t.o %t2.so -o %t
|
||||
// RUN: llvm-readobj -t %t | FileCheck %s
|
||||
|
||||
.global _start
|
||||
_start:
|
||||
.quad foo
|
||||
|
||||
// CHECK: Name: foo
|
||||
// CHECK-NEXT: Value: 0x0
|
||||
// CHECK-NEXT: Size: 0
|
||||
// CHECK-NEXT: Binding: Global
|
||||
// CHECK-NEXT: Type: None
|
||||
// CHECK-NEXT: Other: 0
|
||||
// CHECK-NEXT: Section: Undefined
|
Loading…
Reference in New Issue