aboutsummaryrefslogtreecommitdiff
path: root/llvm/test/CodeGen/X86/load-sample-profile.ll
blob: 2e3f8809d3882e22fcbe6ec8ba239aa12dedb41a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
; RUN: llc < %s -mtriple=x86_64-unknown-linux-gnu -debug-pass=Structure -enable-fs-discriminator=true -improved-fs-discriminator=true 2>&1 | FileCheck %s --check-prefix=NOPROFILE
; RUN: llc < %s -mtriple=x86_64-unknown-linux-gnu -debug-pass=Structure -fs-profile-file=%S/Inputs/fsloader-mfs.afdo -enable-fs-discriminator=true -improved-fs-discriminator=true 2>&1 | FileCheck %s --check-prefix=PROFILE-NOMFS
; RUN: llc < %s -mtriple=x86_64-unknown-linux-gnu -debug-pass=Structure -fs-profile-file=%S/Inputs/fsloader-mfs.afdo -split-machine-functions -enable-fs-discriminator=true -improved-fs-discriminator=true 2>&1 | FileCheck %s --check-prefix=PROFILE-MFS

;; No profile is specified, no load passes.
; NOPROFILE: Add FS discriminators in MIR
; NO-NOPROFILE: SampleFDO loader in MIR
; NOPROFILE: Add FS discriminators in MIR
; NO-NOPROFILE: SampleFDO loader in MIR
; NOPROFILE: Add FS discriminators in MIR
; NO-NOPROFILE: SampleFDO loader in MIR

;; Profile is specified, so we have first 2 load passes.
; PROFILE-NOMFS: Add FS discriminators in MIR
; PROFILE-NOMFS: SampleFDO loader in MIR
; PROFILE-NOMFS: Add FS discriminators in MIR
; PROFILE-NOMFS: SampleFDO loader in MIR
; PROFILE-NOMFS: Add FS discriminators in MIR
;; But mfs is not specified, so no "SampleFDO loader should be created"
; NO-PROFILE-NOMFS: SampleFDO loader in MIR

;; Profile is specified with mfs, so we have 3 load passes.
; PROFILE-MFS: Add FS discriminators in MIR
; PROFILE-MFS: SampleFDO loader in MIR
; PROFILE-MFS: Add FS discriminators in MIR
; PROFILE-MFS: SampleFDO loader in MIR
; PROFILE-MFS: Add FS discriminators in MIR
; PROFILE-MFS: SampleFDO loader in MIR
; PROFILE-MFS: Machine Function Splitter Transformation

define void @foo4(i1 zeroext %0, i1 zeroext %1) nounwind {
  br i1 %0, label %3, label %7

3:
  %4 = call i32 @bar()
  br label %7

5:
  %6 = call i32 @baz()
  br label %7

7:
  br i1 %1, label %8, label %10

8:
  %9 = call i32 @bam()
  br label %12

10:
  %11 = call i32 @baz()
  br label %12

12:
  %13 = tail call i32 @qux()
  ret void
}

declare i32 @bar()
declare i32 @baz()
declare i32 @bam()
declare i32 @qux()