Update for API change for handling mips64el.
llvm-svn: 178695
This commit is contained in:
parent
2025e8b820
commit
26cf0b5130
|
@ -33,16 +33,18 @@ template <class ELFT> class ELFReference LLVM_FINAL : public Reference {
|
|||
typedef llvm::object::Elf_Rel_Impl<ELFT, true> Elf_Rela;
|
||||
public:
|
||||
|
||||
ELFReference(const Elf_Rela *rela, uint64_t offset, const Atom *target)
|
||||
: _target(target), _targetSymbolIndex(rela->getSymbol()),
|
||||
ELFReference(const Elf_Rela *rela, uint64_t offset, const Atom *target,
|
||||
Kind kind, uint32_t symbol)
|
||||
: _target(target), _targetSymbolIndex(symbol),
|
||||
_offsetInAtom(offset), _addend(rela->r_addend) {
|
||||
_kind = (Kind) rela->getType();
|
||||
_kind = kind;
|
||||
}
|
||||
|
||||
ELFReference(const Elf_Rel *rel, uint64_t offset, const Atom *target)
|
||||
: _target(target), _targetSymbolIndex(rel->getSymbol()),
|
||||
ELFReference(const Elf_Rel *rel, uint64_t offset, const Atom *target,
|
||||
Kind kind, uint32_t symbol)
|
||||
: _target(target), _targetSymbolIndex(symbol),
|
||||
_offsetInAtom(offset), _addend(0) {
|
||||
_kind = (Kind) rel->getType();
|
||||
_kind = kind;
|
||||
}
|
||||
|
||||
ELFReference(Kind kind)
|
||||
|
|
|
@ -576,8 +576,12 @@ private:
|
|||
if (!((rai.r_offset >= symbol->st_value) &&
|
||||
(rai.r_offset < symbol->st_value + content.size())))
|
||||
continue;
|
||||
bool isMips64EL = _objFile->isMips64EL();
|
||||
Kind kind = (Kind) rai.getType(isMips64EL);
|
||||
uint32_t symbolIndex = rai.getSymbol(isMips64EL);
|
||||
auto *ERef = new (_readerStorage)
|
||||
ELFReference<ELFT>(&rai, rai.r_offset - symbol->st_value, nullptr);
|
||||
ELFReference<ELFT>(&rai, rai.r_offset - symbol->st_value, nullptr,
|
||||
kind, symbolIndex);
|
||||
_references.push_back(ERef);
|
||||
}
|
||||
|
||||
|
@ -586,8 +590,12 @@ private:
|
|||
for (auto &ri : rri->second) {
|
||||
if ((ri.r_offset >= symbol->st_value) &&
|
||||
(ri.r_offset < symbol->st_value + content.size())) {
|
||||
bool isMips64EL = _objFile->isMips64EL();
|
||||
Kind kind = (Kind) ri.getType(isMips64EL);
|
||||
uint32_t symbolIndex = ri.getSymbol(isMips64EL);
|
||||
auto *ERef = new (_readerStorage)
|
||||
ELFReference<ELFT>(&ri, ri.r_offset - symbol->st_value, nullptr);
|
||||
ELFReference<ELFT>(&ri, ri.r_offset - symbol->st_value, nullptr,
|
||||
kind, symbolIndex);
|
||||
// Read the addend from the section contents
|
||||
// TODO : We should move the way lld reads relocations totally from
|
||||
// ELFObjectFile
|
||||
|
|
Loading…
Reference in New Issue