diff options
author | Chad Rosier <mcrosier@apple.com> | 2011-07-15 18:25:04 +0000 |
---|---|---|
committer | Chad Rosier <mcrosier@apple.com> | 2011-07-15 18:25:04 +0000 |
commit | 71400b6afa3a650cac0ace1beb24a35518555f56 (patch) | |
tree | 0343a3363d0754d6ea5c7b9cde6ae20001803a2c /lib | |
parent | 167eb1f90392f196a62293bdee68b0d662546e7d (diff) | |
download | external_llvm-71400b6afa3a650cac0ace1beb24a35518555f56.zip external_llvm-71400b6afa3a650cac0ace1beb24a35518555f56.tar.gz external_llvm-71400b6afa3a650cac0ace1beb24a35518555f56.tar.bz2 |
Disable loop idiom recognition of memset/memcpy if the function being compiled
is named after a common idiom (i.e., memset/memcpy). Otherwise, we can run into
infinite recursion. Ideally, the user should use the correct -fno-builtin flag,
but in case they don't we should play nicely.
rdar://9763412
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@135286 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib')
-rw-r--r-- | lib/Transforms/Scalar/LoopIdiomRecognize.cpp | 5 |
1 files changed, 5 insertions, 0 deletions
diff --git a/lib/Transforms/Scalar/LoopIdiomRecognize.cpp b/lib/Transforms/Scalar/LoopIdiomRecognize.cpp index a7bc0e0..a0e41d9 100644 --- a/lib/Transforms/Scalar/LoopIdiomRecognize.cpp +++ b/lib/Transforms/Scalar/LoopIdiomRecognize.cpp @@ -173,6 +173,11 @@ static void deleteIfDeadInstruction(Value *V, ScalarEvolution &SE) { bool LoopIdiomRecognize::runOnLoop(Loop *L, LPPassManager &LPM) { CurLoop = L; + // Disable loop idiom recognition if the function's name is a common idiom. + StringRef Name = L->getHeader()->getParent()->getName(); + if (Name == "memset" || Name == "memcpy") + return false; + // The trip count of the loop must be analyzable. SE = &getAnalysis<ScalarEvolution>(); if (!SE->hasLoopInvariantBackedgeTakenCount(L)) |