forked from OSchip/llvm-project
[ELF] ICF should respect section alignment
When performing ICF, we have to respect the alignment requirement of each section within each group. Differential Revision: https://reviews.llvm.org/D23732 llvm-svn: 279456
This commit is contained in:
parent
bee2f41fac
commit
901948a205
|
@ -302,7 +302,11 @@ template <class ELFT> void ICF<ELFT>::run() {
|
|||
// the same group are consecutive in the vector.
|
||||
std::stable_sort(V.begin(), V.end(),
|
||||
[](InputSection<ELFT> *A, InputSection<ELFT> *B) {
|
||||
return A->GroupId < B->GroupId;
|
||||
if (A->GroupId != B->GroupId)
|
||||
return A->GroupId < B->GroupId;
|
||||
// Within a group, put the highest alignment
|
||||
// requirement first, so that's the one we'll keep.
|
||||
return B->Alignment < A->Alignment;
|
||||
});
|
||||
|
||||
// Compare static contents and assign unique IDs for each static content.
|
||||
|
|
|
@ -4,8 +4,8 @@
|
|||
# RUN: ld.lld %t -o %t2 --icf=all --verbose | FileCheck %s
|
||||
# RUN: llvm-objdump -t %t2 | FileCheck -check-prefix=ALIGN %s
|
||||
|
||||
# CHECK: selected .text.f1
|
||||
# CHECK: removed .text.f2
|
||||
# CHECK: selected .text.f2
|
||||
# CHECK: removed .text.f1
|
||||
|
||||
# ALIGN: 0000000000011000 .text 00000000 _start
|
||||
# ALIGN: 0000000000011100 .text 00000000 f1
|
||||
|
|
Loading…
Reference in New Issue