mirror of
https://github.com/kmc7468/cs420.git
synced 2025-12-14 22:38:46 +00:00
Bump
This commit is contained in:
18
examples/c/switch-in-loop.c
Normal file
18
examples/c/switch-in-loop.c
Normal file
@@ -0,0 +1,18 @@
|
||||
int main() {
|
||||
int i = 0;
|
||||
int c = 0;
|
||||
while (i < 10) {
|
||||
i++;
|
||||
switch (i) {
|
||||
case (1): {
|
||||
continue;
|
||||
break;
|
||||
}
|
||||
default: {
|
||||
break;
|
||||
}
|
||||
}
|
||||
c++;
|
||||
}
|
||||
return c;
|
||||
}
|
||||
49
examples/ir0/switch-in-loop.ir
Normal file
49
examples/ir0/switch-in-loop.ir
Normal file
@@ -0,0 +1,49 @@
|
||||
|
||||
fun i32 @main () {
|
||||
init:
|
||||
bid: b0
|
||||
allocations:
|
||||
%l0:i32:i
|
||||
%l1:i32:c
|
||||
|
||||
block b0:
|
||||
%b0:i0:unit = store 0:i32 %l0:i32*
|
||||
%b0:i1:unit = store 0:i32 %l1:i32*
|
||||
j b1()
|
||||
|
||||
block b1:
|
||||
%b1:i0:i32 = load %l0:i32*
|
||||
%b1:i1:u1 = cmp lt %b1:i0:i32 10:i32
|
||||
br %b1:i1:u1, b2(), b3()
|
||||
|
||||
block b2:
|
||||
%b2:i0:i32 = load %l0:i32*
|
||||
%b2:i1:i32 = add %b2:i0:i32 1:i32
|
||||
%b2:i2:unit = store %b2:i1:i32 %l0:i32*
|
||||
%b2:i3:i32 = load %l0:i32*
|
||||
switch %b2:i3:i32 default b7() [
|
||||
1:i32 b5()
|
||||
]
|
||||
|
||||
block b3:
|
||||
%b3:i0:i32 = load %l1:i32*
|
||||
ret %b3:i0:i32
|
||||
|
||||
block b4:
|
||||
%b4:i0:i32 = load %l1:i32*
|
||||
%b4:i1:i32 = add %b4:i0:i32 1:i32
|
||||
%b4:i2:unit = store %b4:i1:i32 %l1:i32*
|
||||
j b1()
|
||||
|
||||
block b5:
|
||||
j b1()
|
||||
|
||||
block b6:
|
||||
j b4()
|
||||
|
||||
block b7:
|
||||
j b4()
|
||||
|
||||
block b8:
|
||||
ret 0:i32
|
||||
}
|
||||
37
examples/ir1/switch-in-loop.ir
Normal file
37
examples/ir1/switch-in-loop.ir
Normal file
@@ -0,0 +1,37 @@
|
||||
|
||||
fun i32 @main () {
|
||||
init:
|
||||
bid: b0
|
||||
allocations:
|
||||
%l0:i32:i
|
||||
%l1:i32:c
|
||||
|
||||
block b0:
|
||||
%b0:i0:unit = store 0:i32 %l0:i32*
|
||||
%b0:i1:unit = store 0:i32 %l1:i32*
|
||||
j b1()
|
||||
|
||||
block b1:
|
||||
%b1:i0:i32 = load %l0:i32*
|
||||
%b1:i1:u1 = cmp lt %b1:i0:i32 10:i32
|
||||
br %b1:i1:u1, b2(), b3()
|
||||
|
||||
block b2:
|
||||
%b2:i0:i32 = load %l0:i32*
|
||||
%b2:i1:i32 = add %b2:i0:i32 1:i32
|
||||
%b2:i2:unit = store %b2:i1:i32 %l0:i32*
|
||||
%b2:i3:i32 = load %l0:i32*
|
||||
switch %b2:i3:i32 default b7() [
|
||||
1:i32 b1()
|
||||
]
|
||||
|
||||
block b3:
|
||||
%b3:i0:i32 = load %l1:i32*
|
||||
ret %b3:i0:i32
|
||||
|
||||
block b7:
|
||||
%b7:i0:i32 = load %l1:i32*
|
||||
%b7:i1:i32 = add %b7:i0:i32 1:i32
|
||||
%b7:i2:unit = store %b7:i1:i32 %l1:i32*
|
||||
j b1()
|
||||
}
|
||||
39
examples/ir2/switch-in-loop.ir
Normal file
39
examples/ir2/switch-in-loop.ir
Normal file
@@ -0,0 +1,39 @@
|
||||
|
||||
fun i32 @main () {
|
||||
init:
|
||||
bid: b0
|
||||
allocations:
|
||||
%l0:i32:i
|
||||
%l1:i32:c
|
||||
|
||||
block b0:
|
||||
%b0:i0:unit = nop
|
||||
%b0:i1:unit = nop
|
||||
j b1(0:i32, 0:i32)
|
||||
|
||||
block b1:
|
||||
%b1:p0:i32:i
|
||||
%b1:p1:i32:c
|
||||
%b1:i0:unit = nop
|
||||
%b1:i1:u1 = cmp lt %b1:p0:i32 10:i32
|
||||
br %b1:i1:u1, b2(), b3()
|
||||
|
||||
block b2:
|
||||
%b2:i0:unit = nop
|
||||
%b2:i1:i32 = add %b1:p0:i32 1:i32
|
||||
%b2:i2:unit = nop
|
||||
%b2:i3:unit = nop
|
||||
switch %b2:i1:i32 default b7() [
|
||||
1:i32 b1(%b2:i1:i32, %b1:p1:i32)
|
||||
]
|
||||
|
||||
block b3:
|
||||
%b3:i0:unit = nop
|
||||
ret %b1:p1:i32
|
||||
|
||||
block b7:
|
||||
%b7:i0:unit = nop
|
||||
%b7:i1:i32 = add %b1:p1:i32 1:i32
|
||||
%b7:i2:unit = nop
|
||||
j b1(%b2:i1:i32, %b7:i1:i32)
|
||||
}
|
||||
29
examples/ir3/switch-in-loop.ir
Normal file
29
examples/ir3/switch-in-loop.ir
Normal file
@@ -0,0 +1,29 @@
|
||||
|
||||
fun i32 @main () {
|
||||
init:
|
||||
bid: b0
|
||||
allocations:
|
||||
|
||||
|
||||
block b0:
|
||||
j b1(0:i32, 0:i32)
|
||||
|
||||
block b1:
|
||||
%b1:p0:i32:i
|
||||
%b1:p1:i32:c
|
||||
%b1:i0:u1 = cmp lt %b1:p0:i32 10:i32
|
||||
br %b1:i0:u1, b2(), b3()
|
||||
|
||||
block b2:
|
||||
%b2:i0:i32 = add %b1:p0:i32 1:i32
|
||||
switch %b2:i0:i32 default b7() [
|
||||
1:i32 b1(%b2:i0:i32, %b1:p1:i32)
|
||||
]
|
||||
|
||||
block b3:
|
||||
ret %b1:p1:i32
|
||||
|
||||
block b7:
|
||||
%b7:i0:i32 = add %b1:p1:i32 1:i32
|
||||
j b1(%b2:i0:i32, %b7:i0:i32)
|
||||
}
|
||||
29
examples/ir4/switch-in-loop.ir
Normal file
29
examples/ir4/switch-in-loop.ir
Normal file
@@ -0,0 +1,29 @@
|
||||
|
||||
fun i32 @main () {
|
||||
init:
|
||||
bid: b0
|
||||
allocations:
|
||||
|
||||
|
||||
block b0:
|
||||
j b1(0:i32, 0:i32)
|
||||
|
||||
block b1:
|
||||
%b1:p0:i32:i
|
||||
%b1:p1:i32:c
|
||||
%b1:i0:u1 = cmp lt %b1:p0:i32 10:i32
|
||||
br %b1:i0:u1, b2(), b3()
|
||||
|
||||
block b2:
|
||||
%b2:i0:i32 = add %b1:p0:i32 1:i32
|
||||
switch %b2:i0:i32 default b7() [
|
||||
1:i32 b1(%b2:i0:i32, %b1:p1:i32)
|
||||
]
|
||||
|
||||
block b3:
|
||||
ret %b1:p1:i32
|
||||
|
||||
block b7:
|
||||
%b7:i0:i32 = add %b1:p1:i32 1:i32
|
||||
j b1(%b2:i0:i32, %b7:i0:i32)
|
||||
}
|
||||
29
examples/opt/switch-in-loop.ir
Normal file
29
examples/opt/switch-in-loop.ir
Normal file
@@ -0,0 +1,29 @@
|
||||
|
||||
fun i32 @main () {
|
||||
init:
|
||||
bid: b0
|
||||
allocations:
|
||||
|
||||
|
||||
block b0:
|
||||
j b1(0:i32, 0:i32)
|
||||
|
||||
block b1:
|
||||
%b1:p0:i32:i
|
||||
%b1:p1:i32:c
|
||||
%b1:i0:u1 = cmp lt %b1:p0:i32 10:i32
|
||||
br %b1:i0:u1, b2(), b3()
|
||||
|
||||
block b2:
|
||||
%b2:i0:i32 = add %b1:p0:i32 1:i32
|
||||
switch %b2:i0:i32 default b7() [
|
||||
1:i32 b1(%b2:i0:i32, %b1:p1:i32)
|
||||
]
|
||||
|
||||
block b3:
|
||||
ret %b1:p1:i32
|
||||
|
||||
block b7:
|
||||
%b7:i0:i32 = add %b1:p1:i32 1:i32
|
||||
j b1(%b2:i0:i32, %b7:i0:i32)
|
||||
}
|
||||
Reference in New Issue
Block a user