]> granicus.if.org Git - llvm/commit
[LICM] sink through non-trivially replicable PHI
authorJun Bum Lim <junbuml@codeaurora.org>
Fri, 3 Nov 2017 16:24:53 +0000 (16:24 +0000)
committerJun Bum Lim <junbuml@codeaurora.org>
Fri, 3 Nov 2017 16:24:53 +0000 (16:24 +0000)
commit7c2eb4ec8b267bb3887787bf8e2afe800a72828a
treefffa23974410171ad0032a390baa58dcb026df0d
parentd16b502afd11c5c7f2883da31b63460eea106ae7
[LICM] sink through non-trivially replicable PHI

Summary:
The current LICM allows sinking an instruction only when it is exposed to exit
blocks through a trivially replacable PHI of which all incoming values are the
same instruction. This change enhance LICM to sink a sinkable instruction
through non-trivially replacable PHIs by spliting predecessors of loop
exits.

Reviewers: hfinkel, majnemer, davidxl, bmakam, mcrosier, danielcdh, efriedma, jtony

Reviewed By: efriedma

Subscribers: nemanjai, dberlin, llvm-commits

Differential Revision: https://reviews.llvm.org/D37163

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@317335 91177308-0d34-0410-b5e6-96231b3b80d8
lib/Transforms/Scalar/LICM.cpp
test/CodeGen/PowerPC/subreg-postra-2.ll
test/Transforms/LICM/sinking.ll