--- /dev/null
+implementation
+
+;; This is an irreducible flow graph
+
+
+void "irreducible"(bool %cond)
+begin
+ br bool %cond, label %X, label %Y
+
+X:
+ br label %Y
+Y:
+ br label %X
+end
+
+;; This is a pair of loops that share the same header
+
+void "sharedheader"(bool %cond)
+begin
+ br label %A
+A:
+ br bool %cond, label %X, label %Y
+
+X:
+ br label %A
+Y:
+ br label %A
+end
+
+;; This is a simple nested loop
+void "nested"(bool %cond1, bool %cond2, bool %cond3)
+begin
+ br label %Loop1
+
+Loop1:
+ br label %Loop2
+
+Loop2:
+ br label %Loop3
+
+Loop3:
+ br bool %cond3, label %Loop3, label %L3Exit
+
+L3Exit:
+ br bool %cond2, label %Loop2, label %L2Exit
+
+L2Exit:
+ br bool %cond1, label %Loop1, label %L1Exit
+
+L1Exit:
+ ret void
+end
+
+++ /dev/null
-implementation
-
-;; This is an irreducible flow graph
-
-void "irreducible"(bool %cond)
-begin
- br bool %cond, label %X, label %Y
-
-X:
- br label %Y
-Y:
- br label %X
-end
-