summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChris Lattner <sabre@nondot.org>2009-02-02 07:24:28 +0000
committerChris Lattner <sabre@nondot.org>2009-02-02 07:24:28 +0000
commit1f386b8ec8de5d24f2eaaa676db0737fe298bccf (patch)
tree6160a18e13e21d309f7591f4372915a355e43f7e
parent1aafe4ceceeeb8ff57fc43f40f93ab3591a98e70 (diff)
downloadbcm5719-llvm-1f386b8ec8de5d24f2eaaa676db0737fe298bccf.tar.gz
bcm5719-llvm-1f386b8ec8de5d24f2eaaa676db0737fe298bccf.zip
Fix PR3372
llvm-svn: 63501
-rw-r--r--llvm/lib/AsmParser/LLParser.cpp5
-rw-r--r--llvm/test/Assembler/2009-02-01-UnnamedForwardRef.ll6
2 files changed, 9 insertions, 2 deletions
diff --git a/llvm/lib/AsmParser/LLParser.cpp b/llvm/lib/AsmParser/LLParser.cpp
index 401dc39ca53..943f1d00256 100644
--- a/llvm/lib/AsmParser/LLParser.cpp
+++ b/llvm/lib/AsmParser/LLParser.cpp
@@ -471,8 +471,9 @@ bool LLParser::ParseGlobal(const std::string &Name, LocTy NameLoc,
GlobalVariable *GV = 0;
// See if the global was forward referenced, if so, use the global.
- if (!Name.empty() && (GV = M->getGlobalVariable(Name, true))) {
- if (!ForwardRefVals.erase(Name))
+ if (!Name.empty()) {
+ if ((GV = M->getGlobalVariable(Name, true)) &&
+ !ForwardRefVals.erase(Name))
return Error(NameLoc, "redefinition of global '@" + Name + "'");
} else {
std::map<unsigned, std::pair<GlobalValue*, LocTy> >::iterator
diff --git a/llvm/test/Assembler/2009-02-01-UnnamedForwardRef.ll b/llvm/test/Assembler/2009-02-01-UnnamedForwardRef.ll
new file mode 100644
index 00000000000..9c6e20d7335
--- /dev/null
+++ b/llvm/test/Assembler/2009-02-01-UnnamedForwardRef.ll
@@ -0,0 +1,6 @@
+; RUN: llvm-as < %s | llvm-dis
+; PR3372
+
+@X = global i32* @0
+global i32 4
+
OpenPOWER on IntegriCloud