summaryrefslogtreecommitdiffstats
path: root/llvm/test/Transforms/WholeProgramDevirt/import-indir.ll
diff options
context:
space:
mode:
Diffstat (limited to 'llvm/test/Transforms/WholeProgramDevirt/import-indir.ll')
-rw-r--r--llvm/test/Transforms/WholeProgramDevirt/import-indir.ll108
1 files changed, 0 insertions, 108 deletions
diff --git a/llvm/test/Transforms/WholeProgramDevirt/import-indir.ll b/llvm/test/Transforms/WholeProgramDevirt/import-indir.ll
deleted file mode 100644
index 927ee16b370..00000000000
--- a/llvm/test/Transforms/WholeProgramDevirt/import-indir.ll
+++ /dev/null
@@ -1,108 +0,0 @@
-; Test that we correctly import an indir resolution for type identifier "typeid1".
-; RUN: opt -S -wholeprogramdevirt -wholeprogramdevirt-summary-action=import -wholeprogramdevirt-read-summary=%S/Inputs/import-indir.yaml -wholeprogramdevirt-write-summary=%t < %s | FileCheck %s
-; RUN: FileCheck --check-prefix=SUMMARY %s < %t
-
-; SUMMARY: GlobalValueMap:
-; SUMMARY-NEXT: 42:
-; SUMMARY-NEXT: - Linkage: 0
-; SUMMARY-NEXT: NotEligibleToImport: false
-; SUMMARY-NEXT: Live: true
-; SUMMARY-NEXT: Local: false
-; SUMMARY-NEXT: TypeTestAssumeVCalls:
-; SUMMARY-NEXT: - GUID: 123
-; SUMMARY-NEXT: Offset: 0
-; SUMMARY-NEXT: - GUID: 456
-; SUMMARY-NEXT: Offset: 4
-; SUMMARY-NEXT: TypeCheckedLoadVCalls:
-; SUMMARY-NEXT: - GUID: 789
-; SUMMARY-NEXT: Offset: 8
-; SUMMARY-NEXT: - GUID: 1234
-; SUMMARY-NEXT: Offset: 16
-; SUMMARY-NEXT: TypeTestAssumeConstVCalls:
-; SUMMARY-NEXT: - VFunc:
-; SUMMARY-NEXT: GUID: 123
-; SUMMARY-NEXT: Offset: 4
-; SUMMARY-NEXT: Args: [ 12, 24 ]
-; SUMMARY-NEXT: TypeCheckedLoadConstVCalls:
-; SUMMARY-NEXT: - VFunc:
-; SUMMARY-NEXT: GUID: 456
-; SUMMARY-NEXT: Offset: 8
-; SUMMARY-NEXT: Args: [ 24, 12 ]
-; SUMMARY-NEXT: TypeIdMap:
-; SUMMARY-NEXT: typeid1:
-; SUMMARY-NEXT: TTRes:
-; SUMMARY-NEXT: Kind: Unsat
-; SUMMARY-NEXT: SizeM1BitWidth: 0
-; SUMMARY-NEXT: AlignLog2: 0
-; SUMMARY-NEXT: SizeM1: 0
-; SUMMARY-NEXT: BitMask: 0
-; SUMMARY-NEXT: InlineBits: 0
-; SUMMARY-NEXT: WPDRes:
-; SUMMARY-NEXT: 0:
-; SUMMARY-NEXT: Kind: Indir
-; SUMMARY-NEXT: SingleImplName: ''
-; SUMMARY-NEXT: ResByArg:
-; SUMMARY-NEXT: 4:
-; SUMMARY-NEXT: Kind: Indir
-; SUMMARY-NEXT: SingleImplName: ''
-; SUMMARY-NEXT: ResByArg:
-; SUMMARY-NEXT: :
-; SUMMARY-NEXT: Kind: UniformRetVal
-; SUMMARY-NEXT: Info: 12
-; SUMMARY-NEXT: Byte: 0
-; SUMMARY-NEXT: Bit: 0
-; SUMMARY-NEXT: 12:
-; SUMMARY-NEXT: Kind: UniformRetVal
-; SUMMARY-NEXT: Info: 24
-; SUMMARY-NEXT: Byte: 0
-; SUMMARY-NEXT: Bit: 0
-; SUMMARY-NEXT: 12,24:
-; SUMMARY-NEXT: Kind: UniformRetVal
-; SUMMARY-NEXT: Info: 48
-; SUMMARY-NEXT: Byte: 0
-; SUMMARY-NEXT: Bit: 0
-
-target datalayout = "e-p:32:32"
-
-declare void @llvm.assume(i1)
-declare void @llvm.trap()
-declare {i8*, i1} @llvm.type.checked.load(i8*, i32, metadata)
-declare i1 @llvm.type.test(i8*, metadata)
-
-; CHECK: define i1 @f1
-define i1 @f1(i8* %obj) {
- %vtableptr = bitcast i8* %obj to [1 x i8*]**
- %vtable = load [1 x i8*]*, [1 x i8*]** %vtableptr
- %vtablei8 = bitcast [1 x i8*]* %vtable to i8*
- %p = call i1 @llvm.type.test(i8* %vtablei8, metadata !"typeid1")
- call void @llvm.assume(i1 %p)
- %fptrptr = getelementptr [1 x i8*], [1 x i8*]* %vtable, i32 0, i32 0
- %fptr = load i8*, i8** %fptrptr
- %fptr_casted = bitcast i8* %fptr to i1 (i8*, i32)*
- ; CHECK: call i1 %
- %result = call i1 %fptr_casted(i8* %obj, i32 5)
- ret i1 %result
-}
-
-; CHECK: define i1 @f2
-define i1 @f2(i8* %obj) {
- %vtableptr = bitcast i8* %obj to [1 x i8*]**
- %vtable = load [1 x i8*]*, [1 x i8*]** %vtableptr
- %vtablei8 = bitcast [1 x i8*]* %vtable to i8*
- %pair = call {i8*, i1} @llvm.type.checked.load(i8* %vtablei8, i32 4, metadata !"typeid1")
- %fptr = extractvalue {i8*, i1} %pair, 0
- %p = extractvalue {i8*, i1} %pair, 1
- ; CHECK: [[P:%.*]] = call i1 @llvm.type.test
- ; CHECK: br i1 [[P]]
- br i1 %p, label %cont, label %trap
-
-cont:
- %fptr_casted = bitcast i8* %fptr to i1 (i8*, i32)*
- ; CHECK: call i1 %
- %result = call i1 %fptr_casted(i8* %obj, i32 undef)
- ret i1 %result
-
-trap:
- call void @llvm.trap()
- unreachable
-}
OpenPOWER on IntegriCloud