Mercurial > hg > CbC > CbC_gcc
diff gcc/testsuite/gcc.dg/tree-ssa/ssa-dom-thread-2b.c @ 111:04ced10e8804
gcc 7
author | kono |
---|---|
date | Fri, 27 Oct 2017 22:46:09 +0900 |
parents | |
children |
line wrap: on
line diff
--- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/gcc/testsuite/gcc.dg/tree-ssa/ssa-dom-thread-2b.c Fri Oct 27 22:46:09 2017 +0900 @@ -0,0 +1,29 @@ +/* { dg-do compile } */ +/* { dg-options "-O2 -fdump-tree-thread1-stats -fdump-tree-dom2-stats -fdisable-tree-ethread" } */ + +void foo(); +void bla(); + +/* In the following case, we should be able to thread edge through + the loop header. */ + +void thread_latch_through_header (void) +{ + int i = 0; + int first = 1; + + do + { + if (first) + foo (); + + first = 0; + bla (); + } while (i++ < 100); +} + +/* Threading the latch to a later point in the loop is safe in this + case. And we want to thread through the header as well. These + are both caught by threading in DOM. */ +/* { dg-final { scan-tree-dump-not "Jumps threaded" "dom2"} } */ +/* { dg-final { scan-tree-dump-times "Jumps threaded: 1" 1 "thread1"} } */