forked from OSchip/llvm-project
[ELF] Make --pack-dyn-relocs=android compatible with parallel relocation scanning
This commit is contained in:
parent
f90c2acb5d
commit
7dac9f4e48
|
@ -1779,8 +1779,7 @@ bool AndroidPackedRelocationSection<ELFT>::updateAllocSize() {
|
||||||
r.r_offset = rel.getOffset();
|
r.r_offset = rel.getOffset();
|
||||||
r.setSymbolAndType(rel.getSymIndex(getPartition().dynSymTab.get()),
|
r.setSymbolAndType(rel.getSymIndex(getPartition().dynSymTab.get()),
|
||||||
rel.type, false);
|
rel.type, false);
|
||||||
if (config->isRela)
|
r.r_addend = config->isRela ? rel.computeAddend() : 0;
|
||||||
r.r_addend = rel.computeAddend();
|
|
||||||
|
|
||||||
if (r.getType(config->isMips64EL) == target->relativeRel)
|
if (r.getType(config->isMips64EL) == target->relativeRel)
|
||||||
relatives.push_back(r);
|
relatives.push_back(r);
|
||||||
|
@ -1824,12 +1823,12 @@ bool AndroidPackedRelocationSection<ELFT>::updateAllocSize() {
|
||||||
//
|
//
|
||||||
// For Rela, we also want to sort by r_addend when r_info is the same. This
|
// For Rela, we also want to sort by r_addend when r_info is the same. This
|
||||||
// enables us to group by r_addend as well.
|
// enables us to group by r_addend as well.
|
||||||
llvm::stable_sort(nonRelatives, [](const Elf_Rela &a, const Elf_Rela &b) {
|
llvm::sort(nonRelatives, [](const Elf_Rela &a, const Elf_Rela &b) {
|
||||||
if (a.r_info != b.r_info)
|
if (a.r_info != b.r_info)
|
||||||
return a.r_info < b.r_info;
|
return a.r_info < b.r_info;
|
||||||
if (config->isRela)
|
if (a.r_addend != b.r_addend)
|
||||||
return a.r_addend < b.r_addend;
|
return a.r_addend < b.r_addend;
|
||||||
return false;
|
return a.r_offset < b.r_offset;
|
||||||
});
|
});
|
||||||
|
|
||||||
// Group relocations with the same r_info. Note that each group emits a group
|
// Group relocations with the same r_info. Note that each group emits a group
|
||||||
|
|
Loading…
Reference in New Issue