Files
wasmtime/cranelift/filetests/filetests/domtree/loops.clif
Trevor Elliott 8abfe928d6 Reuse the DominatorTree postorder travesal in BlockLoweringOrder (#5843)
* Rework the blockorder module to reuse the dom tree's cfg postorder

* Update domtree tests

* Treat br_table with an empty jump table as multiple block exits

* Bless tests

* Change branch_idx to succ_idx and fix the comment
2023-02-23 22:05:20 +00:00

110 lines
2.4 KiB
Plaintext

test domtree
function %test(i32) {
block0(v0: i32):
brif v0, block2, block1 ; dominates: block1 block2 block3 block4 block5
block1:
jump block3
block2:
brif v0, block5, block4
block3:
jump block4
block4:
brif v0, block5, block3
block5:
brif v0, block6, block4 ; dominates: block6
block6:
return
}
; Fall-through-first, prune-at-source DFT:
;
; block0 {
; block0:brif v0, block1 {
; block0:jump block2 {
; block2 {
; block2:brif v2, block2 -
; block2:brif v3, block1 -
; block2:brif v4, block4 {
; block2: jump block5 {
; block5: jump block6 {
; block6 {}
; }
; }
; block4 {}
; }
; } block2
; }
; block1 {
; block1:jump block3 {
; block3 {}
; }
; } block1
; }
; } block0
;
; check: cfg_postorder:
; sameln: block6
; sameln: block3
; sameln: block4
; sameln: block5
; sameln: block2
; sameln: block1
; sameln: block0
; check: domtree_preorder {
; nextln: block0: block1 block2 block5 block4 block3
; nextln: block1:
; nextln: block2:
; nextln: block5: block6
; nextln: block6:
; nextln: block4:
; nextln: block3:
; nextln: }
function %loop2(i32) system_v {
block0(v0: i32):
brif v0, block2, block1 ; dominates: block2 block1 block3 block4 block5
block1:
jump block3
block2:
brif v0, block5, block4
block3:
jump block4
block4:
brif v0, block8, block3 ; dominates: block8
block8:
brif v0, block5, block6 ; dominates: block6
block5:
brif v0, block9, block4 ; dominates: block9
block9:
trap user0
block6:
jump block7 ; dominates: block7
block7:
return
}
; check: cfg_postorder:
; sameln: block9
; sameln: block7
; sameln: block6
; sameln: block8
; sameln: block3
; sameln: block4
; sameln: block5
; sameln: block2
; sameln: block1
; sameln: block0
; check: domtree_preorder {
; nextln: block0: block1 block2 block5 block4 block3
; nextln: block1:
; nextln: block2:
; nextln: block5: block9
; nextln: block9:
; nextln: block4: block8
; nextln: block8: block6
; nextln: block6: block7
; nextln: block7:
; nextln: block3:
; nextln: }