2016-05-10 21:48:23 +08:00
|
|
|
; RUN: opt -module-summary %s -o %t1.bc
|
|
|
|
; RUN: opt -module-summary %p/Inputs/distributed_indexes.ll -o %t2.bc
|
|
|
|
; RUN: llvm-lto -thinlto-action=thinlink -o %t.index.bc %t1.bc %t2.bc
|
|
|
|
; RUN: llvm-lto -thinlto-action=distributedindexes -thinlto-index %t.index.bc %t1.bc %t2.bc
|
|
|
|
; RUN: llvm-bcanalyzer -dump %t1.bc.thinlto.bc | FileCheck %s --check-prefix=BACKEND1
|
|
|
|
; RUN: llvm-bcanalyzer -dump %t2.bc.thinlto.bc | FileCheck %s --check-prefix=BACKEND2
|
|
|
|
|
|
|
|
; The backend index for this module contains summaries from itself and
|
|
|
|
; Inputs/distributed_indexes.ll, as it imports from the latter.
|
2017-12-16 08:18:12 +08:00
|
|
|
; We should import @g and alias @analias. While we don't import the aliasee
|
|
|
|
; directly (and therefore don't have a third COMBINED record from module
|
|
|
|
; id 1), we will have a VALUE_GUID for it (hence the 4 VALUE_GUID entries).
|
2016-05-10 21:48:23 +08:00
|
|
|
; BACKEND1: <MODULE_STRTAB_BLOCK
|
|
|
|
; BACKEND1-NEXT: <ENTRY {{.*}} record string = '{{.*}}distributed_indexes.ll.tmp{{.*}}.bc'
|
|
|
|
; BACKEND1-NEXT: <ENTRY {{.*}} record string = '{{.*}}distributed_indexes.ll.tmp{{.*}}.bc'
|
|
|
|
; BACKEND1-NEXT: </MODULE_STRTAB_BLOCK
|
|
|
|
; BACKEND1-NEXT: <GLOBALVAL_SUMMARY_BLOCK
|
|
|
|
; BACKEND1-NEXT: <VERSION
|
2017-12-19 02:00:32 +08:00
|
|
|
; BACKEND1-DAG: <VALUE_GUID op0={{.*}} op1=-5751648690987223394
|
|
|
|
; BACKEND1-DAG: <VALUE_GUID op0={{.*}} op1=-5300342847281564238
|
|
|
|
; BACKEND1-DAG: <VALUE_GUID op0={{.*}} op1=-3706093650706652785
|
|
|
|
; BACKEND1-DAG: <VALUE_GUID op0={{.*}} op1=-1039159065113703048
|
2017-12-16 08:18:12 +08:00
|
|
|
; BACKEND1-DAG: <COMBINED {{.*}} op1=0
|
|
|
|
; BACKEND1-DAG: <COMBINED {{.*}} op1=1
|
|
|
|
; BACKEND1-DAG: <COMBINED_ALIAS {{.*}} op1=1
|
2016-05-10 21:48:23 +08:00
|
|
|
; BACKEND1-NEXT: </GLOBALVAL_SUMMARY_BLOCK
|
|
|
|
|
|
|
|
; The backend index for Input/distributed_indexes.ll contains summaries from
|
|
|
|
; itself only, as it does not import anything.
|
|
|
|
; BACKEND2: <MODULE_STRTAB_BLOCK
|
|
|
|
; BACKEND2-NEXT: <ENTRY {{.*}} record string = '{{.*}}distributed_indexes.ll.tmp2.bc'
|
|
|
|
; BACKEND2-NEXT: </MODULE_STRTAB_BLOCK
|
|
|
|
; BACKEND2-NEXT: <GLOBALVAL_SUMMARY_BLOCK
|
|
|
|
; BACKEND2-NEXT: <VERSION
|
2017-12-19 02:00:32 +08:00
|
|
|
; BACKEND2-DAG: <VALUE_GUID op0={{.*}} op1=-5751648690987223394/>
|
|
|
|
; BACKEND2-DAG: <VALUE_GUID op0={{.*}} op1=-5300342847281564238/>
|
|
|
|
; BACKEND2-DAG: <VALUE_GUID op0={{.*}} op1=-1039159065113703048/>
|
2016-05-10 21:48:23 +08:00
|
|
|
; BACKEND2-NEXT: <COMBINED
|
2017-12-16 08:18:12 +08:00
|
|
|
; BACKEND2-NEXT: <COMBINED
|
|
|
|
; BACKEND2-NEXT: <COMBINED_ALIAS
|
2016-05-10 21:48:23 +08:00
|
|
|
; BACKEND2-NEXT: </GLOBALVAL_SUMMARY_BLOCK
|
|
|
|
|
|
|
|
declare void @g(...)
|
2017-12-16 08:18:12 +08:00
|
|
|
declare void @analias(...)
|
2016-05-10 21:48:23 +08:00
|
|
|
|
|
|
|
define void @f() {
|
|
|
|
entry:
|
|
|
|
call void (...) @g()
|
2017-12-16 08:18:12 +08:00
|
|
|
call void (...) @analias()
|
2016-05-10 21:48:23 +08:00
|
|
|
ret void
|
|
|
|
}
|