mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-06-17 20:23:59 +00:00
This patch adds a new flag "-coff-imports" to llvm-readobj.
When the flag is given, the command prints out the COFF import table. Currently only the import table directory will be printed. I'm going to make another patch to print out the imported symbols. The implementation of import directory entry iterator in COFFObjectFile.cpp was buggy. This patch fixes that too. http://reviews.llvm.org/D5569 git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@218891 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
@ -491,8 +491,9 @@ std::error_code COFFObjectFile::initImportTablePtr() {
|
||||
return object_error::success;
|
||||
|
||||
uint32_t ImportTableRva = DataEntry->RelativeVirtualAddress;
|
||||
// -1 because the last entry is the null entry.
|
||||
NumberOfImportDirectory = DataEntry->Size /
|
||||
sizeof(import_directory_table_entry);
|
||||
sizeof(import_directory_table_entry) - 1;
|
||||
|
||||
// Find the section that contains the RVA. This is needed because the RVA is
|
||||
// the import table's memory address which is different from its file offset.
|
||||
@ -1029,24 +1030,36 @@ void ImportDirectoryEntryRef::moveNext() {
|
||||
|
||||
std::error_code ImportDirectoryEntryRef::getImportTableEntry(
|
||||
const import_directory_table_entry *&Result) const {
|
||||
Result = ImportTable;
|
||||
Result = ImportTable + Index;
|
||||
return object_error::success;
|
||||
}
|
||||
|
||||
std::error_code ImportDirectoryEntryRef::getName(StringRef &Result) const {
|
||||
uintptr_t IntPtr = 0;
|
||||
if (std::error_code EC =
|
||||
OwningObject->getRvaPtr(ImportTable->NameRVA, IntPtr))
|
||||
OwningObject->getRvaPtr(ImportTable[Index].NameRVA, IntPtr))
|
||||
return EC;
|
||||
Result = StringRef(reinterpret_cast<const char *>(IntPtr));
|
||||
return object_error::success;
|
||||
}
|
||||
|
||||
std::error_code
|
||||
ImportDirectoryEntryRef::getImportLookupTableRVA(uint32_t &Result) const {
|
||||
Result = ImportTable[Index].ImportLookupTableRVA;
|
||||
return object_error::success;
|
||||
}
|
||||
|
||||
std::error_code
|
||||
ImportDirectoryEntryRef::getImportAddressTableRVA(uint32_t &Result) const {
|
||||
Result = ImportTable[Index].ImportAddressTableRVA;
|
||||
return object_error::success;
|
||||
}
|
||||
|
||||
std::error_code ImportDirectoryEntryRef::getImportLookupEntry(
|
||||
const import_lookup_table_entry32 *&Result) const {
|
||||
uintptr_t IntPtr = 0;
|
||||
if (std::error_code EC =
|
||||
OwningObject->getRvaPtr(ImportTable->ImportLookupTableRVA, IntPtr))
|
||||
uint32_t RVA = ImportTable[Index].ImportLookupTableRVA;
|
||||
if (std::error_code EC = OwningObject->getRvaPtr(RVA, IntPtr))
|
||||
return EC;
|
||||
Result = reinterpret_cast<const import_lookup_table_entry32 *>(IntPtr);
|
||||
return object_error::success;
|
||||
|
Reference in New Issue
Block a user