blob: 6fe7bf5c25cd404c5a20c357e79669819ecff278 [file] [log] [blame] [edit]
; BB cluster section tests when using edges profile and basic blocks hashes to generate clusters.
; In the tests, we first generate hash values for basic blocks and write them to the profile.
; When generating basic blocks clusters, we match the hashes of basic blocks in the current CFG
; with those in the profile. After a successful match, we retrieve the weights of the basic blocks
; and edges from the profile. Subsequently, we use an inference algorithm to deduce the complete
; weights of all basic blocks and edges. Finally, we generate "hot" and "cold" clusters based on
; these complete weights.
; In Test 1 and Test 2, the weights of basic blocks and edges in the profiles are different, which
; will ultimately result in distinct cluster partitioning outcomes.
;
; RUN: llc %s -O0 -mtriple=x86_64-pc-linux -function-sections -filetype=obj -basic-block-address-map -emit-bb-hash -o %t.o
;
; Test1: Basic blocks #0 (entry), #1 and #3 will be placed in the same section.
; The rest will be placed in the cold section.
;
; RUN: echo 'v1' > %t1
; RUN: echo 'f foo' >> %t1
; RUN: echo 'g 0:100,1:100,2:0 1:100,3:100 2:0,3:0 3:100' >> %t1
;
; These commands read BB hashes from SHT_LLVM_BB_ADDR_MAP
; and put them into the basic blocks sections profile.
; RUN: llvm-readobj %t.o --bb-addr-map | \
; RUN: awk 'BEGIN {printf "h"} \
; RUN: /ID: [0-9]+/ {id=$2} \
; RUN: /Hash: 0x[0-9A-Fa-f]+/ {gsub(/^0x/, "", $2); hash=$2; printf " %%s:%%s", id, hash} \
; RUN: END {print ""}' \
; RUN: >> %t1
;
; RUN: llc < %s -O0 -mtriple=x86_64-pc-linux -function-sections -basic-block-sections=%t1 -basic-block-section-match-infer | \
; RUN: FileCheck %s -check-prefixes=CHECK,LINUX-SECTIONS1
;
; Test2: Basic #0 (entry), #2 and #3 will be placed in the same section.
; The rest will be placed in the cold section.
;
; RUN: echo 'v1' > %t2
; RUN: echo 'f foo' >> %t2
; RUN: echo 'g 0:100,1:0,2:100 1:0,3:0 2:100,3:100 3:100' >> %t2
;
; These commands read BB hashes from SHT_LLVM_BB_ADDR_MAP
; and put them into the basic blocks sections profile.
; RUN: llvm-readobj %t.o --bb-addr-map | \
; RUN: awk 'BEGIN {printf "h"} \
; RUN: /ID: [0-9]+/ {id=$2} \
; RUN: /Hash: 0x[0-9A-Fa-f]+/ {gsub(/^0x/, "", $2); hash=$2; printf " %%s:%%s", id, hash} \
; RUN: END {print ""}' \
; RUN: >> %t2
;
; RUN: llc < %s -O0 -mtriple=x86_64-pc-linux -function-sections -basic-block-sections=%t2 -basic-block-section-match-infer | \
; RUN: FileCheck %s -check-prefixes=CHECK,LINUX-SECTIONS2
define void @foo(i1 zeroext) nounwind {
%2 = alloca i8, align 1
%3 = zext i1 %0 to i8
store i8 %3, ptr %2, align 1
%4 = load i8, ptr %2, align 1
%5 = trunc i8 %4 to i1
br i1 %5, label %6, label %8
6: ; preds = %1
%7 = call i32 @bar()
br label %10
8: ; preds = %1
%9 = call i32 @baz()
br label %10
10: ; preds = %8, %6
ret void
}
declare i32 @bar() #1
declare i32 @baz() #1
; CHECK: .section .text.foo,"ax",@progbits
; CHECK-NOT: .section
; CHECK-LABEL: foo:
; CHECK-NOT: .section
; CHECK-NOT: .LBB_END0_{{0-9}}+
; LINUX-SECTIONS1-LABEL: # %bb.1:
; LINUX-SECTIONS2-LABEL: # %bb.2:
; CHECK-NOT: .section
; CHECK-NOT: .LBB_END0_{{0-9}}+
; CHECK-LABEL: .LBB0_3:
; CHECK-LABEL: .LBB_END0_3:
; CHECK-NEXT: .section .text.split.foo,"ax",@progbits
; CHECK-LABEL: foo.cold:
; LINUX-SECTIONS1-LABEL: .LBB_END0_2:
; LINUX-SECTIONS2-LABEL: .LBB_END0_1:
; LINUX-SECTIONS1-LABEL: .size foo.cold, .LBB_END0_2-foo.cold
; LINUX-SECTIONS2-LABEL: .size foo.cold, .LBB_END0_1-foo.cold
; CHECK-LABEL: .Lfunc_end0:
; CHECK-NEXT: .size foo, .Lfunc_end0-foo