summaryrefslogtreecommitdiffstats
path: root/libcxx/test/std/utilities/function.objects/func.wrap/func.wrap.func/func.wrap.func.con/F.pass.cpp
diff options
context:
space:
mode:
authorBruno Cardoso Lopes <bruno.cardoso@gmail.com>2014-12-22 22:35:46 +0000
committerBruno Cardoso Lopes <bruno.cardoso@gmail.com>2014-12-22 22:35:46 +0000
commitbad65c3b708accec8c6e85346dabc7967cb3d7ca (patch)
tree859975d0c73e10979f445919d266492d4b42617d /libcxx/test/std/utilities/function.objects/func.wrap/func.wrap.func/func.wrap.func.con/F.pass.cpp
parenta47ace59019721411307ab06eea5b7796cb3dd3e (diff)
downloadbcm5719-llvm-bad65c3b708accec8c6e85346dabc7967cb3d7ca.tar.gz
bcm5719-llvm-bad65c3b708accec8c6e85346dabc7967cb3d7ca.zip
[LCSSA] Handle PHI insertion in disjoint loops
Take two disjoint Loops L1 and L2. LoopSimplify fails to simplify some loops (e.g. when indirect branches are involved). In such situations, it can happen that an exit for L1 is the header of L2. Thus, when we create PHIs in one of such exits we are also inserting PHIs in L2 header. This could break LCSSA form for L2 because these inserted PHIs can also have uses in L2 exits, which are never handled in the current implementation. Provide a fix for this corner case and test that we don't assert/crash on that. Differential Revision: http://reviews.llvm.org/D6624 rdar://problem/19166231 llvm-svn: 224740
Diffstat (limited to 'libcxx/test/std/utilities/function.objects/func.wrap/func.wrap.func/func.wrap.func.con/F.pass.cpp')
0 files changed, 0 insertions, 0 deletions
OpenPOWER on IntegriCloud