diff options
author | Owen Anderson <resistor@mac.com> | 2006-10-18 02:21:12 +0000 |
---|---|---|
committer | Owen Anderson <resistor@mac.com> | 2006-10-18 02:21:12 +0000 |
commit | cf7ff2b4c8c18d67aced9d7ba84482819b38a84b (patch) | |
tree | 20ac08acae42a4e16ae1b95c36f6a205fd228817 | |
parent | 9935dd919882bec89f185d49655eba9db644e49e (diff) |
Add support for the new "target data" information in .ll files. This provides
a better encoding of the targets data layout, rather than trying to guess it
from the endianness and pointersize like before.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@31030 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | include/llvm/Module.h | 8 | ||||
-rw-r--r-- | lib/AsmParser/Lexer.l | 1 | ||||
-rw-r--r-- | lib/AsmParser/llvmAsmParser.y | 6 | ||||
-rw-r--r-- | lib/VMCore/AsmWriter.cpp | 3 |
4 files changed, 18 insertions, 0 deletions
diff --git a/include/llvm/Module.h b/include/llvm/Module.h index 8e8f554abe..195c73d2f4 100644 --- a/include/llvm/Module.h +++ b/include/llvm/Module.h @@ -116,6 +116,11 @@ public: /// @returns the module identifier as a string const std::string &getModuleIdentifier() const { return ModuleID; } + /// Get the data layout string for the module's target platform. This encodes + /// the type sizes and alignments expected by this module. + /// @returns the data layout as a string + std::string getDataLayout() const { return DataLayout; } + /// Get the target triple which is a string describing the target host. /// @returns a string containing the target triple. const std::string &getTargetTriple() const { return TargetTriple; } @@ -139,6 +144,9 @@ public: /// Set the module identifier. void setModuleIdentifier(const std::string &ID) { ModuleID = ID; } + /// Set the data layout + void setDataLayout(std::string DL) { DataLayout = DL; } + /// Set the target triple. void setTargetTriple(const std::string &T) { TargetTriple = T; } diff --git a/lib/AsmParser/Lexer.l b/lib/AsmParser/Lexer.l index 635318c40c..af61a679fb 100644 --- a/lib/AsmParser/Lexer.l +++ b/lib/AsmParser/Lexer.l @@ -210,6 +210,7 @@ triple { return TRIPLE; } deplibs { return DEPLIBS; } endian { return ENDIAN; } pointersize { return POINTERSIZE; } +data { return DATA; } little { return LITTLE; } big { return BIG; } volatile { return VOLATILE; } diff --git a/lib/AsmParser/llvmAsmParser.y b/lib/AsmParser/llvmAsmParser.y index e57ca4ca5d..2842f27f1b 100644 --- a/lib/AsmParser/llvmAsmParser.y +++ b/lib/AsmParser/llvmAsmParser.y @@ -1068,6 +1068,7 @@ Module *llvm::RunVMAsmParser(const char * AsmString, Module * M) { %token DEPLIBS CALL TAIL ASM_TOK MODULE SIDEEFFECT %token CC_TOK CCC_TOK CSRETCC_TOK FASTCC_TOK COLDCC_TOK %token X86_STDCALLCC_TOK X86_FASTCALLCC_TOK +%token DATA %type <UIntVal> OptCallingConv // Basic Block Terminating Operators @@ -1873,6 +1874,11 @@ TargetDefinition : ENDIAN '=' BigOrLittle { free($3); CHECK_FOR_ERROR }; + | DATA '=' STRINGCONSTANT { + CurModule.CurrentModule->setDataLayout($3); + free($3); + CHECK_FOR_ERROR + }; LibrariesDefinition : '[' LibList ']'; diff --git a/lib/VMCore/AsmWriter.cpp b/lib/VMCore/AsmWriter.cpp index 6b08266c31..aedb2c4040 100644 --- a/lib/VMCore/AsmWriter.cpp +++ b/lib/VMCore/AsmWriter.cpp @@ -781,6 +781,9 @@ void AssemblyWriter::printModule(const Module *M) { M->getModuleIdentifier().find('\n') == std::string::npos) Out << "; ModuleID = '" << M->getModuleIdentifier() << "'\n"; + if (!M->getDataLayout().empty()) + Out << "target data = \"" << M->getDataLayout() << "\"\n"; + switch (M->getEndianness()) { case Module::LittleEndian: Out << "target endian = little\n"; break; case Module::BigEndian: Out << "target endian = big\n"; break; |