diff options
Diffstat (limited to 'llvm/lib/Target/PowerPC/PPCTargetTransformInfo.cpp')
| -rw-r--r-- | llvm/lib/Target/PowerPC/PPCTargetTransformInfo.cpp | 12 | 
1 files changed, 7 insertions, 5 deletions
| diff --git a/llvm/lib/Target/PowerPC/PPCTargetTransformInfo.cpp b/llvm/lib/Target/PowerPC/PPCTargetTransformInfo.cpp index 0cb88c111bf..37624ed93d3 100644 --- a/llvm/lib/Target/PowerPC/PPCTargetTransformInfo.cpp +++ b/llvm/lib/Target/PowerPC/PPCTargetTransformInfo.cpp @@ -38,6 +38,7 @@ void initializePPCTTIPass(PassRegistry &);  namespace {  class PPCTTI final : public ImmutablePass, public TargetTransformInfo { +  const TargetMachine *TM;    const PPCSubtarget *ST;    const PPCTargetLowering *TLI; @@ -47,7 +48,7 @@ public:    }    PPCTTI(const PPCTargetMachine *TM) -      : ImmutablePass(ID), ST(TM->getSubtargetImpl()), +      : ImmutablePass(ID), TM(TM), ST(TM->getSubtargetImpl()),          TLI(TM->getSubtargetImpl()->getTargetLowering()) {      initializePPCTTIPass(*PassRegistry::getPassRegistry());    } @@ -80,8 +81,8 @@ public:                           Type *Ty) const override;    PopcntSupportKind getPopcntSupport(unsigned TyWidth) const override; -  void getUnrollingPreferences( -    Loop *L, UnrollingPreferences &UP) const override; +  void getUnrollingPreferences(const Function *F, Loop *L, +                               UnrollingPreferences &UP) const override;    /// @} @@ -269,8 +270,9 @@ unsigned PPCTTI::getIntImmCost(unsigned Opcode, unsigned Idx, const APInt &Imm,    return PPCTTI::getIntImmCost(Imm, Ty);  } -void PPCTTI::getUnrollingPreferences(Loop *L, UnrollingPreferences &UP) const { -  if (ST->getDarwinDirective() == PPC::DIR_A2) { +void PPCTTI::getUnrollingPreferences(const Function *F, Loop *L, +                                     UnrollingPreferences &UP) const { +  if (TM->getSubtarget<PPCSubtarget>(F).getDarwinDirective() == PPC::DIR_A2) {      // The A2 is in-order with a deep pipeline, and concatenation unrolling      // helps expose latency-hiding opportunities to the instruction scheduler.      UP.Partial = UP.Runtime = true; | 

