llvm-6502/test/Analysis/RegionInfo/two_loops_same_header.ll
Tobias Grosser f96b006367 Add new RegionInfo pass.
The RegionInfo pass detects single entry single exit regions in a function,
where a region is defined as any subgraph that is connected to the remaining
graph at only two spots.
Furthermore an hierarchical region tree is built.
Use it by calling "opt -regions analyze" or "opt -view-regions".

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@109089 91177308-0d34-0410-b5e6-96231b3b80d8
2010-07-22 07:46:31 +00:00

47 lines
1.1 KiB
LLVM

; RUN: opt -regions -analyze < %s | FileCheck %s
; RUN: opt -regions -stats < %s |& FileCheck -check-prefix=STAT %s
; RUN: opt -regions -print-region-style=bb -analyze < %s |& FileCheck -check-prefix=BBIT %s
; RUN: opt -regions -print-region-style=rn -analyze < %s |& FileCheck -check-prefix=RNIT %s
define internal fastcc zeroext i8 @handle_compress() nounwind {
entry:
br label %outer
outer:
br label %body
body:
br i1 1, label %else, label %true77
true77:
br i1 1, label %then83, label %else
then83:
br label %outer
else:
br label %else106
else106:
br i1 1, label %end, label %outer
end:
ret i8 1
}
; CHECK-NOT: =>
; CHECK: [0] entry => <Function Return>
; CHECK-NEXT: [1] outer => end
; CHECK-NEXT: [2] outer => else
; STAT: 3 region - The # of regions
; STAT: 1 region - The # of simple regions
; BBIT: entry, outer, body, else, else106, end, true77, then83,
; BBIT: outer, body, else, else106, true77, then83,
; BBIT: outer, body, true77, then83,
; RNIT: entry, outer => end, end,
; RNIT: outer => else, else, else106,
; RNIT: outer, body, true77, then83,