mirror of
https://github.com/RPCSX/llvm.git
synced 2025-02-25 07:31:32 +00:00
Rollback r246276 - Object: Teach llvm-ar to create symbol table for COFF short import files
This change caused a test for llvm-readobj to fail. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@246277 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
e8402a23ca
commit
976f3e14bf
@ -11,58 +11,14 @@
|
||||
//
|
||||
//===----------------------------------------------------------------------===//
|
||||
|
||||
#include "llvm/Object/COFF.h"
|
||||
#include "llvm/Object/IRObjectFile.h"
|
||||
#include "llvm/Object/ObjectFile.h"
|
||||
#include "llvm/Object/SymbolicFile.h"
|
||||
#include "llvm/Support/COFF.h"
|
||||
#include "llvm/Support/MemoryBuffer.h"
|
||||
|
||||
using namespace llvm;
|
||||
using namespace object;
|
||||
|
||||
// COFF short import file is a special kind of file which contains
|
||||
// only symbol names for DLL-exported symbols. This class implements
|
||||
// SymbolicFile interface for the file.
|
||||
namespace {
|
||||
class COFFImportFile : public SymbolicFile {
|
||||
public:
|
||||
COFFImportFile(MemoryBufferRef Source)
|
||||
: SymbolicFile(sys::fs::file_magic::coff_import_library, Source) {}
|
||||
|
||||
void moveSymbolNext(DataRefImpl &Symb) const override { ++Symb.p; }
|
||||
|
||||
std::error_code printSymbolName(raw_ostream &OS,
|
||||
DataRefImpl Symb) const override {
|
||||
if (Symb.p == 1)
|
||||
OS << "__imp_";
|
||||
OS << StringRef(Data.getBufferStart() + sizeof(coff_import_header));
|
||||
return std::error_code();
|
||||
}
|
||||
|
||||
uint32_t getSymbolFlags(DataRefImpl Symb) const override {
|
||||
return SymbolRef::SF_Global;
|
||||
}
|
||||
|
||||
basic_symbol_iterator symbol_begin_impl() const override {
|
||||
return BasicSymbolRef(DataRefImpl(), this);
|
||||
}
|
||||
|
||||
basic_symbol_iterator symbol_end_impl() const override {
|
||||
DataRefImpl Symb;
|
||||
Symb.p = isCode() ? 2 : 1;
|
||||
return BasicSymbolRef(Symb, this);
|
||||
}
|
||||
|
||||
private:
|
||||
bool isCode() const {
|
||||
auto *Import = reinterpret_cast<const coff_import_header *>(
|
||||
Data.getBufferStart());
|
||||
return Import->getType() == llvm::COFF::IMPORT_CODE;
|
||||
}
|
||||
};
|
||||
} // anonymous namespace
|
||||
|
||||
SymbolicFile::SymbolicFile(unsigned int Type, MemoryBufferRef Source)
|
||||
: Binary(Type, Source) {}
|
||||
|
||||
@ -98,10 +54,9 @@ ErrorOr<std::unique_ptr<SymbolicFile>> SymbolicFile::createSymbolicFile(
|
||||
case sys::fs::file_magic::macho_dynamically_linked_shared_lib_stub:
|
||||
case sys::fs::file_magic::macho_dsym_companion:
|
||||
case sys::fs::file_magic::macho_kext_bundle:
|
||||
case sys::fs::file_magic::coff_import_library:
|
||||
case sys::fs::file_magic::pecoff_executable:
|
||||
return ObjectFile::createObjectFile(Object, Type);
|
||||
case sys::fs::file_magic::coff_import_library:
|
||||
return std::unique_ptr<SymbolicFile>(new COFFImportFile(Object));
|
||||
case sys::fs::file_magic::elf_relocatable:
|
||||
case sys::fs::file_magic::macho_object:
|
||||
case sys::fs::file_magic::coff_object: {
|
||||
|
Binary file not shown.
Binary file not shown.
@ -99,16 +99,6 @@ MACHO-NEXT: 0000000000000000 t _bar
|
||||
MACHO-NEXT: 0000000000000001 T _foo
|
||||
MACHO-NEXT: 0000000000000002 T _main
|
||||
|
||||
RUN: rm -f %t.a
|
||||
RUN: llvm-ar --format=gnu rcsU %t.a %p/Inputs/coff-short-import-code %p/Inputs/coff-short-import-data
|
||||
RUN: llvm-nm -M %t.a | FileCheck --check-prefix=COFF-SHORT-IMPORT %s
|
||||
|
||||
COFF-SHORT-IMPORT: Archive map
|
||||
COFF-SHORT-IMPORT-NEXT: _foo in coff-short-import-code
|
||||
COFF-SHORT-IMPORT-NEXT: __imp__foo in coff-short-import-code
|
||||
COFF-SHORT-IMPORT-NEXT: _bar in coff-short-import-data
|
||||
COFF-SHORT-IMPORT-NOT: __imp__bar in coff-short-import-data
|
||||
|
||||
Test that we pad the symbol table so that it ends in a multiple of 4 bytes:
|
||||
8 + 60 + 36 == 104
|
||||
RUN: rm -f %t.a
|
||||
|
Loading…
x
Reference in New Issue
Block a user