mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-22 10:42:39 +01:00
[InlineCost] GetElementPtr with constant operands
If the GEP instruction contanins only constants as its arguments, then it should be recognized as a constant. For now, there was also added a flag to turn off this simplification if it causes any regressions ("disable-gep-const-evaluation") which is off by default. Once I gather needed data of the effectiveness of this simplification, the flag will be deleted. Reviewers: apilipenko, davidxl, mtrofin Reviewed By: mtrofin Differential Revision: https://reviews.llvm.org/D81026
This commit is contained in:
parent
0f8b5722e7
commit
056922ee41
@ -110,6 +110,10 @@ static cl::opt<bool> InlineCallerSupersetNoBuiltin(
|
||||
cl::desc("Allow inlining when caller has a superset of callee's nobuiltin "
|
||||
"attributes."));
|
||||
|
||||
static cl::opt<bool> DisableGEPConstOperand(
|
||||
"disable-gep-const-evaluation", cl::Hidden, cl::init(false),
|
||||
cl::desc("Disables evaluation of GetElementPtr with constant operands"));
|
||||
|
||||
namespace {
|
||||
class InlineCostCallAnalyzer;
|
||||
|
||||
@ -1019,6 +1023,16 @@ bool CallAnalyzer::visitGetElementPtr(GetElementPtrInst &I) {
|
||||
return true;
|
||||
};
|
||||
|
||||
if (!DisableGEPConstOperand)
|
||||
if (simplifyInstruction(I, [&](SmallVectorImpl<Constant *> &COps) {
|
||||
SmallVector<Constant *, 2> Indices;
|
||||
for (unsigned int Index = 1 ; Index < COps.size() ; ++Index)
|
||||
Indices.push_back(COps[Index]);
|
||||
return ConstantExpr::getGetElementPtr(I.getSourceElementType(), COps[0],
|
||||
Indices, I.isInBounds());
|
||||
}))
|
||||
return true;
|
||||
|
||||
if ((I.isInBounds() && canFoldInboundsGEP(I)) || IsGEPOffsetConstant(I)) {
|
||||
if (SROAArg)
|
||||
SROAArgValues[&I] = SROAArg;
|
||||
|
15
test/Transforms/Inline/gep_from_constant.ll
Normal file
15
test/Transforms/Inline/gep_from_constant.ll
Normal file
@ -0,0 +1,15 @@
|
||||
; RUN: opt < %s -passes="print<inline-cost>" 2>&1 | FileCheck %s
|
||||
|
||||
; CHECK-LABEL: @foo
|
||||
; CHECK: cost before = {{.*}}, cost after = {{.*}}, threshold before = {{.*}}, threshold after = {{.*}}, cost delta = {{.*}}, simplified to i8 addrspace(1)** getelementptr (i8 addrspace(1)*, i8 addrspace(1)** inttoptr (i64 754974720 to i8 addrspace(1)**), i64 5)
|
||||
|
||||
define i8 addrspace(1)** @foo(i64 %0) {
|
||||
%2 = inttoptr i64 754974720 to i8 addrspace(1)**
|
||||
%3 = getelementptr i8 addrspace(1)*, i8 addrspace(1)** %2, i64 %0
|
||||
ret i8 addrspace(1)** %3
|
||||
}
|
||||
|
||||
define i8 addrspace(1)** @main() {
|
||||
%1 = call i8 addrspace(1)** @foo(i64 5)
|
||||
ret i8 addrspace(1)** %1
|
||||
}
|
Loading…
Reference in New Issue
Block a user