1 ## This test verifies the effect of -icp-inline option: that ICP is only
2 ## performed for call targets eligible for inlining.
4 ## The assembly was produced from C code compiled with clang-15 -O1 -S:
6 # int foo(int x) { return x + 1; }
7 # int bar(int x) { return x*100 + 42; }
8 # typedef int (*const fn)(int);
9 # fn funcs[] = { foo, bar };
11 # int main(int argc, char *argv[]) {
12 # fn func = funcs[argc];
16 # RUN: llvm-mc -filetype=obj -triple x86_64-unknown-unknown %s -o %t.o
17 # RUN: link_fdata %s %t.o %t.fdata
18 # RUN: llvm-strip --strip-unneeded %t.o
19 # RUN: %clang %cflags %t.o -o %t.exe -Wl,-q -nostdlib -pie
21 # Without -icp-inline option, ICP is performed
22 # RUN: llvm-bolt %t.exe --icp=calls --icp-calls-topn=1 --inline-small-functions\
23 # RUN: -o %t.null --lite=0 \
24 # RUN: --inline-small-functions-bytes=4 --print-icp --data %t.fdata \
25 # RUN: | FileCheck %s --check-prefix=CHECK-NO-ICP-INLINE
26 # CHECK-NO-ICP-INLINE: Binary Function "main" after indirect-call-promotion
27 # CHECK-NO-ICP-INLINE: callq bar
28 # CHECK-NO-ICP-INLINE: End of Function "main"
30 # With -icp-inline option, ICP is not performed (size of bar > inline threshold)
31 # RUN: llvm-bolt %t.exe --icp=calls --icp-calls-topn=1 --inline-small-functions\
32 # RUN: -o %t.null --lite=0 \
33 # RUN: --inline-small-functions-bytes=4 --icp-inline --print-icp \
34 # RUN: --data %t.fdata | FileCheck %s --check-prefix=CHECK-ICP-INLINE
35 # CHECK-ICP-INLINE: Binary Function "main" after indirect-call-promotion
36 # CHECK-ICP-INLINE: callq *(%rcx,%rax,8)
37 # CHECK-ICP-INLINE-NOT: callq bar
38 # CHECK-ICP-INLINE: End of Function "main"
42 imull $
0x64, %edi
, %eax
60 .cfi_def_cfa_offset 16
62 leaq funcs
(%rip
), %rcx
66 # FDATA: 1 main #LBB00_br# 1 foo 0 0 1
67 # FDATA: 1 main #LBB00_br# 1 bar 0 0 2