diff options
| author | Chris Lattner <sabre@nondot.org> | 2010-12-19 05:57:25 +0000 |
|---|---|---|
| committer | Chris Lattner <sabre@nondot.org> | 2010-12-19 05:57:25 +0000 |
| commit | 408a684d295b63f398dd92d948ee42c180ad7d1a (patch) | |
| tree | 5e1c514a95f00fb40aa1a5ce503ff97830f278a8 /llvm/lib/Transforms | |
| parent | 3337a81450a943f35e5edc7c1e2d413890b76d80 (diff) | |
| download | bcm5719-llvm-408a684d295b63f398dd92d948ee42c180ad7d1a.tar.gz bcm5719-llvm-408a684d295b63f398dd92d948ee42c180ad7d1a.zip | |
Enhance LICM to promote alias sets whose pointers themselves are stored,
which doesn't affect the memory address being promoted.
llvm-svn: 122172
Diffstat (limited to 'llvm/lib/Transforms')
| -rw-r--r-- | llvm/lib/Transforms/Scalar/LICM.cpp | 5 |
1 files changed, 4 insertions, 1 deletions
diff --git a/llvm/lib/Transforms/Scalar/LICM.cpp b/llvm/lib/Transforms/Scalar/LICM.cpp index 46fffccb3ac..6d5b24a01b2 100644 --- a/llvm/lib/Transforms/Scalar/LICM.cpp +++ b/llvm/lib/Transforms/Scalar/LICM.cpp @@ -691,7 +691,10 @@ void LICM::PromoteAliasSet(AliasSet &AS) { if (isa<LoadInst>(Use)) assert(!cast<LoadInst>(Use)->isVolatile() && "AST broken"); else if (isa<StoreInst>(Use)) { - if (Use->getOperand(0) == ASIV) return; + // Stores *of* the pointer are not interesting, only stores *to* the + // pointer. + if (Use->getOperand(1) != ASIV) + continue; assert(!cast<StoreInst>(Use)->isVolatile() && "AST broken"); } else return; // Not a load or store. |

