forked from OSchip/llvm-project
5db6ffd76f
BeforeBB | v GuardBB / \ __ PreHeaderBB \ / \ / | latch HeaderBB | \ / \ / < \ / \ / ExitBB This does not only remove the need for an explicit loop rotate pass, but it also gives us the possibility to skip the construction of the guard condition in case the loop is known to be executed at least once. We do not yet exploit this, but by implementing this analysis in the isl code generator we should be able to remove more guards than the generic loop rotate pass can. Another point is that loop rotation can introduce additional PHI nodes, which may hide that a loop can be executed in parallel. This change avoids this complication and will make it easier to move the openmp code generation into a separate pass. llvm-svn: 181986 |
||
---|---|---|
.. | ||
codegen_constant_offset.ll | ||
codegen_constant_offset___%for.cond---%for.end.jscop | ||
codegen_constant_offset___%for.cond---%for.end.jscop.transformed | ||
codegen_simple.ll | ||
codegen_simple___%for.cond---%for.end.jscop | ||
codegen_simple___%for.cond---%for.end.jscop.transformed | ||
codegen_simple_md.ll | ||
codegen_simple_md___%for.cond---%for.end6.jscop | ||
codegen_simple_md___%for.cond---%for.end6.jscop.transformed+withconst | ||
codegen_simple_md___%for.cond---%for.end6.jscop.transformed+withoutconst | ||
simple.ll | ||
simple___%for.cond---%for.end.jscop | ||
simple___%for.cond---%for.end.jscop.transformed | ||
simple___%for.cond4---%for.end14.jscop | ||
simple___%for.cond4---%for.end14.jscop.transformed | ||
simple_analyze.ll |