summaryrefslogtreecommitdiff
path: root/lib/Analysis/TargetTransformInfo.cpp
diff options
context:
space:
mode:
authorHal Finkel <hfinkel@anl.gov>2013-08-29 03:29:57 +0000
committerHal Finkel <hfinkel@anl.gov>2013-08-29 03:29:57 +0000
commit32f258b96a723b771eb44a2c0689b8bf4dd871ee (patch)
tree0a48bd05ecababcbe58e27cdd0dd15ab16c6f1f4 /lib/Analysis/TargetTransformInfo.cpp
parent253acef7a5ea2fbba7848d2257ae3cce2ea02ce0 (diff)
downloadllvm-32f258b96a723b771eb44a2c0689b8bf4dd871ee.tar.gz
llvm-32f258b96a723b771eb44a2c0689b8bf4dd871ee.tar.bz2
llvm-32f258b96a723b771eb44a2c0689b8bf4dd871ee.tar.xz
Add getUnrollingPreferences to TTI
Allow targets to customize the default behavior of the generic loop unrolling transformation. This will be used by the PowerPC backend when targeting the A2 core (which is in-order with a deep pipeline), and using more aggressive defaults is important. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@189565 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/Analysis/TargetTransformInfo.cpp')
-rw-r--r--lib/Analysis/TargetTransformInfo.cpp9
1 files changed, 9 insertions, 0 deletions
diff --git a/lib/Analysis/TargetTransformInfo.cpp b/lib/Analysis/TargetTransformInfo.cpp
index 8c6005b31c..b587ff27ea 100644
--- a/lib/Analysis/TargetTransformInfo.cpp
+++ b/lib/Analysis/TargetTransformInfo.cpp
@@ -96,6 +96,11 @@ bool TargetTransformInfo::isLoweredToCall(const Function *F) const {
return PrevTTI->isLoweredToCall(F);
}
+bool TargetTransformInfo::getUnrollingPreferences(
+ UnrollingPreferences &UP) const {
+ return PrevTTI->getUnrollingPreferences(UP);
+}
+
bool TargetTransformInfo::isLegalAddImmediate(int64_t Imm) const {
return PrevTTI->isLegalAddImmediate(Imm);
}
@@ -469,6 +474,10 @@ struct NoTTI : ImmutablePass, TargetTransformInfo {
return true;
}
+ virtual bool getUnrollingPreferences(UnrollingPreferences &) const {
+ return false;
+ }
+
bool isLegalAddImmediate(int64_t Imm) const {
return false;
}