forked from OSchip/llvm-project
WholeProgramDevirt: Implement importing for uniform ret val opt.
Differential Revision: https://reviews.llvm.org/D29854 llvm-svn: 297350
This commit is contained in:
parent
3f57cff1e8
commit
0152c8156b
|
@ -1126,6 +1126,24 @@ void DevirtModule::importResolution(VTableSlot Slot, VTableSlotInfo &SlotInfo) {
|
||||||
applySingleImplDevirt(SlotInfo, SingleImpl, IsExported);
|
applySingleImplDevirt(SlotInfo, SingleImpl, IsExported);
|
||||||
assert(!IsExported);
|
assert(!IsExported);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
for (auto &CSByConstantArg : SlotInfo.ConstCSInfo) {
|
||||||
|
auto I = Res.ResByArg.find(CSByConstantArg.first);
|
||||||
|
if (I == Res.ResByArg.end())
|
||||||
|
continue;
|
||||||
|
auto &ResByArg = I->second;
|
||||||
|
// FIXME: We should figure out what to do about the "function name" argument
|
||||||
|
// to the apply* functions, as the function names are unavailable during the
|
||||||
|
// importing phase. For now we just pass the empty string. This does not
|
||||||
|
// impact correctness because the function names are just used for remarks.
|
||||||
|
switch (ResByArg.TheKind) {
|
||||||
|
case WholeProgramDevirtResolution::ByArg::UniformRetVal:
|
||||||
|
applyUniformRetValOpt(CSByConstantArg.second, "", ResByArg.Info);
|
||||||
|
break;
|
||||||
|
default:
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void DevirtModule::removeRedundantTypeTests() {
|
void DevirtModule::removeRedundantTypeTests() {
|
||||||
|
|
|
@ -0,0 +1,19 @@
|
||||||
|
---
|
||||||
|
TypeIdMap:
|
||||||
|
typeid1:
|
||||||
|
WPDRes:
|
||||||
|
0:
|
||||||
|
Kind: Indir
|
||||||
|
ResByArg:
|
||||||
|
1:
|
||||||
|
Kind: UniformRetVal
|
||||||
|
Info: 42
|
||||||
|
typeid2:
|
||||||
|
WPDRes:
|
||||||
|
8:
|
||||||
|
Kind: Indir
|
||||||
|
ResByArg:
|
||||||
|
1:
|
||||||
|
Kind: UniformRetVal
|
||||||
|
Info: 42
|
||||||
|
...
|
|
@ -1,8 +1,12 @@
|
||||||
; RUN: opt -S -wholeprogramdevirt -wholeprogramdevirt-summary-action=import -wholeprogramdevirt-read-summary=%S/Inputs/import-single-impl.yaml < %s | FileCheck --check-prefixes=CHECK,SINGLE-IMPL %s
|
; RUN: opt -S -wholeprogramdevirt -wholeprogramdevirt-summary-action=import -wholeprogramdevirt-read-summary=%S/Inputs/import-single-impl.yaml < %s | FileCheck --check-prefixes=CHECK,SINGLE-IMPL %s
|
||||||
|
; RUN: opt -S -wholeprogramdevirt -wholeprogramdevirt-summary-action=import -wholeprogramdevirt-read-summary=%S/Inputs/import-uniform-ret-val.yaml < %s | FileCheck --check-prefixes=CHECK,UNIFORM-RET-VAL %s
|
||||||
|
|
||||||
target datalayout = "e-p:64:64"
|
target datalayout = "e-p:64:64"
|
||||||
target triple = "x86_64-unknown-linux-gnu"
|
target triple = "x86_64-unknown-linux-gnu"
|
||||||
|
|
||||||
|
; Test cases where the argument values are known and we can apply virtual
|
||||||
|
; constant propagation.
|
||||||
|
|
||||||
; CHECK: define i32 @call1
|
; CHECK: define i32 @call1
|
||||||
define i32 @call1(i8* %obj) {
|
define i32 @call1(i8* %obj) {
|
||||||
%vtableptr = bitcast i8* %obj to [3 x i8*]**
|
%vtableptr = bitcast i8* %obj to [3 x i8*]**
|
||||||
|
@ -15,9 +19,13 @@ define i32 @call1(i8* %obj) {
|
||||||
%fptr_casted = bitcast i8* %fptr to i32 (i8*, i32)*
|
%fptr_casted = bitcast i8* %fptr to i32 (i8*, i32)*
|
||||||
; SINGLE-IMPL: call i32 bitcast (void ()* @singleimpl1 to i32 (i8*, i32)*)
|
; SINGLE-IMPL: call i32 bitcast (void ()* @singleimpl1 to i32 (i8*, i32)*)
|
||||||
%result = call i32 %fptr_casted(i8* %obj, i32 1)
|
%result = call i32 %fptr_casted(i8* %obj, i32 1)
|
||||||
|
; UNIFORM-RET-VAL: ret i32 42
|
||||||
ret i32 %result
|
ret i32 %result
|
||||||
}
|
}
|
||||||
|
|
||||||
|
; Test cases where the argument values are unknown, so we cannot apply virtual
|
||||||
|
; constant propagation.
|
||||||
|
|
||||||
; CHECK: define i1 @call2
|
; CHECK: define i1 @call2
|
||||||
define i1 @call2(i8* %obj) {
|
define i1 @call2(i8* %obj) {
|
||||||
%vtableptr = bitcast i8* %obj to [1 x i8*]**
|
%vtableptr = bitcast i8* %obj to [1 x i8*]**
|
||||||
|
@ -32,6 +40,7 @@ define i1 @call2(i8* %obj) {
|
||||||
cont:
|
cont:
|
||||||
%fptr_casted = bitcast i8* %fptr to i1 (i8*, i32)*
|
%fptr_casted = bitcast i8* %fptr to i1 (i8*, i32)*
|
||||||
; SINGLE-IMPL: call i1 bitcast (void ()* @singleimpl2 to i1 (i8*, i32)*)
|
; SINGLE-IMPL: call i1 bitcast (void ()* @singleimpl2 to i1 (i8*, i32)*)
|
||||||
|
; UNIFORM-RET-VAL: call i1 %
|
||||||
%result = call i1 %fptr_casted(i8* %obj, i32 undef)
|
%result = call i1 %fptr_casted(i8* %obj, i32 undef)
|
||||||
ret i1 %result
|
ret i1 %result
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue