summaryrefslogtreecommitdiff
path: root/lib/AsmParser
diff options
context:
space:
mode:
authorLang Hames <lhames@gmail.com>2011-10-17 23:24:48 +0000
committerLang Hames <lhames@gmail.com>2011-10-17 23:24:48 +0000
commit5fa792e65a2da4f24c70772cecccb1e04d9a38e7 (patch)
treeeb68943544ae41ff99c310335f6f66ffd4c09a97 /lib/AsmParser
parentea46110f57b293844a314aec3b8092adf21ff63f (diff)
downloadllvm-5fa792e65a2da4f24c70772cecccb1e04d9a38e7.tar.gz
llvm-5fa792e65a2da4f24c70772cecccb1e04d9a38e7.tar.bz2
llvm-5fa792e65a2da4f24c70772cecccb1e04d9a38e7.tar.xz
Re-applying the target data layout verification patch from r142288, plus appropriate CMake dependencies.
Thanks to Raphael Espindola for tracking down the CMake issues. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@142306 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/AsmParser')
-rw-r--r--lib/AsmParser/CMakeLists.txt1
-rw-r--r--lib/AsmParser/LLParser.cpp6
2 files changed, 7 insertions, 0 deletions
diff --git a/lib/AsmParser/CMakeLists.txt b/lib/AsmParser/CMakeLists.txt
index 749601510b..5dcf48dff9 100644
--- a/lib/AsmParser/CMakeLists.txt
+++ b/lib/AsmParser/CMakeLists.txt
@@ -8,4 +8,5 @@ add_llvm_library(LLVMAsmParser
add_llvm_library_dependencies(LLVMAsmParser
LLVMCore
LLVMSupport
+ LLVMTarget
)
diff --git a/lib/AsmParser/LLParser.cpp b/lib/AsmParser/LLParser.cpp
index cafaab01af..eb6afd36c7 100644
--- a/lib/AsmParser/LLParser.cpp
+++ b/lib/AsmParser/LLParser.cpp
@@ -24,6 +24,7 @@
#include "llvm/ADT/SmallPtrSet.h"
#include "llvm/Support/ErrorHandling.h"
#include "llvm/Support/raw_ostream.h"
+#include "llvm/Target/TargetData.h"
using namespace llvm;
static std::string getTypeString(Type *T) {
@@ -260,9 +261,14 @@ bool LLParser::ParseTargetDefinition() {
return false;
case lltok::kw_datalayout:
Lex.Lex();
+ LocTy SpecifierLoc = Lex.getLoc();
if (ParseToken(lltok::equal, "expected '=' after target datalayout") ||
ParseStringConstant(Str))
return true;
+ std::string errMsg = TargetData::parseSpecifier(Str);
+ if (errMsg != "") {
+ return Error(SpecifierLoc, errMsg);
+ }
M->setDataLayout(Str);
return false;
}