summaryrefslogtreecommitdiffstats
path: root/llvm/test/Transforms/LoopStrengthReduce/pr2537.ll
diff options
context:
space:
mode:
authorJingyue Wu <jingyue@google.com>2015-07-28 18:22:40 +0000
committerJingyue Wu <jingyue@google.com>2015-07-28 18:22:40 +0000
commit42f1d67a45f3762ee7a5ffd9f1511b9314602fcc (patch)
treea1ae5444da994a2e0ba39be1abef9af0a476a726 /llvm/test/Transforms/LoopStrengthReduce/pr2537.ll
parent916cea5682a468db21b2872c31b5bef87bb67f17 (diff)
downloadbcm5719-llvm-42f1d67a45f3762ee7a5ffd9f1511b9314602fcc.tar.gz
bcm5719-llvm-42f1d67a45f3762ee7a5ffd9f1511b9314602fcc.zip
[SCEV] Apply NSW and NUW flags via poison value analysis
Summary: Make Scalar Evolution able to propagate NSW and NUW flags from instructions to SCEVs in some cases. This is based on reasoning about when poison from instructions with these flags would trigger undefined behavior. This gives a 13% speed-up on some Eigen3-based Google-internal microbenchmarks for NVPTX. There does not seem to be clear agreement about when poison should be considered to propagate through instructions. In this analysis, poison propagates only in cases where that should be uncontroversial. This change makes LSR able to create induction variables for expressions like &ptr[i + offset] for loops like this: for (int i = 0; i < limit; ++i) { sum += ptr[i + offset]; } Here ptr is a 64 bit pointer and offset is a 32 bit integer. For NVPTX, LSR currently creates an induction variable for i + offset instead, which is not as fast. Improving this situation is what brings the 13% speed-up on some Eigen3-based Google-internal microbenchmarks for NVPTX. There are more details in this discussion on llvmdev. June: http://lists.cs.uiuc.edu/pipermail/llvmdev/2015-June/thread.html#87234 July: http://lists.cs.uiuc.edu/pipermail/llvmdev/2015-July/thread.html#87392 Patch by Bjarke Roune Reviewers: eliben, atrick, sanjoy Subscribers: majnemer, hfinkel, jingyue, meheff, llvm-commits Differential Revision: http://reviews.llvm.org/D11212 llvm-svn: 243460
Diffstat (limited to 'llvm/test/Transforms/LoopStrengthReduce/pr2537.ll')
0 files changed, 0 insertions, 0 deletions
OpenPOWER on IntegriCloud