mirror of
https://github.com/capstone-engine/llvm-capstone.git
synced 2024-12-04 03:44:59 +00:00
00dc23f26e
The gold behaviour with regard to --keep-unique is arguably a bug. I also noticed a bug in my patch, which is that we mislink the following program with --icf=safe by merging f3 and f4: void f1() {} void f2() {} __attribute__((weak)) void* f3() { return f1; } __attribute__((weak)) void* f4() { return f2; } int main() { printf("%p %p\n", f3(), f4()); } llvm-svn: 337729
44 lines
1.3 KiB
ArmAsm
44 lines
1.3 KiB
ArmAsm
# REQUIRES: x86
|
|
|
|
# RUN: llvm-mc -filetype=obj -triple=x86_64-unknown-linux %s -o %t
|
|
# RUN: ld.lld %t -o %t2 --icf=all --print-icf-sections | FileCheck %s
|
|
# RUN: ld.lld %t -o %t2 --keep-unique f2 --keep-unique f4 --keep-unique f5 --icf=all --print-icf-sections 2>&1 | FileCheck %s -check-prefix=CHECK-KEEP
|
|
|
|
// Base case, expect only .text.f1 to be kept
|
|
// CHECK: selected section {{.*}}:(.text.f1)
|
|
// CHECK-NEXT: removing identical section {{.*}}:(.text.f2)
|
|
// CHECK-NEXT: removing identical section {{.*}}:(.text.f3)
|
|
// CHECK-NEXT: removing identical section {{.*}}:(.text.f4)
|
|
// CHECK-NEXT: removing identical section {{.*}}:(.text.f5)
|
|
|
|
// With --keep-unique f2, f4 and f5 we expect only f3 and f5 to be removed.
|
|
// f5 is not matched by --keep-unique as it is a local symbol.
|
|
// CHECK-KEEP: warning: could not find symbol f5 to keep unique
|
|
// CHECK-KEEP: selected section {{.*}}:(.text.f1)
|
|
// CHECK-KEEP-NEXT: removing identical section {{.*}}:(.text.f3)
|
|
// CHECK-KEEP-NEXT: removing identical section {{.*}}:(.text.f5)
|
|
.globl _start, f1, f2, f3, f4
|
|
_start:
|
|
ret
|
|
|
|
.section .text.f1, "ax"
|
|
f1:
|
|
nop
|
|
|
|
.section .text.f2, "ax"
|
|
f2:
|
|
nop
|
|
|
|
.section .text.f3, "ax"
|
|
f3:
|
|
nop
|
|
|
|
.section .text.f4, "ax"
|
|
f4:
|
|
nop
|
|
|
|
# f5 is local, not found by --keep-unique f5
|
|
.section .text.f5, "ax"
|
|
f5:
|
|
nop
|