mirror of
https://github.com/c64scene-ar/llvm-6502.git
synced 2025-02-01 17:32:36 +00:00
Use TopTTI->getGEPCost from within getUserCost
The implementation of getUserCost had duplicated (and hard-coded) the default logic in getGEPCost. Instead, it is better to use getGEPCost directly, which limits the default logic to the implementation of one function, and allows targets to override the behavior. No functionality change intended. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@205346 91177308-0d34-0410-b5e6-96231b3b80d8
This commit is contained in:
parent
54c55edb0a
commit
a7a02cb737
@ -415,10 +415,10 @@ struct NoTTI final : ImmutablePass, TargetTransformInfo {
|
||||
if (isa<PHINode>(U))
|
||||
return TCC_Free; // Model all PHI nodes as free.
|
||||
|
||||
if (const GEPOperator *GEP = dyn_cast<GEPOperator>(U))
|
||||
// In the basic model we just assume that all-constant GEPs will be
|
||||
// folded into their uses via addressing modes.
|
||||
return GEP->hasAllConstantIndices() ? TCC_Free : TCC_Basic;
|
||||
if (const GEPOperator *GEP = dyn_cast<GEPOperator>(U)) {
|
||||
SmallVector<const Value *, 4> Indices(GEP->idx_begin(), GEP->idx_end());
|
||||
return TopTTI->getGEPCost(GEP->getPointerOperand(), Indices);
|
||||
}
|
||||
|
||||
if (ImmutableCallSite CS = U) {
|
||||
const Function *F = CS.getCalledFunction();
|
||||
|
Loading…
x
Reference in New Issue
Block a user