mirror of
https://github.com/RPCSX/llvm.git
synced 2024-11-28 14:10:41 +00:00
91f86b7e1c
This interface allows IRObjectFile to be implemented without having dummy methods for all section and segment related methods. Both llvm-ar and llvm-nm are changed to use it. Unfortunately the mangler is still not plugged in since it requires some refactoring to make a Module hold a DataLayout. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@201881 91177308-0d34-0410-b5e6-96231b3b80d8
88 lines
3.1 KiB
C++
88 lines
3.1 KiB
C++
//===- Binary.cpp - A generic binary file -----------------------*- C++ -*-===//
|
|
//
|
|
// The LLVM Compiler Infrastructure
|
|
//
|
|
// This file is distributed under the University of Illinois Open Source
|
|
// License. See LICENSE.TXT for details.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
//
|
|
// This file defines the Binary class.
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
|
|
#include "llvm/Object/Binary.h"
|
|
#include "llvm/ADT/StringRef.h"
|
|
#include "llvm/Support/FileSystem.h"
|
|
#include "llvm/Support/MemoryBuffer.h"
|
|
#include "llvm/Support/Path.h"
|
|
|
|
// Include headers for createBinary.
|
|
#include "llvm/Object/Archive.h"
|
|
#include "llvm/Object/MachOUniversal.h"
|
|
#include "llvm/Object/ObjectFile.h"
|
|
|
|
using namespace llvm;
|
|
using namespace object;
|
|
|
|
Binary::~Binary() {
|
|
if (BufferOwned)
|
|
delete Data;
|
|
}
|
|
|
|
Binary::Binary(unsigned int Type, MemoryBuffer *Source, bool BufferOwned)
|
|
: TypeID(Type), BufferOwned(BufferOwned), Data(Source) {}
|
|
|
|
StringRef Binary::getData() const {
|
|
return Data->getBuffer();
|
|
}
|
|
|
|
StringRef Binary::getFileName() const {
|
|
return Data->getBufferIdentifier();
|
|
}
|
|
|
|
ErrorOr<Binary *> object::createBinary(MemoryBuffer *Source,
|
|
LLVMContext *Context) {
|
|
OwningPtr<MemoryBuffer> scopedSource(Source);
|
|
sys::fs::file_magic Type = sys::fs::identify_magic(Source->getBuffer());
|
|
|
|
switch (Type) {
|
|
case sys::fs::file_magic::archive:
|
|
return Archive::create(scopedSource.take());
|
|
case sys::fs::file_magic::elf_relocatable:
|
|
case sys::fs::file_magic::elf_executable:
|
|
case sys::fs::file_magic::elf_shared_object:
|
|
case sys::fs::file_magic::elf_core:
|
|
case sys::fs::file_magic::macho_object:
|
|
case sys::fs::file_magic::macho_executable:
|
|
case sys::fs::file_magic::macho_fixed_virtual_memory_shared_lib:
|
|
case sys::fs::file_magic::macho_core:
|
|
case sys::fs::file_magic::macho_preload_executable:
|
|
case sys::fs::file_magic::macho_dynamically_linked_shared_lib:
|
|
case sys::fs::file_magic::macho_dynamic_linker:
|
|
case sys::fs::file_magic::macho_bundle:
|
|
case sys::fs::file_magic::macho_dynamically_linked_shared_lib_stub:
|
|
case sys::fs::file_magic::macho_dsym_companion:
|
|
case sys::fs::file_magic::coff_object:
|
|
case sys::fs::file_magic::coff_import_library:
|
|
case sys::fs::file_magic::pecoff_executable:
|
|
case sys::fs::file_magic::bitcode:
|
|
return ObjectFile::createSymbolicFile(scopedSource.take(), true, Type,
|
|
Context);
|
|
case sys::fs::file_magic::macho_universal_binary:
|
|
return MachOUniversalBinary::create(scopedSource.take());
|
|
case sys::fs::file_magic::unknown:
|
|
case sys::fs::file_magic::windows_resource:
|
|
// Unrecognized object file format.
|
|
return object_error::invalid_file_type;
|
|
}
|
|
llvm_unreachable("Unexpected Binary File Type");
|
|
}
|
|
|
|
ErrorOr<Binary *> object::createBinary(StringRef Path) {
|
|
OwningPtr<MemoryBuffer> File;
|
|
if (error_code EC = MemoryBuffer::getFileOrSTDIN(Path, File))
|
|
return EC;
|
|
return createBinary(File.take());
|
|
}
|