forked from OSchip/llvm-project
Move function to the only file that uses it.
llvm-svn: 241040
This commit is contained in:
parent
f69ac42ac4
commit
0ad71d982c
|
@ -244,7 +244,6 @@ public:
|
||||||
std::error_code
|
std::error_code
|
||||||
getRelocationTypeName(DataRefImpl Rel,
|
getRelocationTypeName(DataRefImpl Rel,
|
||||||
SmallVectorImpl<char> &Result) const override;
|
SmallVectorImpl<char> &Result) const override;
|
||||||
bool getRelocationHidden(DataRefImpl Rel) const override;
|
|
||||||
uint8_t getRelocationLength(DataRefImpl Rel) const;
|
uint8_t getRelocationLength(DataRefImpl Rel) const;
|
||||||
|
|
||||||
// MachO specific.
|
// MachO specific.
|
||||||
|
|
|
@ -55,11 +55,6 @@ public:
|
||||||
symbol_iterator getSymbol() const;
|
symbol_iterator getSymbol() const;
|
||||||
uint64_t getType() const;
|
uint64_t getType() const;
|
||||||
|
|
||||||
/// @brief Indicates whether this relocation should hidden when listing
|
|
||||||
/// relocations, usually because it is the trailing part of a multipart
|
|
||||||
/// relocation that will be printed as part of the leading relocation.
|
|
||||||
bool getHidden() const;
|
|
||||||
|
|
||||||
/// @brief Get a string that represents the type of this relocation.
|
/// @brief Get a string that represents the type of this relocation.
|
||||||
///
|
///
|
||||||
/// This is for display purposes only.
|
/// This is for display purposes only.
|
||||||
|
@ -246,7 +241,6 @@ protected:
|
||||||
virtual std::error_code
|
virtual std::error_code
|
||||||
getRelocationTypeName(DataRefImpl Rel,
|
getRelocationTypeName(DataRefImpl Rel,
|
||||||
SmallVectorImpl<char> &Result) const = 0;
|
SmallVectorImpl<char> &Result) const = 0;
|
||||||
virtual bool getRelocationHidden(DataRefImpl Rel) const { return false; }
|
|
||||||
|
|
||||||
public:
|
public:
|
||||||
uint64_t getCommonSymbolSize(DataRefImpl Symb) const {
|
uint64_t getCommonSymbolSize(DataRefImpl Symb) const {
|
||||||
|
@ -468,10 +462,6 @@ RelocationRef::getTypeName(SmallVectorImpl<char> &Result) const {
|
||||||
return OwningObject->getRelocationTypeName(RelocationPimpl, Result);
|
return OwningObject->getRelocationTypeName(RelocationPimpl, Result);
|
||||||
}
|
}
|
||||||
|
|
||||||
inline bool RelocationRef::getHidden() const {
|
|
||||||
return OwningObject->getRelocationHidden(RelocationPimpl);
|
|
||||||
}
|
|
||||||
|
|
||||||
inline DataRefImpl RelocationRef::getRawDataRefImpl() const {
|
inline DataRefImpl RelocationRef::getRawDataRefImpl() const {
|
||||||
return RelocationPimpl;
|
return RelocationPimpl;
|
||||||
}
|
}
|
||||||
|
|
|
@ -770,30 +770,6 @@ MachOObjectFile::getRelocationTypeName(DataRefImpl Rel,
|
||||||
return std::error_code();
|
return std::error_code();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool MachOObjectFile::getRelocationHidden(DataRefImpl Rel) const {
|
|
||||||
unsigned Arch = getArch();
|
|
||||||
uint64_t Type = getRelocationType(Rel);
|
|
||||||
|
|
||||||
// On arches that use the generic relocations, GENERIC_RELOC_PAIR
|
|
||||||
// is always hidden.
|
|
||||||
if (Arch == Triple::x86 || Arch == Triple::arm || Arch == Triple::ppc) {
|
|
||||||
if (Type == MachO::GENERIC_RELOC_PAIR)
|
|
||||||
return true;
|
|
||||||
} else if (Arch == Triple::x86_64) {
|
|
||||||
// On x86_64, X86_64_RELOC_UNSIGNED is hidden only when it follows
|
|
||||||
// an X86_64_RELOC_SUBTRACTOR.
|
|
||||||
if (Type == MachO::X86_64_RELOC_UNSIGNED && Rel.d.a > 0) {
|
|
||||||
DataRefImpl RelPrev = Rel;
|
|
||||||
RelPrev.d.a--;
|
|
||||||
uint64_t PrevType = getRelocationType(RelPrev);
|
|
||||||
if (PrevType == MachO::X86_64_RELOC_SUBTRACTOR)
|
|
||||||
return true;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
uint8_t MachOObjectFile::getRelocationLength(DataRefImpl Rel) const {
|
uint8_t MachOObjectFile::getRelocationLength(DataRefImpl Rel) const {
|
||||||
MachO::any_relocation_info RE = getRelocation(Rel);
|
MachO::any_relocation_info RE = getRelocation(Rel);
|
||||||
return getAnyRelocationLength(RE);
|
return getAnyRelocationLength(RE);
|
||||||
|
|
|
@ -692,6 +692,39 @@ static std::error_code getRelocationValueString(const RelocationRef &Rel,
|
||||||
return getRelocationValueString(MachO, Rel, Result);
|
return getRelocationValueString(MachO, Rel, Result);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// @brief Indicates whether this relocation should hidden when listing
|
||||||
|
/// relocations, usually because it is the trailing part of a multipart
|
||||||
|
/// relocation that will be printed as part of the leading relocation.
|
||||||
|
static bool getHidden(RelocationRef RelRef) {
|
||||||
|
const ObjectFile *Obj = RelRef.getObject();
|
||||||
|
auto *MachO = dyn_cast<MachOObjectFile>(Obj);
|
||||||
|
if (!MachO)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
unsigned Arch = MachO->getArch();
|
||||||
|
DataRefImpl Rel = RelRef.getRawDataRefImpl();
|
||||||
|
uint64_t Type = MachO->getRelocationType(Rel);
|
||||||
|
|
||||||
|
// On arches that use the generic relocations, GENERIC_RELOC_PAIR
|
||||||
|
// is always hidden.
|
||||||
|
if (Arch == Triple::x86 || Arch == Triple::arm || Arch == Triple::ppc) {
|
||||||
|
if (Type == MachO::GENERIC_RELOC_PAIR)
|
||||||
|
return true;
|
||||||
|
} else if (Arch == Triple::x86_64) {
|
||||||
|
// On x86_64, X86_64_RELOC_UNSIGNED is hidden only when it follows
|
||||||
|
// an X86_64_RELOC_SUBTRACTOR.
|
||||||
|
if (Type == MachO::X86_64_RELOC_UNSIGNED && Rel.d.a > 0) {
|
||||||
|
DataRefImpl RelPrev = Rel;
|
||||||
|
RelPrev.d.a--;
|
||||||
|
uint64_t PrevType = MachO->getRelocationType(RelPrev);
|
||||||
|
if (PrevType == MachO::X86_64_RELOC_SUBTRACTOR)
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
static void DisassembleObject(const ObjectFile *Obj, bool InlineRelocs) {
|
static void DisassembleObject(const ObjectFile *Obj, bool InlineRelocs) {
|
||||||
const Target *TheTarget = getTarget(Obj);
|
const Target *TheTarget = getTarget(Obj);
|
||||||
// getTarget() will have already issued a diagnostic if necessary, so
|
// getTarget() will have already issued a diagnostic if necessary, so
|
||||||
|
@ -888,7 +921,7 @@ static void DisassembleObject(const ObjectFile *Obj, bool InlineRelocs) {
|
||||||
|
|
||||||
// Print relocation for instruction.
|
// Print relocation for instruction.
|
||||||
while (rel_cur != rel_end) {
|
while (rel_cur != rel_end) {
|
||||||
bool hidden = rel_cur->getHidden();
|
bool hidden = getHidden(*rel_cur);
|
||||||
uint64_t addr = rel_cur->getOffset();
|
uint64_t addr = rel_cur->getOffset();
|
||||||
SmallString<16> name;
|
SmallString<16> name;
|
||||||
SmallString<32> val;
|
SmallString<32> val;
|
||||||
|
@ -928,7 +961,7 @@ void llvm::PrintRelocations(const ObjectFile *Obj) {
|
||||||
continue;
|
continue;
|
||||||
outs() << "RELOCATION RECORDS FOR [" << secname << "]:\n";
|
outs() << "RELOCATION RECORDS FOR [" << secname << "]:\n";
|
||||||
for (const RelocationRef &Reloc : Section.relocations()) {
|
for (const RelocationRef &Reloc : Section.relocations()) {
|
||||||
bool hidden = Reloc.getHidden();
|
bool hidden = getHidden(Reloc);
|
||||||
uint64_t address = Reloc.getOffset();
|
uint64_t address = Reloc.getOffset();
|
||||||
SmallString<32> relocname;
|
SmallString<32> relocname;
|
||||||
SmallString<32> valuestr;
|
SmallString<32> valuestr;
|
||||||
|
|
Loading…
Reference in New Issue