diff options
author | Chandler Carruth <chandlerc@gmail.com> | 2015-01-31 11:17:59 +0000 |
---|---|---|
committer | Chandler Carruth <chandlerc@gmail.com> | 2015-01-31 11:17:59 +0000 |
commit | 93dcdc47db64b1674996d555786230873c83bdde (patch) | |
tree | ea487af3bf71bde23ad90436b32a0c4a9c8d3191 /llvm/lib/Target/R600/AMDGPUTargetTransformInfo.cpp | |
parent | 9559a5c05e1fab06c7493eb34dd37cf06cb353d8 (diff) | |
download | bcm5719-llvm-93dcdc47db64b1674996d555786230873c83bdde.tar.gz bcm5719-llvm-93dcdc47db64b1674996d555786230873c83bdde.zip |
[PM] Switch the TargetMachine interface from accepting a pass manager
base which it adds a single analysis pass to, to instead return the type
erased TargetTransformInfo object constructed for that TargetMachine.
This removes all of the pass variants for TTI. There is now a single TTI
*pass* in the Analysis layer. All of the Analysis <-> Target
communication is through the TTI's type erased interface itself. While
the diff is large here, it is nothing more that code motion to make
types available in a header file for use in a different source file
within each target.
I've tried to keep all the doxygen comments and file boilerplate in line
with this move, but let me know if I missed anything.
With this in place, the next step to making TTI work with the new pass
manager is to introduce a really simple new-style analysis that produces
a TTI object via a callback into this routine on the target machine.
Once we have that, we'll have the building blocks necessary to accept
a function argument as well.
llvm-svn: 227685
Diffstat (limited to 'llvm/lib/Target/R600/AMDGPUTargetTransformInfo.cpp')
-rw-r--r-- | llvm/lib/Target/R600/AMDGPUTargetTransformInfo.cpp | 53 |
1 files changed, 1 insertions, 52 deletions
diff --git a/llvm/lib/Target/R600/AMDGPUTargetTransformInfo.cpp b/llvm/lib/Target/R600/AMDGPUTargetTransformInfo.cpp index 132765ab9b0..be7b2f42971 100644 --- a/llvm/lib/Target/R600/AMDGPUTargetTransformInfo.cpp +++ b/llvm/lib/Target/R600/AMDGPUTargetTransformInfo.cpp @@ -15,8 +15,7 @@ // //===----------------------------------------------------------------------===// -#include "AMDGPU.h" -#include "AMDGPUTargetMachine.h" +#include "AMDGPUTargetTransformInfo.h" #include "llvm/Analysis/LoopInfo.h" #include "llvm/Analysis/TargetTransformInfo.h" #include "llvm/Analysis/ValueTracking.h" @@ -28,56 +27,6 @@ using namespace llvm; #define DEBUG_TYPE "AMDGPUtti" -namespace { - -class AMDGPUTTIImpl : public BasicTTIImplBase<AMDGPUTTIImpl> { - typedef BasicTTIImplBase<AMDGPUTTIImpl> BaseT; - typedef TargetTransformInfo TTI; - - const AMDGPUSubtarget *ST; - -public: - explicit AMDGPUTTIImpl(const AMDGPUTargetMachine *TM = nullptr) - : BaseT(TM), ST(TM->getSubtargetImpl()) {} - - // Provide value semantics. MSVC requires that we spell all of these out. - AMDGPUTTIImpl(const AMDGPUTTIImpl &Arg) - : BaseT(static_cast<const BaseT &>(Arg)), ST(Arg.ST) {} - AMDGPUTTIImpl(AMDGPUTTIImpl &&Arg) - : BaseT(std::move(static_cast<BaseT &>(Arg))), ST(std::move(Arg.ST)) {} - AMDGPUTTIImpl &operator=(const AMDGPUTTIImpl &RHS) { - BaseT::operator=(static_cast<const BaseT &>(RHS)); - ST = RHS.ST; - return *this; - } - AMDGPUTTIImpl &operator=(AMDGPUTTIImpl &&RHS) { - BaseT::operator=(std::move(static_cast<BaseT &>(RHS))); - ST = std::move(RHS.ST); - return *this; - } - - bool hasBranchDivergence() { return true; } - - void getUnrollingPreferences(const Function *F, Loop *L, - TTI::UnrollingPreferences &UP); - - TTI::PopcntSupportKind getPopcntSupport(unsigned TyWidth) { - assert(isPowerOf2_32(TyWidth) && "Ty width must be power of 2"); - return ST->hasBCNT(TyWidth) ? TTI::PSK_FastHardware : TTI::PSK_Software; - } - - unsigned getNumberOfRegisters(bool Vector); - unsigned getRegisterBitWidth(bool Vector); - unsigned getMaxInterleaveFactor(); -}; - -} // end anonymous namespace - -ImmutablePass * -llvm::createAMDGPUTargetTransformInfoPass(const AMDGPUTargetMachine *TM) { - return new TargetTransformInfoWrapperPass(AMDGPUTTIImpl(TM)); -} - void AMDGPUTTIImpl::getUnrollingPreferences(const Function *, Loop *L, TTI::UnrollingPreferences &UP) { UP.Threshold = 300; // Twice the default. |