# REQUIRES: x86 # RUN: rm -rf %t* # RUN: llvm-mc -filetype=obj -triple=x86_64-apple-darwin %s -o %t.o # RUN: %lld -lSystem --icf=all -o %t %t.o # RUN: llvm-objdump -d --syms %t | FileCheck %s ## When ICF has fewer than 1 Ki functions to segregate into equivalence classes, ## it uses a sequential algorithm to avoid the overhead of threading. ## At 1 Ki functions or more, when threading begins to pay-off, ICF employs its ## parallel segregation algorithm. Here we generate 4 Ki functions to exercise ## the parallel algorithm. There are 4 unique function bodies, each replicated ## 1 Ki times. The resulting folded program should retain one instance for each ## of the four unique functions. ## The symtab does not have a particular order. And even though we can expect ## some partial order, it is not possible to express that in FileCheck syntax. ## So just use -DAG # CHECK-LABEL: SYMBOL TABLE: # CHECK-DAG: [[#%x,G0:]] g F __TEXT,__text _g000000 # CHECK-DAG: [[#%x,G0]] g F __TEXT,__text _g033333 # CHECK-DAG: [[#%x,G1:]] g F __TEXT,__text _g100000 # CHECK-DAG: [[#%x,G1]] g F __TEXT,__text _g133333 # CHECK-DAG: [[#%x,G2:]] g F __TEXT,__text _g200000 # CHECK-DAG: [[#%x,G2]] g F __TEXT,__text _g233333 # CHECK-DAG: [[#%x,G3:]] g F __TEXT,__text _g300000 # CHECK-DAG: [[#%x,G3]] g F __TEXT,__text _g333333 ## . . . many intervening _gXXXXXX symbols # CHECK-LABEL: Disassembly of section __TEXT,__text: # CHECK-DAG: [[#%x,G0]] <_g033333>: # CHECK-DAG: [[#%x,G1]] <_g133333>: # CHECK-DAG: [[#%x,G2]] <_g233333>: # CHECK-DAG: [[#%x,G3]] <_g333333>: # CHECK-NOT: [[#]] <_g{{.*}}>: .subsections_via_symbols .text .p2align 2 .macro gen_4 c .globl _g0\c, _g1\c, _g2\c, _g3\c _g0\c:; movl $0, %eax; ret _g1\c:; movl $1, %eax; ret _g2\c:; movl $2, %eax; ret _g3\c:; movl $3, %eax; ret .endm .macro gen_16 c gen_4 0\c gen_4 1\c gen_4 2\c gen_4 3\c .endm .macro gen_64 c gen_16 0\c gen_16 1\c gen_16 2\c gen_16 3\c .endm .macro gen_256 c gen_64 0\c gen_64 1\c gen_64 2\c gen_64 3\c .endm .macro gen_1024 c gen_256 0\c gen_256 1\c gen_256 2\c gen_256 3\c .endm gen_1024 0 gen_1024 1 gen_1024 2 gen_1024 3 .globl _main _main: ret