diff options
author | Rafael Espindola <rafael.espindola@gmail.com> | 2013-04-08 13:25:33 +0000 |
---|---|---|
committer | Rafael Espindola <rafael.espindola@gmail.com> | 2013-04-08 13:25:33 +0000 |
commit | d66c414619a7a3b4893c6730d2d9ebc859d1f23f (patch) | |
tree | 12aa39ea864cc2db4e721505f50f463774009fc3 /llvm/lib | |
parent | 5f11dd390abeaf77901dfa5f6d7863fe472f9110 (diff) | |
download | bcm5719-llvm-d66c414619a7a3b4893c6730d2d9ebc859d1f23f.tar.gz bcm5719-llvm-d66c414619a7a3b4893c6730d2d9ebc859d1f23f.zip |
Add all 4 MachO object types. Use the stored type to implement is64Bits().
llvm-svn: 179021
Diffstat (limited to 'llvm/lib')
-rw-r--r-- | llvm/lib/Object/MachOObjectFile.cpp | 13 |
1 files changed, 8 insertions, 5 deletions
diff --git a/llvm/lib/Object/MachOObjectFile.cpp b/llvm/lib/Object/MachOObjectFile.cpp index 4fe791c8265..24c916c3238 100644 --- a/llvm/lib/Object/MachOObjectFile.cpp +++ b/llvm/lib/Object/MachOObjectFile.cpp @@ -28,8 +28,9 @@ using namespace object; namespace llvm { namespace object { -MachOObjectFile::MachOObjectFile(MemoryBuffer *Object, error_code &ec) - : ObjectFile(Binary::ID_MachO, Object) { +MachOObjectFile::MachOObjectFile(MemoryBuffer *Object, bool Is64bits, + error_code &ec) + : ObjectFile(getMachOType(true, Is64bits), Object) { DataRefImpl DRI; moveToNextSection(DRI); uint32_t LoadCommandCount = getHeader()->NumLoadCommands; @@ -41,8 +42,8 @@ MachOObjectFile::MachOObjectFile(MemoryBuffer *Object, error_code &ec) } bool MachOObjectFile::is64Bit() const { - StringRef Magic = getData(0, 4); - return (Magic == "\xFE\xED\xFA\xCF") || (Magic == "\xCF\xFA\xED\xFE"); + unsigned int Type = getType(); + return Type == ID_MachO64L || Type == ID_MachO64B; } const MachOFormat::LoadCommand * @@ -88,8 +89,10 @@ StringRef MachOObjectFile::getData(size_t Offset, size_t Size) const { } ObjectFile *ObjectFile::createMachOObjectFile(MemoryBuffer *Buffer) { + StringRef Magic = Buffer->getBuffer().slice(0, 4); error_code ec; - ObjectFile *Ret = new MachOObjectFile(Buffer, ec); + bool Is64Bits = Magic == "\xFE\xED\xFA\xCF" || Magic == "\xCF\xFA\xED\xFE"; + ObjectFile *Ret = new MachOObjectFile(Buffer, Is64Bits, ec); if (ec) return NULL; return Ret; |