diff options
author | Owen Anderson <resistor@mac.com> | 2006-05-12 05:49:47 +0000 |
---|---|---|
committer | Owen Anderson <resistor@mac.com> | 2006-05-12 05:49:47 +0000 |
commit | 8f60c56a06c4bc2027c5d1a7ee7ad626ae274604 (patch) | |
tree | c66ded8daf936cbe7715268a1bb4c79c4f1f7a03 /lib | |
parent | 21a57dc75172aa964c51d386b2cdd0ad3be7792f (diff) | |
download | external_llvm-8f60c56a06c4bc2027c5d1a7ee7ad626ae274604.zip external_llvm-8f60c56a06c4bc2027c5d1a7ee7ad626ae274604.tar.gz external_llvm-8f60c56a06c4bc2027c5d1a7ee7ad626ae274604.tar.bz2 |
Add a new constructor to TargetData that builds a TargetData from its
string representation.
This is part of PR 761.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@28234 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib')
-rw-r--r-- | lib/Target/TargetData.cpp | 65 |
1 files changed, 65 insertions, 0 deletions
diff --git a/lib/Target/TargetData.cpp b/lib/Target/TargetData.cpp index 63c5b61..be6ba60 100644 --- a/lib/Target/TargetData.cpp +++ b/lib/Target/TargetData.cpp @@ -22,7 +22,9 @@ #include "llvm/Constants.h" #include "llvm/Support/GetElementPtrTypeIterator.h" #include "llvm/Support/MathExtras.h" +#include "llvm/ADT/StringExtras.h" #include <algorithm> +#include <cstdlib> using namespace llvm; // Handle the Pass registration stuff necessary to use TargetData's. @@ -118,6 +120,69 @@ TargetData::TargetData(const std::string &TargetName, BoolAlignment = BoolAl; } +TargetData::TargetData(const std::string &TargetName, + const std::string &TargetDescription) { + std::string temp = TargetDescription; + + LittleEndian = false; + PointerSize = 8; + PointerAlignment = 8; + DoubleAlignment = 8; + FloatAlignment = 4; + LongAlignment = 8; + IntAlignment = 4; + ShortAlignment = 2; + ByteAlignment = 1; + BoolAlignment = 1; + + while (temp.length() > 0) { + std::string token = getToken(temp, "-"); + + switch(token[0]) { + case 'E': + LittleEndian = false; + break; + case 'e': + LittleEndian = true; + break; + case 'p': + PointerSize = atoi(getToken(token,":").c_str()) / 8; + PointerAlignment = atoi(getToken(token,":").c_str()) / 8; + break; + case 'd': + token = getToken(token,":"); //Ignore the size + DoubleAlignment = atoi(getToken(token,":").c_str()) / 8; + break; + case 'f': + token = getToken(token, ":"); //Ignore the size + FloatAlignment = atoi(getToken(token, ":").c_str()) / 8; + break; + case 'l': + token = getToken(token, ":"); //Ignore the size + LongAlignment = atoi(getToken(token, ":").c_str()) / 8; + break; + case 'i': + token = getToken(token, ":"); //Ignore the size + IntAlignment = atoi(getToken(token, ":").c_str()) / 8; + break; + case 's': + token = getToken(token, ":"); //Ignore the size + ShortAlignment = atoi(getToken(token, ":").c_str()) / 8; + break; + case 'b': + token = getToken(token, ":"); //Ignore the size + ByteAlignment = atoi(getToken(token, ":").c_str()) / 8; + break; + case 'B': + token = getToken(token, ":"); //Ignore the size + BoolAlignment = atoi(getToken(token, ":").c_str()) / 8; + break; + default: + break; + } + } +} + TargetData::TargetData(const std::string &ToolName, const Module *M) { LittleEndian = M->getEndianness() != Module::BigEndian; PointerSize = M->getPointerSize() != Module::Pointer64 ? 4 : 8; |