OSDN Git Service

Enrich inline messages
[android-x86/external-llvm.git] / test / ThinLTO / X86 / diagnostic-handler-remarks.ll
1 ; RUN: opt -module-summary %s -o %t1.bc
2 ; RUN: opt -module-summary %p/Inputs/diagnostic-handler-remarks.ll -o %t2.bc
3
4 ; Optimization records are collected regardless of the diagnostic handler
5 ; RUN: rm -f %t.yaml.thin.0.yaml %t.yaml.thin.1.yaml
6 ; RUN: llvm-lto -thinlto-action=run \
7 ; RUN:          -lto-pass-remarks-output=%t.yaml \
8 ; RUN:          -exported-symbol _func2 \
9 ; RUN:          -exported-symbol _main %t1.bc %t2.bc 2>&1 | \
10 ; RUN:     FileCheck %s -allow-empty
11 ; CHECK-NOT: remark:
12 ; CHECK-NOT: llvm-lto:
13
14
15 ; Verify that bar is imported and inlined into foo
16 ; RUN: cat %t.yaml.thin.0.yaml | FileCheck %s -check-prefix=YAML1
17 ; YAML1:      --- !Passed
18 ; YAML1-NEXT: Pass:            inline
19 ; YAML1-NEXT: Name:            Inlined
20 ; YAML1-NEXT: Function:        main
21 ; YAML1-NEXT: Args:
22 ; YAML1-NEXT:   - Callee:          foo
23 ; YAML1-NEXT:   - String:          ' inlined into '
24 ; YAML1-NEXT:   - Caller:          main
25 ; YAML1-NEXT:   - String:          ' with '
26 ; YAML1-NEXT:   - String:          '(cost='
27 ; YAML1-NEXT:   - Cost:            '-30'
28 ; YAML1-NEXT:   - String:          ', threshold='
29 ; YAML1-NEXT:   - Threshold:       '337'
30 ; YAML1-NEXT:   - String:          ')'
31 ; YAML1-NEXT: ...
32
33
34 ; Verify that bar is imported and inlined into foo
35 ; RUN: cat %t.yaml.thin.1.yaml | FileCheck %s -check-prefix=YAML2
36 ; YAML2: --- !Passed
37 ; YAML2-NEXT: Pass:            inline
38 ; YAML2-NEXT: Name:            Inlined
39 ; YAML2-NEXT: Function:        foo
40 ; YAML2-NEXT: Args:
41 ; YAML2-NEXT:   - Callee:          bar
42 ; YAML2-NEXT:   - String:          ' inlined into '
43 ; YAML2-NEXT:   - Caller:          foo
44 ; YAML2-NEXT:   - String:          ' with '
45 ; YAML2-NEXT:   - String:          '(cost='
46 ; YAML2-NEXT:   - Cost:            '-30'
47 ; YAML2-NEXT:   - String:          ', threshold='
48 ; YAML2-NEXT:   - Threshold:       '337'
49 ; YAML2-NEXT:   - String:          ')'
50 ; YAML2-NEXT: ...
51
52
53 target datalayout = "e-m:o-i64:64-f80:128-n8:16:32:64-S128"
54 target triple = "x86_64-apple-macosx10.11.0"
55
56 define i32 @bar() {
57         ret i32 42
58 }
59 declare i32 @foo()
60 define i32 @main() {
61   %i = call i32 @foo()
62   ret i32 %i
63 }
64