Reverted r275257 "[ELF] - Implement extern "c++" version script tag"
It broke build bots: http://lab.llvm.org:8011/builders/llvm-clang-lld-x86_64-scei-ps4-windows10pro-fast/builds/8204 http://lab.llvm.org:8011/builders/lld-x86_64-freebsd/builds/19432 llvm-svn: 275258
This commit is contained in:
parent
e05103ea11
commit
dd64bb38bd
|
@ -35,18 +35,13 @@ enum class BuildIdKind { None, Fnv1, Md5, Sha1, Hexstring };
|
|||
|
||||
enum class UnresolvedPolicy { NoUndef, Error, Warn, Ignore };
|
||||
|
||||
struct SymbolVersion {
|
||||
llvm::StringRef Name;
|
||||
bool IsExternCpp;
|
||||
};
|
||||
|
||||
// This struct contains symbols version definition that
|
||||
// can be found in version script if it is used for link.
|
||||
struct Version {
|
||||
Version(llvm::StringRef Name, size_t Id) : Name(Name), Id(Id) {}
|
||||
llvm::StringRef Name;
|
||||
size_t Id;
|
||||
std::vector<SymbolVersion> Globals;
|
||||
std::vector<llvm::StringRef> Globals;
|
||||
size_t NameOff; // Offset in string table.
|
||||
};
|
||||
|
||||
|
@ -73,7 +68,7 @@ struct Configuration {
|
|||
std::vector<llvm::StringRef> DynamicList;
|
||||
std::vector<llvm::StringRef> SearchPaths;
|
||||
std::vector<llvm::StringRef> Undefined;
|
||||
std::vector<SymbolVersion> VersionScriptGlobals;
|
||||
std::vector<llvm::StringRef> VersionScriptGlobals;
|
||||
std::vector<uint8_t> BuildIdVector;
|
||||
bool AllowMultipleDefinition;
|
||||
bool AsNeeded = false;
|
||||
|
|
|
@ -77,7 +77,6 @@ public:
|
|||
void run();
|
||||
|
||||
private:
|
||||
void parseExtern(std::vector<SymbolVersion> *Globals);
|
||||
void parseVersion(StringRef Version);
|
||||
void parseLocal();
|
||||
void parseVersionSymbols(StringRef Version);
|
||||
|
@ -121,38 +120,21 @@ void VersionScriptParser::parseLocal() {
|
|||
Config->VersionScriptGlobalByDefault = false;
|
||||
}
|
||||
|
||||
void VersionScriptParser::parseExtern(std::vector<SymbolVersion> *Globals) {
|
||||
expect("extern");
|
||||
expect("C++");
|
||||
expect("{");
|
||||
|
||||
for (;;) {
|
||||
if (peek() == "}" || Error)
|
||||
break;
|
||||
Globals->push_back({next(), true});
|
||||
expect(";");
|
||||
}
|
||||
|
||||
expect("}");
|
||||
expect(";");
|
||||
}
|
||||
|
||||
void VersionScriptParser::parseVersionSymbols(StringRef Version) {
|
||||
std::vector<SymbolVersion> *Globals;
|
||||
std::vector<StringRef> *Globals;
|
||||
if (Version.empty())
|
||||
Globals = &Config->VersionScriptGlobals;
|
||||
else
|
||||
Globals = &Config->SymbolVersions.back().Globals;
|
||||
|
||||
for (;;) {
|
||||
if (peek() == "extern")
|
||||
parseExtern(Globals);
|
||||
|
||||
StringRef Cur = peek();
|
||||
if (Cur == "extern")
|
||||
setError("extern keyword is not supported");
|
||||
if (Cur == "}" || Cur == "local:" || Error)
|
||||
return;
|
||||
next();
|
||||
Globals->push_back({Cur, false});
|
||||
Globals->push_back(Cur);
|
||||
expect(";");
|
||||
}
|
||||
}
|
||||
|
|
|
@ -567,37 +567,6 @@ static bool hasWildcard(StringRef S) {
|
|||
return S.find_first_of("?*") != StringRef::npos;
|
||||
}
|
||||
|
||||
static void setVersionId(SymbolBody *Body, StringRef VersionName,
|
||||
StringRef Name, uint16_t Version) {
|
||||
if (!Body || Body->isUndefined()) {
|
||||
if (Config->NoUndefinedVersion)
|
||||
error("version script assignment of " + VersionName + " to symbol " +
|
||||
Name + " failed: symbol not defined");
|
||||
return;
|
||||
}
|
||||
|
||||
Symbol *Sym = Body->symbol();
|
||||
if (Sym->VersionId != VER_NDX_GLOBAL && Sym->VersionId != VER_NDX_LOCAL)
|
||||
warning("duplicate symbol " + Name + " in version script");
|
||||
Sym->VersionId = Version;
|
||||
}
|
||||
|
||||
template <class ELFT>
|
||||
std::map<std::string, SymbolBody *> SymbolTable<ELFT>::getDemangledSyms() {
|
||||
std::map<std::string, SymbolBody *> Result;
|
||||
for (std::pair<SymName, unsigned> Sym : Symtab)
|
||||
Result[demangle(Sym.first.Val)] = SymVector[Sym.second]->body();
|
||||
return Result;
|
||||
}
|
||||
|
||||
static bool hasExternCpp() {
|
||||
for (Version& V : Config->SymbolVersions)
|
||||
for (SymbolVersion Sym : V.Globals)
|
||||
if (Sym.IsExternCpp)
|
||||
return true;
|
||||
return false;
|
||||
}
|
||||
|
||||
// This function processes the --version-script option by marking all global
|
||||
// symbols with the VersionScriptGlobal flag, which acts as a filter on the
|
||||
// dynamic symbol table.
|
||||
|
@ -605,8 +574,8 @@ template <class ELFT> void SymbolTable<ELFT>::scanVersionScript() {
|
|||
// If version script does not contain versions declarations,
|
||||
// we just should mark global symbols.
|
||||
if (!Config->VersionScriptGlobals.empty()) {
|
||||
for (SymbolVersion &Sym : Config->VersionScriptGlobals)
|
||||
if (SymbolBody *B = find(Sym.Name))
|
||||
for (StringRef S : Config->VersionScriptGlobals)
|
||||
if (SymbolBody *B = find(S))
|
||||
B->symbol()->VersionId = VER_NDX_GLOBAL;
|
||||
return;
|
||||
}
|
||||
|
@ -617,35 +586,38 @@ template <class ELFT> void SymbolTable<ELFT>::scanVersionScript() {
|
|||
// If we have symbols version declarations, we should
|
||||
// assign version references for each symbol.
|
||||
// Current rules are:
|
||||
// * If there is an exact match for the mangled name or we have extern C++
|
||||
// exact match, then we use it.
|
||||
// * If there is an exact match for the mangled name, we use it.
|
||||
// * Otherwise, we look through the wildcard patterns. We look through the
|
||||
// version tags in reverse order. We use the first match we find (the last
|
||||
// matching version tag in the file).
|
||||
|
||||
// Handle exact matches and build a map of demangled externs for
|
||||
// quick search during next step.
|
||||
std::map<std::string, SymbolBody *> Demangled;
|
||||
if (hasExternCpp())
|
||||
Demangled = getDemangledSyms();
|
||||
|
||||
for (Version &V : Config->SymbolVersions) {
|
||||
for (SymbolVersion Sym : V.Globals) {
|
||||
if (hasWildcard(Sym.Name))
|
||||
for (size_t I = 0, E = Config->SymbolVersions.size(); I < E; ++I) {
|
||||
Version &V = Config->SymbolVersions[I];
|
||||
for (StringRef Name : V.Globals) {
|
||||
if (hasWildcard(Name))
|
||||
continue;
|
||||
SymbolBody *B = Sym.IsExternCpp ? Demangled[Sym.Name] : find(Sym.Name);
|
||||
setVersionId(B, V.Name, Sym.Name, V.Id);
|
||||
|
||||
SymbolBody *B = find(Name);
|
||||
if (!B || B->isUndefined()) {
|
||||
if (Config->NoUndefinedVersion)
|
||||
error("version script assignment of " + V.Name + " to symbol " +
|
||||
Name + " failed: symbol not defined");
|
||||
continue;
|
||||
}
|
||||
|
||||
if (B->symbol()->VersionId != VER_NDX_GLOBAL &&
|
||||
B->symbol()->VersionId != VER_NDX_LOCAL)
|
||||
warning("duplicate symbol " + Name + " in version script");
|
||||
B->symbol()->VersionId = V.Id;
|
||||
}
|
||||
}
|
||||
|
||||
// Handle wildcards.
|
||||
for (size_t I = Config->SymbolVersions.size() - 1; I != (size_t)-1; --I) {
|
||||
Version &V = Config->SymbolVersions[I];
|
||||
for (SymbolVersion Sym : V.Globals) {
|
||||
if (!hasWildcard(Sym.Name))
|
||||
for (StringRef Name : V.Globals) {
|
||||
if (!hasWildcard(Name))
|
||||
continue;
|
||||
|
||||
for (SymbolBody *B : findAll(Sym.Name))
|
||||
for (SymbolBody *B : findAll(Name))
|
||||
if (B->symbol()->VersionId == VER_NDX_GLOBAL ||
|
||||
B->symbol()->VersionId == VER_NDX_LOCAL)
|
||||
B->symbol()->VersionId = V.Id;
|
||||
|
|
|
@ -97,8 +97,6 @@ private:
|
|||
std::string conflictMsg(SymbolBody *Existing, InputFile *NewFile);
|
||||
void reportDuplicate(SymbolBody *Existing, InputFile *NewFile);
|
||||
|
||||
std::map<std::string, SymbolBody *> getDemangledSyms();
|
||||
|
||||
// The order the global symbols are in is not defined. We can use an arbitrary
|
||||
// order, but it has to be reproducible. That is true even when cross linking.
|
||||
// The default hashing of StringRef produces different results on 32 and 64
|
||||
|
|
|
@ -8,3 +8,8 @@
|
|||
// RUN: not ld.lld --version-script %terr1.script -shared %t.o -o %t.so 2>&1 | \
|
||||
// RUN: FileCheck -check-prefix=ERR1 %s
|
||||
// ERR1: unclosed quote
|
||||
|
||||
// RUN: echo "VERSION { extern "C++" {}; }; " > %terr2.script
|
||||
// RUN: not ld.lld --version-script %terr2.script -shared %t.o -o %t.so 2>&1 | \
|
||||
// RUN: FileCheck -check-prefix=ERR2 %s
|
||||
// ERR2: extern keyword is not supported
|
||||
|
|
|
@ -1,98 +0,0 @@
|
|||
# REQUIRES: x86
|
||||
# XFAIL: win32
|
||||
|
||||
# RUN: llvm-mc -filetype=obj -triple=x86_64-pc-linux %s -o %t.o
|
||||
# RUN: echo "LIBSAMPLE_1.0 { \
|
||||
# RUN: global: \
|
||||
# RUN: extern "C++" { \
|
||||
# RUN: \"foo()\"; \
|
||||
# RUN: \"zed()\"; \
|
||||
# RUN: }; \
|
||||
# RUN: }; \
|
||||
# RUN: LIBSAMPLE_2.0 { \
|
||||
# RUN: global: \
|
||||
# RUN: extern "C++" { \
|
||||
# RUN: \"bar()\"; \
|
||||
# RUN: }; \
|
||||
# RUN: }; " > %t.script
|
||||
# RUN: ld.lld --version-script %t.script -shared %t.o -o %t.so
|
||||
# RUN: llvm-readobj -V -dyn-symbols %t.so | FileCheck --check-prefix=DSO %s
|
||||
|
||||
# DSO: DynamicSymbols [
|
||||
# DSO-NEXT: Symbol {
|
||||
# DSO-NEXT: Name: @
|
||||
# DSO-NEXT: Value: 0x0
|
||||
# DSO-NEXT: Size: 0
|
||||
# DSO-NEXT: Binding: Local
|
||||
# DSO-NEXT: Type: None
|
||||
# DSO-NEXT: Other: 0
|
||||
# DSO-NEXT: Section: Undefined
|
||||
# DSO-NEXT: }
|
||||
# DSO-NEXT: Symbol {
|
||||
# DSO-NEXT: Name: _Z3barv@@LIBSAMPLE_2.0
|
||||
# DSO-NEXT: Value: 0x1001
|
||||
# DSO-NEXT: Size: 0
|
||||
# DSO-NEXT: Binding: Global
|
||||
# DSO-NEXT: Type: Function
|
||||
# DSO-NEXT: Other: 0
|
||||
# DSO-NEXT: Section: .text
|
||||
# DSO-NEXT: }
|
||||
# DSO-NEXT: Symbol {
|
||||
# DSO-NEXT: Name: _Z3foov@@LIBSAMPLE_1.0
|
||||
# DSO-NEXT: Value: 0x1000
|
||||
# DSO-NEXT: Size: 0
|
||||
# DSO-NEXT: Binding: Global
|
||||
# DSO-NEXT: Type: Function
|
||||
# DSO-NEXT: Other: 0
|
||||
# DSO-NEXT: Section: .text
|
||||
# DSO-NEXT: }
|
||||
# DSO-NEXT: Symbol {
|
||||
# DSO-NEXT: Name: _Z3zedv@@LIBSAMPLE_1.0
|
||||
# DSO-NEXT: Value: 0x1002
|
||||
# DSO-NEXT: Size: 0
|
||||
# DSO-NEXT: Binding: Global (0x1)
|
||||
# DSO-NEXT: Type: Function (0x2)
|
||||
# DSO-NEXT: Other: 0
|
||||
# DSO-NEXT: Section: .text (0x6)
|
||||
# DSO-NEXT: }
|
||||
# DSO-NEXT: ]
|
||||
# DSO-NEXT: Version symbols {
|
||||
# DSO-NEXT: Section Name: .gnu.version
|
||||
# DSO-NEXT: Address: 0x228
|
||||
# DSO-NEXT: Offset: 0x228
|
||||
# DSO-NEXT: Link: 1
|
||||
# DSO-NEXT: Symbols [
|
||||
# DSO-NEXT: Symbol {
|
||||
# DSO-NEXT: Version: 0
|
||||
# DSO-NEXT: Name: @
|
||||
# DSO-NEXT: }
|
||||
# DSO-NEXT: Symbol {
|
||||
# DSO-NEXT: Version: 3
|
||||
# DSO-NEXT: Name: _Z3barv@@LIBSAMPLE_2.0
|
||||
# DSO-NEXT: }
|
||||
# DSO-NEXT: Symbol {
|
||||
# DSO-NEXT: Version: 2
|
||||
# DSO-NEXT: Name: _Z3foov@@LIBSAMPLE_1.0
|
||||
# DSO-NEXT: }
|
||||
# DSO-NEXT: Symbol {
|
||||
# DSO-NEXT: Version: 2
|
||||
# DSO-NEXT: Name: _Z3zedv@@LIBSAMPLE_1.0
|
||||
# DSO-NEXT: }
|
||||
# DSO-NEXT: ]
|
||||
# DSO-NEXT: }
|
||||
|
||||
.text
|
||||
.globl _Z3foov
|
||||
.type _Z3foov,@function
|
||||
_Z3foov:
|
||||
retq
|
||||
|
||||
.globl _Z3barv
|
||||
.type _Z3barv,@function
|
||||
_Z3barv:
|
||||
retq
|
||||
|
||||
.globl _Z3zedv
|
||||
.type _Z3zedv,@function
|
||||
_Z3zedv:
|
||||
retq
|
Loading…
Reference in New Issue