summaryrefslogtreecommitdiffstats
path: root/llvm/lib/AsmParser/LLParser.cpp
diff options
context:
space:
mode:
authorRafael Espindola <rafael.espindola@gmail.com>2013-10-06 15:10:43 +0000
committerRafael Espindola <rafael.espindola@gmail.com>2013-10-06 15:10:43 +0000
commit78527050c28fcdb57c0d24a10b55ab43dc4e5412 (patch)
treee288583d75b747e3820f1c5ddf4e4d53e2a65ef1 /llvm/lib/AsmParser/LLParser.cpp
parent93c69ac8c342a353ef4b0b9709ecb129a9332095 (diff)
downloadbcm5719-llvm-78527050c28fcdb57c0d24a10b55ab43dc4e5412.tar.gz
bcm5719-llvm-78527050c28fcdb57c0d24a10b55ab43dc4e5412.zip
Add support for aliases with linkonce_odr.
This will be used to extend constructor aliases in clang. llvm-svn: 192066
Diffstat (limited to 'llvm/lib/AsmParser/LLParser.cpp')
-rw-r--r--llvm/lib/AsmParser/LLParser.cpp17
1 files changed, 8 insertions, 9 deletions
diff --git a/llvm/lib/AsmParser/LLParser.cpp b/llvm/lib/AsmParser/LLParser.cpp
index bdc79068946..d5c5db11de8 100644
--- a/llvm/lib/AsmParser/LLParser.cpp
+++ b/llvm/lib/AsmParser/LLParser.cpp
@@ -627,18 +627,17 @@ bool LLParser::ParseAlias(const std::string &Name, LocTy NameLoc,
unsigned Visibility) {
assert(Lex.getKind() == lltok::kw_alias);
Lex.Lex();
- unsigned Linkage;
LocTy LinkageLoc = Lex.getLoc();
- if (ParseOptionalLinkage(Linkage))
+ unsigned L;
+ if (ParseOptionalLinkage(L))
return true;
- if (Linkage != GlobalValue::ExternalLinkage &&
- Linkage != GlobalValue::WeakAnyLinkage &&
- Linkage != GlobalValue::WeakODRLinkage &&
- Linkage != GlobalValue::InternalLinkage &&
- Linkage != GlobalValue::PrivateLinkage &&
- Linkage != GlobalValue::LinkerPrivateLinkage &&
- Linkage != GlobalValue::LinkerPrivateWeakLinkage)
+ GlobalValue::LinkageTypes Linkage = (GlobalValue::LinkageTypes) L;
+
+ if(!GlobalValue::isExternalLinkage(Linkage) &&
+ !GlobalValue::isLocalLinkage(Linkage) &&
+ !GlobalValue::isWeakLinkage(Linkage) &&
+ !GlobalValue::isLinkOnceLinkage(Linkage))
return Error(LinkageLoc, "invalid linkage type for alias");
Constant *Aliasee;
OpenPOWER on IntegriCloud