Piotr Padlewski | 3a0579f | 2016-09-07 23:46:50 +0000 | [diff] [blame] | 1 | ; Test to check the callgraph in summary when there is PGO |
| 2 | ; RUN: opt -module-summary %s -o %t.o |
| 3 | ; RUN: llvm-bcanalyzer -dump %t.o | FileCheck %s |
Piotr Padlewski | d9830eb | 2016-09-26 20:37:32 +0000 | [diff] [blame] | 4 | |
Piotr Padlewski | 3a0579f | 2016-09-07 23:46:50 +0000 | [diff] [blame] | 5 | ; RUN: opt -module-summary %p/Inputs/thinlto-function-summary-callgraph.ll -o %t2.o |
| 6 | ; RUN: llvm-lto -thinlto -o %t3 %t.o %t2.o |
| 7 | ; RUN: llvm-bcanalyzer -dump %t3.thinlto.bc | FileCheck %s --check-prefix=COMBINED |
| 8 | |
Piotr Padlewski | d9830eb | 2016-09-26 20:37:32 +0000 | [diff] [blame] | 9 | ; Check parsing for old summary versions generated from this file. |
| 10 | ; RUN: llvm-lto -thinlto-index-stats %p/Inputs/thinlto-function-summary-callgraph-pgo.1.bc | FileCheck %s --check-prefix=OLD |
| 11 | ; RUN: llvm-lto -thinlto-index-stats %p/Inputs/thinlto-function-summary-callgraph-pgo-combined.1.bc | FileCheck %s --check-prefix=OLD-COMBINED |
| 12 | |
Peter Collingbourne | a0f371a | 2017-04-17 17:51:36 +0000 | [diff] [blame] | 13 | ; CHECK: <SOURCE_FILENAME |
| 14 | ; CHECK-NEXT: <FUNCTION |
| 15 | ; "func" |
| 16 | ; CHECK-NEXT: <FUNCTION op0=4 op1=4 |
Piotr Padlewski | 3a0579f | 2016-09-07 23:46:50 +0000 | [diff] [blame] | 17 | ; CHECK: <GLOBALVAL_SUMMARY_BLOCK |
| 18 | ; CHECK-NEXT: <VERSION |
Peter Collingbourne | a0f371a | 2017-04-17 17:51:36 +0000 | [diff] [blame] | 19 | ; See if the call to func is registered, using the expected hotness type. |
Charles Saternos | 75da10d | 2017-08-04 16:00:58 +0000 | [diff] [blame] | 20 | ; CHECK-NEXT: <PERMODULE_PROFILE {{.*}} op5=1 op6=2/> |
Piotr Padlewski | 3a0579f | 2016-09-07 23:46:50 +0000 | [diff] [blame] | 21 | ; CHECK-NEXT: </GLOBALVAL_SUMMARY_BLOCK> |
Peter Collingbourne | a0f371a | 2017-04-17 17:51:36 +0000 | [diff] [blame] | 22 | ; CHECK: <STRTAB_BLOCK |
Peter Collingbourne | 92648c2 | 2017-06-27 23:50:11 +0000 | [diff] [blame] | 23 | ; CHECK-NEXT: blob data = 'mainfunc{{.*}}' |
Piotr Padlewski | 3a0579f | 2016-09-07 23:46:50 +0000 | [diff] [blame] | 24 | |
| 25 | ; COMBINED: <GLOBALVAL_SUMMARY_BLOCK |
| 26 | ; COMBINED-NEXT: <VERSION |
Peter Collingbourne | a0f371a | 2017-04-17 17:51:36 +0000 | [diff] [blame] | 27 | ; COMBINED-NEXT: <VALUE_GUID op0=[[FUNCID:[0-9]+]] op1=7289175272376759421/> |
| 28 | ; COMBINED-NEXT: <VALUE_GUID |
Piotr Padlewski | 3a0579f | 2016-09-07 23:46:50 +0000 | [diff] [blame] | 29 | ; COMBINED-NEXT: <COMBINED |
Peter Collingbourne | a0f371a | 2017-04-17 17:51:36 +0000 | [diff] [blame] | 30 | ; See if the call to func is registered, using the expected hotness type. |
Piotr Padlewski | d9830eb | 2016-09-26 20:37:32 +0000 | [diff] [blame] | 31 | ; op6=2 which is hotnessType::None. |
Charles Saternos | 75da10d | 2017-08-04 16:00:58 +0000 | [diff] [blame] | 32 | ; COMBINED-NEXT: <COMBINED_PROFILE {{.*}} op6=[[FUNCID]] op7=2/> |
Piotr Padlewski | 3a0579f | 2016-09-07 23:46:50 +0000 | [diff] [blame] | 33 | ; COMBINED-NEXT: </GLOBALVAL_SUMMARY_BLOCK> |
Piotr Padlewski | 3a0579f | 2016-09-07 23:46:50 +0000 | [diff] [blame] | 34 | |
| 35 | ; ModuleID = 'thinlto-function-summary-callgraph.ll' |
| 36 | target datalayout = "e-m:e-i64:64-f80:128-n8:16:32:64-S128" |
| 37 | target triple = "x86_64-unknown-linux-gnu" |
| 38 | |
| 39 | ; Function Attrs: nounwind uwtable |
| 40 | define i32 @main() #0 !prof !2 { |
| 41 | entry: |
| 42 | call void (...) @func() |
| 43 | ret i32 0 |
| 44 | } |
| 45 | |
| 46 | declare void @func(...) #1 |
| 47 | |
| 48 | !2 = !{!"function_entry_count", i64 1} |
Piotr Padlewski | d9830eb | 2016-09-26 20:37:32 +0000 | [diff] [blame] | 49 | |
| 50 | ; OLD: Index {{.*}} contains 1 nodes (1 functions, 0 alias, 0 globals) and 1 edges (0 refs and 1 calls) |
| 51 | ; OLD-COMBINED: Index {{.*}} contains 2 nodes (2 functions, 0 alias, 0 globals) and 1 edges (0 refs and 1 calls) |