Add tests

This commit is contained in:
Jeehoon Kang
2020-06-09 14:45:11 +00:00
parent ea97330e03
commit ea9e6afcf8
258 changed files with 149921 additions and 26 deletions

13
examples/ir4/alignof.ir Normal file
View File

@@ -0,0 +1,13 @@
fun i32 @main () {
init:
bid: b0
allocations:
block b0:
%b0:i0:u64 = typecast 4:i32 to u64
%b0:i1:u1 = cmp eq 4:u64 %b0:i0:u64
%b0:i2:i32 = typecast %b0:i1:u1 to i32
ret %b0:i2:i32
}

59
examples/ir4/array.ir Normal file
View File

@@ -0,0 +1,59 @@
fun i32 @main () {
init:
bid: b0
allocations:
%l0:[5 x i32]:a
block b0:
j b2(0:i32)
block b2:
%b2:p0:i32:i
%b2:i0:u1 = cmp lt %b2:p0:i32 5:i32
br %b2:i0:u1, b3(), b5()
block b3:
%b3:i0:*i32 = getelementptr %l0:*[5 x i32] offset 0:i32
%b3:i1:i64 = typecast %b2:p0:i32 to i64
%b3:i2:i64 = mul %b3:i1:i64 4:i64
%b3:i3:*i32 = getelementptr %b3:i0:*i32 offset %b3:i2:i64
%b3:i4:unit = store %b2:p0:i32 %b3:i3:*i32
%b3:i5:i32 = add %b2:p0:i32 1:i32
j b2(%b3:i5:i32)
block b5:
%b5:i0:*i32 = getelementptr %l0:*[5 x i32] offset 0:i32
%b5:i1:i32 = call @sum:*[ret:i32 params:(i32, *i32)](5:i32, %b5:i0:*i32)
%b5:i2:u1 = cmp eq %b5:i1:i32 10:i32
%b5:i3:i32 = typecast %b5:i2:u1 to i32
ret %b5:i3:i32
}
fun i32 @sum (i32, *i32) {
init:
bid: b0
allocations:
block b0:
j b2(0:i32, 0:i32)
block b2:
%b2:p0:i32:result
%b2:p1:i32:i
%b2:i0:u1 = cmp lt %b2:p1:i32 %b0:p0:i32
br %b2:i0:u1, b3(), b5()
block b3:
%b3:i0:i64 = typecast %b2:p1:i32 to i64
%b3:i1:i64 = mul %b3:i0:i64 4:i64
%b3:i2:*i32 = getelementptr %b0:p1:*i32 offset %b3:i1:i64
%b3:i3:i32 = load %b3:i2:*i32
%b3:i4:i32 = add %b2:p0:i32 %b3:i3:i32
%b3:i5:i32 = add %b2:p1:i32 1:i32
j b2(%b3:i4:i32, %b3:i5:i32)
block b5:
ret %b2:p0:i32
}

66
examples/ir4/array2.ir Normal file
View File

@@ -0,0 +1,66 @@
fun unit @init (i32, i32, *[5 x i32]) {
init:
bid: b0
allocations:
block b0:
j b2(0:i32)
block b2:
%b2:p0:i32:i
%b2:i0:u1 = cmp lt %b2:p0:i32 %b0:p0:i32
br %b2:i0:u1, b3(), b5()
block b3:
j b7(0:i32)
block b5:
ret unit:unit
block b7:
%b7:p0:i32:j
%b7:i0:u1 = cmp lt %b7:p0:i32 %b0:p1:i32
br %b7:i0:u1, b8(), b10()
block b8:
%b8:i0:i64 = typecast %b2:p0:i32 to i64
%b8:i1:i64 = mul %b8:i0:i64 20:i64
%b8:i2:*[5 x i32] = getelementptr %b0:p2:*[5 x i32] offset %b8:i1:i64
%b8:i3:*i32 = getelementptr %b8:i2:*[5 x i32] offset 0:i32
%b8:i4:i64 = typecast %b7:p0:i32 to i64
%b8:i5:i64 = mul %b8:i4:i64 4:i64
%b8:i6:*i32 = getelementptr %b8:i3:*i32 offset %b8:i5:i64
%b8:i7:i32 = mul %b2:p0:i32 %b7:p0:i32
%b8:i8:unit = store %b8:i7:i32 %b8:i6:*i32
%b8:i9:i32 = add %b7:p0:i32 1:i32
j b7(%b8:i9:i32)
block b10:
%b10:i0:i32 = add %b2:p0:i32 1:i32
j b2(%b10:i0:i32)
}
fun i32 @main () {
init:
bid: b0
allocations:
%l0:[4 x [5 x i32]]:a
block b0:
%b0:i0:*[5 x i32] = getelementptr %l0:*[4 x [5 x i32]] offset 0:i32
%b0:i1:unit = call @init:*[ret:unit params:(i32, i32, *[5 x i32])](4:i32, 5:i32, %b0:i0:*[5 x i32])
%b0:i2:*[5 x i32] = getelementptr %l0:*[4 x [5 x i32]] offset 0:i32
%b0:i3:i64 = typecast 2:i32 to i64
%b0:i4:i64 = mul %b0:i3:i64 20:i64
%b0:i5:*[5 x i32] = getelementptr %b0:i0:*[5 x i32] offset %b0:i4:i64
%b0:i6:*i32 = getelementptr %b0:i5:*[5 x i32] offset 0:i32
%b0:i7:i64 = typecast 3:i32 to i64
%b0:i8:i64 = mul %b0:i7:i64 4:i64
%b0:i9:*i32 = getelementptr %b0:i6:*i32 offset %b0:i8:i64
%b0:i10:i32 = load %b0:i9:*i32
%b0:i11:u1 = cmp eq %b0:i10:i32 6:i32
%b0:i12:i32 = typecast %b0:i11:u1 to i32
ret %b0:i12:i32
}

45
examples/ir4/array3.ir Normal file
View File

@@ -0,0 +1,45 @@
fun *i32 @foo (*i32) {
init:
bid: b0
allocations:
block b0:
ret %b0:p0:*i32
}
fun i32 @main () {
init:
bid: b0
allocations:
%l0:[10 x i32]:a
block b0:
j b2(0:i32)
block b2:
%b2:p0:i32:i
%b2:i0:u1 = cmp lt %b2:p0:i32 10:i32
br %b2:i0:u1, b3(), b5()
block b3:
%b3:i0:*i32 = getelementptr %l0:*[10 x i32] offset 0:i32
%b3:i1:*i32 = call @foo:*[ret:*i32 params:(*i32)](%b3:i0:*i32)
%b3:i2:i64 = typecast %b2:p0:i32 to i64
%b3:i3:i64 = mul %b3:i2:i64 4:i64
%b3:i4:*i32 = getelementptr %b3:i1:*i32 offset %b3:i3:i64
%b3:i5:unit = store %b2:p0:i32 %b3:i4:*i32
%b3:i6:i32 = add %b2:p0:i32 1:i32
j b2(%b3:i6:i32)
block b5:
%b5:i0:*i32 = getelementptr %l0:*[10 x i32] offset 0:i32
%b5:i1:i64 = typecast 5:i32 to i64
%b5:i2:i64 = mul %b5:i1:i64 4:i64
%b5:i3:*i32 = getelementptr %b5:i0:*i32 offset %b5:i2:i64
%b5:i4:i32 = load %b5:i3:*i32
%b5:i5:u1 = cmp eq %b5:i4:i32 5:i32
%b5:i6:i32 = typecast %b5:i5:u1 to i32
ret %b5:i6:i32
}

34
examples/ir4/array4.ir Normal file
View File

@@ -0,0 +1,34 @@
fun i32 @main () {
init:
bid: b0
allocations:
%l0:[10 x i32]:a
block b0:
%b0:i0:*i32 = getelementptr %l0:*[10 x i32] offset 0:i32
j b2(%b0:i0:*i32, 0:i32)
block b2:
%b2:p0:*i32:p
%b2:p1:i32:i
%b2:i0:u1 = cmp lt %b2:p1:i32 10:i32
br %b2:i0:u1, b3(), b5()
block b3:
%b3:i0:i64 = mul 1:i64 4:i64
%b3:i1:*i32 = getelementptr %b2:p0:*i32 offset %b3:i0:i64
%b3:i2:unit = store %b2:p1:i32 %b2:p0:*i32
%b3:i3:i32 = add %b2:p1:i32 1:i32
j b2(%b3:i1:*i32, %b3:i3:i32)
block b5:
%b5:i0:*i32 = getelementptr %l0:*[10 x i32] offset 0:i32
%b5:i1:i64 = typecast 5:i32 to i64
%b5:i2:i64 = mul %b5:i1:i64 4:i64
%b5:i3:*i32 = getelementptr %b0:i0:*i32 offset %b5:i2:i64
%b5:i4:i32 = load %b5:i3:*i32
%b5:i5:u1 = cmp eq %b5:i4:i32 5:i32
%b5:i6:i32 = typecast %b5:i5:u1 to i32
ret %b5:i6:i32
}

53
examples/ir4/array5.ir Normal file
View File

@@ -0,0 +1,53 @@
var [5 x i32] @g_a = {1, 2, 3}
fun i32 @main () {
init:
bid: b0
allocations:
%l0:[5 x i32]:a
block b0:
%b0:i0:*i32 = getelementptr %l0:*[5 x i32] offset 0:i32
%b0:i1:i64 = mul 0:i64 4:i64
%b0:i2:*i32 = getelementptr %b0:i0:*i32 offset %b0:i1:i64
%b0:i3:unit = store 1:i32 %b0:i2:*i32
%b0:i4:i64 = mul 1:i64 4:i64
%b0:i5:*i32 = getelementptr %b0:i0:*i32 offset %b0:i4:i64
%b0:i6:unit = store 2:i32 %b0:i5:*i32
%b0:i7:i64 = mul 2:i64 4:i64
%b0:i8:*i32 = getelementptr %b0:i0:*i32 offset %b0:i7:i64
%b0:i9:unit = store 3:i32 %b0:i8:*i32
%b0:i10:i64 = mul 3:i64 4:i64
%b0:i11:*i32 = getelementptr %b0:i0:*i32 offset %b0:i10:i64
%b0:i12:unit = store 4:i32 %b0:i11:*i32
%b0:i13:i64 = mul 4:i64 4:i64
%b0:i14:*i32 = getelementptr %b0:i0:*i32 offset %b0:i13:i64
%b0:i15:i32 = minus 5:i32
%b0:i16:unit = store %b0:i15:i32 %b0:i14:*i32
j b2(0:i32, 0:i32)
block b2:
%b2:p0:i32:sum
%b2:p1:i32:i
%b2:i0:u1 = cmp lt %b2:p1:i32 5:i32
br %b2:i0:u1, b3(), b5()
block b3:
%b3:i0:*i32 = getelementptr %l0:*[5 x i32] offset 0:i32
%b3:i1:i64 = typecast %b2:p1:i32 to i64
%b3:i2:i64 = mul %b3:i1:i64 4:i64
%b3:i3:*i32 = getelementptr %b0:i0:*i32 offset %b3:i2:i64
%b3:i4:i32 = load %b3:i3:*i32
%b3:i5:i32 = add %b2:p0:i32 %b3:i4:i32
%b3:i6:*i32 = getelementptr @g_a:*[5 x i32] offset 0:i32
%b3:i7:i64 = typecast %b2:p1:i32 to i64
%b3:i8:i64 = mul %b3:i1:i64 4:i64
%b3:i9:*i32 = getelementptr %b3:i6:*i32 offset %b3:i2:i64
%b3:i10:i32 = load %b3:i9:*i32
%b3:i11:i32 = add %b3:i5:i32 %b3:i10:i32
%b3:i12:i32 = add %b2:p1:i32 1:i32
j b2(%b3:i11:i32, %b3:i12:i32)
block b5:
ret %b2:p0:i32
}

27
examples/ir4/bar.ir Normal file
View File

@@ -0,0 +1,27 @@
fun i32 @bar (i32, i32, i32) {
init:
bid: b0
allocations:
block b0:
%b0:i0:u1 = cmp eq %b0:p0:i32 %b0:p1:i32
br %b0:i0:u1, b1(), b2()
block b1:
ret %b0:p1:i32
block b2:
ret %b0:p2:i32
}
fun i32 @main () {
init:
bid: b0
allocations:
block b0:
ret 1:i32
}

101
examples/ir4/bitwise.ir Normal file
View File

@@ -0,0 +1,101 @@
fun i32 @main () {
init:
bid: b0
allocations:
block b0:
%b0:i0:i32 = minus 1:i32
%b0:i1:u8 = typecast %b0:i0:i32 to u8
%b0:i2:i32 = minus 128:i32
%b0:i3:u8 = typecast %b0:i2:i32 to u8
%b0:i4:u8 = typecast 127:i32 to u8
%b0:i5:i32 = typecast %b0:i3:u8 to i32
%b0:i6:i32 = typecast %b0:i1:u8 to i32
%b0:i7:i32 = or %b0:i5:i32 %b0:i6:i32
%b0:i8:u8 = typecast %b0:i7:i32 to u8
%b0:i9:i32 = typecast %b0:i3:u8 to i32
%b0:i10:i32 = typecast %b0:i1:u8 to i32
%b0:i11:i32 = and %b0:i5:i32 %b0:i6:i32
%b0:i12:u8 = typecast %b0:i11:i32 to u8
%b0:i13:i32 = typecast %b0:i3:u8 to i32
%b0:i14:i32 = typecast %b0:i4:u8 to i32
%b0:i15:i32 = and %b0:i5:i32 %b0:i14:i32
%b0:i16:u8 = typecast %b0:i15:i32 to u8
%b0:i17:i32 = typecast %b0:i3:u8 to i32
%b0:i18:i32 = typecast %b0:i4:u8 to i32
%b0:i19:i32 = or %b0:i5:i32 %b0:i14:i32
%b0:i20:u8 = typecast %b0:i19:i32 to u8
%b0:i21:i32 = minus 1:i32
%b0:i22:i32 = minus 1:i32
%b0:i23:i32 = xor %b0:i0:i32 %b0:i0:i32
%b0:i24:u8 = typecast %b0:i23:i32 to u8
%b0:i25:i32 = minus 1:i32
%b0:i26:i32 = xor %b0:i0:i32 0:i32
%b0:i27:u8 = typecast %b0:i26:i32 to u8
%b0:i28:i32 = typecast %b0:i8:u8 to i32
%b0:i29:u1 = cmp eq %b0:i28:i32 255:i32
br %b0:i29:u1, b13(), b14()
block b1:
%b1:i0:i32 = typecast %b0:i27:u8 to i32
%b1:i1:u1 = cmp eq %b1:i0:i32 255:i32
j b3(%b1:i1:u1)
block b2:
j b3(0:u1)
block b3:
%b3:p0:u1:t4
%b3:i0:i32 = typecast %b3:p0:u1 to i32
ret %b3:i0:i32
block b4:
%b4:i0:i32 = typecast %b0:i24:u8 to i32
%b4:i1:u1 = cmp eq %b4:i0:i32 0:i32
j b6(%b4:i1:u1)
block b5:
j b6(0:u1)
block b6:
%b6:p0:u1:t3
br %b6:p0:u1, b1(), b2()
block b7:
%b7:i0:i32 = typecast %b0:i20:u8 to i32
%b7:i1:u1 = cmp eq %b7:i0:i32 255:i32
j b9(%b7:i1:u1)
block b8:
j b9(0:u1)
block b9:
%b9:p0:u1:t2
br %b9:p0:u1, b4(), b5()
block b10:
%b10:i0:i32 = typecast %b0:i16:u8 to i32
%b10:i1:u1 = cmp eq %b10:i0:i32 0:i32
j b12(%b10:i1:u1)
block b11:
j b12(0:u1)
block b12:
%b12:p0:u1:t1
br %b12:p0:u1, b7(), b8()
block b13:
%b13:i0:i32 = typecast %b0:i12:u8 to i32
%b13:i1:u1 = cmp eq %b13:i0:i32 128:i32
j b15(%b13:i1:u1)
block b14:
j b15(0:u1)
block b15:
%b15:p0:u1:t0
br %b15:p0:u1, b10(), b11()
}

67
examples/ir4/cmp.ir Normal file
View File

@@ -0,0 +1,67 @@
fun i32 @char_greater_than (i8, u8) {
init:
bid: b0
allocations:
block b0:
%b0:i0:i32 = typecast %b0:p0:i8 to i32
%b0:i1:i32 = typecast %b0:p1:u8 to i32
%b0:i2:u1 = cmp gt %b0:i0:i32 %b0:i1:i32
br %b0:i2:u1, b1(), b2()
block b1:
ret 1:i32
block b2:
ret 0:i32
}
fun i32 @int_greater_than (i32, u32) {
init:
bid: b0
allocations:
block b0:
%b0:i0:u32 = typecast %b0:p0:i32 to u32
%b0:i1:u1 = cmp gt %b0:i0:u32 %b0:p1:u32
br %b0:i1:u1, b1(), b2()
block b1:
ret 1:i32
block b2:
ret 0:i32
}
fun i32 @main () {
init:
bid: b0
allocations:
block b0:
%b0:i0:i32 = minus 1:i32
%b0:i1:u32 = typecast 1:i32 to u32
%b0:i2:i32 = call @int_greater_than:*[ret:i32 params:(i32, u32)](%b0:i0:i32, %b0:i1:u32)
%b0:i3:i32 = minus 1:i32
%b0:i4:i8 = typecast %b0:i0:i32 to i8
%b0:i5:u8 = typecast 1:i32 to u8
%b0:i6:i32 = call @char_greater_than:*[ret:i32 params:(i8, u8)](%b0:i4:i8, %b0:i5:u8)
%b0:i7:u1 = cmp eq %b0:i2:i32 1:i32
br %b0:i7:u1, b1(), b2()
block b1:
%b1:i0:u1 = cmp eq %b0:i6:i32 0:i32
j b3(%b1:i0:u1)
block b2:
j b3(0:u1)
block b3:
%b3:p0:u1:t0
%b3:i0:i32 = typecast %b3:p0:u1 to i32
ret %b3:i0:i32
}

14
examples/ir4/comma.ir Normal file
View File

@@ -0,0 +1,14 @@
fun i32 @main () {
init:
bid: b0
allocations:
block b0:
%b0:i0:i32 = add 2:i32 2:i32
%b0:i1:i32 = add %b0:i0:i32 3:i32
%b0:i2:u1 = cmp eq %b0:i1:i32 7:i32
%b0:i3:i32 = typecast %b0:i2:u1 to i32
ret %b0:i3:i32
}

16705
examples/ir4/complete_cond.ir Normal file

File diff suppressed because it is too large Load Diff

23
examples/ir4/cond.ir Normal file
View File

@@ -0,0 +1,23 @@
fun i32 @main () {
init:
bid: b0
allocations:
block b0:
%b0:i0:u1 = cmp eq 0:i32 1:i32
br %b0:i0:u1, b1(), b2()
block b1:
j b3(2:i32)
block b2:
j b3(5:i32)
block b3:
%b3:p0:i32:t0
%b3:i0:u1 = cmp eq %b3:p0:i32 5:i32
%b3:i1:i32 = typecast %b3:i0:u1 to i32
ret %b3:i1:i32
}

View File

@@ -0,0 +1,80 @@
fun i32 @main () {
init:
bid: b0
allocations:
block b0:
%b0:i0:u1 = cmp ne 0:i32 0:i32
br %b0:i0:u1, b1(), b2()
block b1:
%b1:i0:u1 = cmp gt 2:i32 5:i32
br %b1:i0:u1, b4(), b5()
block b2:
%b2:i0:i32 = add 2:i32 5:i32
j b3(2:i32, %b2:i0:i32)
block b3:
%b3:p0:i32:p
%b3:p1:i32:t1
j b8(0:i32, %b3:p0:i32)
block b4:
%b4:i0:i32 = sub 2:i32 2:i32
j b6(%b4:i0:i32, %b4:i0:i32)
block b5:
%b5:i0:i32 = add 2:i32 2:i32
j b6(%b5:i0:i32, %b5:i0:i32)
block b6:
%b6:p0:i32:p
%b6:p1:i32:t0
j b3(%b6:p0:i32, %b6:p1:i32)
block b8:
%b8:p0:i32:i
%b8:p1:i32:p
%b8:i0:u1 = cmp lt %b8:p0:i32 11:i32
br %b8:i0:u1, b9(), b11()
block b9:
%b9:i0:i32 = mod %b8:p0:i32 2:i32
%b9:i1:u1 = cmp ne %b9:i0:i32 0:i32
br %b9:i1:u1, b12(), b13()
block b11:
%b11:i0:u1 = cmp eq %b8:p1:i32 34:i32
%b11:i1:i32 = typecast %b11:i0:u1 to i32
ret %b11:i1:i32
block b12:
%b12:i0:i32 = add %b8:p1:i32 5:i32
j b14(%b12:i0:i32)
block b13:
%b13:i0:i32 = add %b8:p1:i32 %b3:p1:i32
j b14(%b13:i0:i32)
block b14:
%b14:p0:i32:p
%b14:i0:i32 = mod %b8:p0:i32 2:i32
%b14:i1:u1 = cmp ne %b9:i0:i32 0:i32
br %b9:i1:u1, b15(), b16()
block b15:
%b15:i0:i32 = add %b8:p0:i32 2:i32
j b17(%b15:i0:i32, %b15:i0:i32)
block b16:
%b16:i0:i32 = add %b8:p0:i32 1:i32
j b17(%b16:i0:i32, %b16:i0:i32)
block b17:
%b17:p0:i32:i
%b17:p1:i32:t2
j b8(%b17:p0:i32, %b14:p0:i32)
}

35
examples/ir4/fib2.ir Normal file
View File

@@ -0,0 +1,35 @@
fun i32 @fibonacci (i32) {
init:
bid: b0
allocations:
block b0:
%b0:i0:u1 = cmp lt %b0:p0:i32 2:i32
br %b0:i0:u1, b1(), b2()
block b1:
ret %b0:p0:i32
block b2:
%b2:i0:i32 = sub %b0:p0:i32 2:i32
%b2:i1:i32 = call @fibonacci:*[ret:i32 params:(i32)](%b2:i0:i32)
%b2:i2:i32 = sub %b0:p0:i32 1:i32
%b2:i3:i32 = call @fibonacci:*[ret:i32 params:(i32)](%b2:i2:i32)
%b2:i4:i32 = add %b2:i1:i32 %b2:i3:i32
ret %b2:i4:i32
}
fun i32 @main () {
init:
bid: b0
allocations:
block b0:
%b0:i0:i32 = call @fibonacci:*[ret:i32 params:(i32)](9:i32)
%b0:i1:u1 = cmp eq %b0:i0:i32 34:i32
%b0:i2:i32 = typecast %b0:i1:u1 to i32
ret %b0:i2:i32
}

45
examples/ir4/fib3.ir Normal file
View File

@@ -0,0 +1,45 @@
fun i32 @fibonacci (i32) {
init:
bid: b0
allocations:
block b0:
%b0:i0:u1 = cmp lt %b0:p0:i32 2:i32
br %b0:i0:u1, b1(), b2()
block b1:
ret %b0:p0:i32
block b2:
j b6(1:i32, 0:i32, 1:i32)
block b6:
%b6:p0:i32:i
%b6:p1:i32:t1
%b6:p2:i32:t2
%b6:i0:u1 = cmp lt %b6:p0:i32 %b0:p0:i32
br %b6:i0:u1, b7(), b9()
block b7:
%b7:i0:i32 = add %b6:p1:i32 %b6:p2:i32
%b7:i1:i32 = add %b6:p0:i32 1:i32
j b6(%b7:i1:i32, %b6:p2:i32, %b7:i0:i32)
block b9:
ret %b6:p2:i32
}
fun i32 @main () {
init:
bid: b0
allocations:
block b0:
%b0:i0:i32 = call @fibonacci:*[ret:i32 params:(i32)](9:i32)
%b0:i1:u1 = cmp eq %b0:i0:i32 34:i32
%b0:i2:i32 = typecast %b0:i1:u1 to i32
ret %b0:i2:i32
}

45
examples/ir4/fib4.ir Normal file
View File

@@ -0,0 +1,45 @@
fun i32 @fibonacci (i32) {
init:
bid: b0
allocations:
block b0:
%b0:i0:u1 = cmp lt %b0:p0:i32 2:i32
br %b0:i0:u1, b1(), b2()
block b1:
ret %b0:p0:i32
block b2:
j b5(1:i32, 0:i32, 1:i32)
block b5:
%b5:p0:i32:i
%b5:p1:i32:t1
%b5:p2:i32:t2
%b5:i0:u1 = cmp lt %b5:p0:i32 %b0:p0:i32
br %b5:i0:u1, b6(), b7()
block b6:
%b6:i0:i32 = add %b5:p1:i32 %b5:p2:i32
%b6:i1:i32 = add %b5:p0:i32 1:i32
j b5(%b6:i1:i32, %b5:p2:i32, %b6:i0:i32)
block b7:
ret %b5:p2:i32
}
fun i32 @main () {
init:
bid: b0
allocations:
block b0:
%b0:i0:i32 = call @fibonacci:*[ret:i32 params:(i32)](9:i32)
%b0:i1:u1 = cmp eq %b0:i0:i32 34:i32
%b0:i2:i32 = typecast %b0:i1:u1 to i32
ret %b0:i2:i32
}

42
examples/ir4/fib5.ir Normal file
View File

@@ -0,0 +1,42 @@
fun i32 @fibonacci (i32) {
init:
bid: b0
allocations:
block b0:
%b0:i0:u1 = cmp lt %b0:p0:i32 2:i32
br %b0:i0:u1, b1(), b2()
block b1:
ret %b0:p0:i32
block b2:
j b5(1:i32, 0:i32, 1:i32)
block b5:
%b5:p0:i32:i
%b5:p1:i32:t1
%b5:p2:i32:t2
%b5:i0:i32 = add %b5:p1:i32 %b5:p2:i32
%b5:i1:i32 = add %b5:p0:i32 1:i32
%b5:i2:u1 = cmp lt %b5:i1:i32 %b0:p0:i32
br %b5:i2:u1, b5(%b5:i1:i32, %b5:p2:i32, %b5:i0:i32), b7()
block b7:
ret %b5:i0:i32
}
fun i32 @main () {
init:
bid: b0
allocations:
block b0:
%b0:i0:i32 = call @fibonacci:*[ret:i32 params:(i32)](9:i32)
%b0:i1:u1 = cmp eq %b0:i0:i32 34:i32
%b0:i2:i32 = typecast %b0:i1:u1 to i32
ret %b0:i2:i32
}

35
examples/ir4/fibonacci.ir Normal file
View File

@@ -0,0 +1,35 @@
fun i32 @fibonacci (i32) {
init:
bid: b0
allocations:
block b0:
%b0:i0:u1 = cmp lt %b0:p0:i32 2:i32
br %b0:i0:u1, b1(), b2()
block b1:
ret %b0:p0:i32
block b2:
%b2:i0:i32 = sub %b0:p0:i32 2:i32
%b2:i1:i32 = call @fibonacci:*[ret:i32 params:(i32)](%b2:i0:i32)
%b2:i2:i32 = sub %b0:p0:i32 1:i32
%b2:i3:i32 = call @fibonacci:*[ret:i32 params:(i32)](%b2:i2:i32)
%b2:i4:i32 = add %b2:i1:i32 %b2:i3:i32
ret %b2:i4:i32
}
fun i32 @main () {
init:
bid: b0
allocations:
block b0:
%b0:i0:i32 = call @fibonacci:*[ret:i32 params:(i32)](9:i32)
%b0:i1:u1 = cmp eq %b0:i0:i32 34:i32
%b0:i2:i32 = typecast %b0:i1:u1 to i32
ret %b0:i2:i32
}

126
examples/ir4/float.ir Normal file
View File

@@ -0,0 +1,126 @@
fun f64 @average (i32, *i32) {
init:
bid: b0
allocations:
block b0:
j b2(0:i32, 0:i32)
block b2:
%b2:p0:i32:sum
%b2:p1:i32:i
%b2:i0:u1 = cmp lt %b2:p1:i32 %b0:p0:i32
br %b2:i0:u1, b3(), b5()
block b3:
%b3:i0:i64 = typecast %b2:p1:i32 to i64
%b3:i1:i64 = mul %b3:i0:i64 4:i64
%b3:i2:*i32 = getelementptr %b0:p1:*i32 offset %b3:i1:i64
%b3:i3:i32 = load %b3:i2:*i32
%b3:i4:i32 = add %b2:p0:i32 %b3:i3:i32
%b3:i5:i32 = add %b2:p1:i32 1:i32
j b2(%b3:i4:i32, %b3:i5:i32)
block b5:
%b5:i0:f64 = typecast %b2:p0:i32 to f64
%b5:i1:f64 = typecast %b0:p0:i32 to f64
%b5:i2:f64 = div %b5:i0:f64 %b5:i1:f64
ret %b5:i2:f64
}
fun f64 @custom_abs (f64) {
init:
bid: b0
allocations:
block b0:
%b0:i0:f64 = typecast 0:i32 to f64
%b0:i1:u1 = cmp lt %b0:p0:f64 %b0:i0:f64
br %b0:i1:u1, b1(), b2()
block b1:
%b1:i0:f64 = minus %b0:p0:f64
j b3(%b1:i0:f64)
block b2:
j b3(%b0:p0:f64)
block b3:
%b3:p0:f64:t0
ret %b3:p0:f64
}
fun f64 @custom_max (f64, f64) {
init:
bid: b0
allocations:
block b0:
%b0:i0:u1 = cmp gt %b0:p0:f64 %b0:p1:f64
br %b0:i0:u1, b1(), b2()
block b1:
j b3(%b0:p0:f64)
block b2:
j b3(%b0:p1:f64)
block b3:
%b3:p0:f64:t0
ret %b3:p0:f64
}
fun i32 @is_close (f64, f64, f64, f64) {
init:
bid: b0
allocations:
block b0:
%b0:i0:f64 = sub %b0:p0:f64 %b0:p1:f64
%b0:i1:f64 = call @custom_abs:*[ret:f64 params:(f64)](%b0:i0:f64)
%b0:i2:f64 = call @custom_abs:*[ret:f64 params:(f64)](%b0:p0:f64)
%b0:i3:f64 = call @custom_abs:*[ret:f64 params:(f64)](%b0:p1:f64)
%b0:i4:f64 = call @custom_max:*[ret:f64 params:(f64, f64)](%b0:i2:f64, %b0:i3:f64)
%b0:i5:f64 = mul %b0:p2:f64 %b0:i4:f64
%b0:i6:f64 = call @custom_max:*[ret:f64 params:(f64, f64)](%b0:i5:f64, %b0:p3:f64)
%b0:i7:u1 = cmp le %b0:i1:f64 %b0:i6:f64
%b0:i8:i32 = typecast %b0:i7:u1 to i32
ret %b0:i8:i32
}
fun i32 @main () {
init:
bid: b0
allocations:
%l0:[10 x i32]:a
block b0:
j b2(0:i32)
block b2:
%b2:p0:i32:i
%b2:i0:u1 = cmp lt %b2:p0:i32 10:i32
br %b2:i0:u1, b3(), b5()
block b3:
%b3:i0:*i32 = getelementptr %l0:*[10 x i32] offset 0:i32
%b3:i1:i64 = typecast %b2:p0:i32 to i64
%b3:i2:i64 = mul %b3:i1:i64 4:i64
%b3:i3:*i32 = getelementptr %b3:i0:*i32 offset %b3:i2:i64
%b3:i4:unit = store %b2:p0:i32 %b3:i3:*i32
%b3:i5:i32 = add %b2:p0:i32 1:i32
j b2(%b3:i5:i32)
block b5:
%b5:i0:*i32 = getelementptr %l0:*[10 x i32] offset 0:i32
%b5:i1:f64 = call @average:*[ret:f64 params:(i32, *i32)](10:i32, %b5:i0:*i32)
%b5:i2:f32 = typecast %b5:i1:f64 to f32
%b5:i3:f64 = typecast %b5:i2:f32 to f64
%b5:i4:i32 = call @is_close:*[ret:i32 params:(f64, f64, f64, f64)](%b5:i3:f64, 4.5:f64, 0.000000001:f64, 0.1:f64)
ret %b5:i4:i32
}

7940
examples/ir4/float2.ir Normal file

File diff suppressed because it is too large Load Diff

32
examples/ir4/foo.ir Normal file
View File

@@ -0,0 +1,32 @@
fun i32 @foo (i32, i32, i32) {
init:
bid: b0
allocations:
block b0:
%b0:i0:u1 = cmp eq %b0:p0:i32 %b0:p1:i32
br %b0:i0:u1, b1(), b2()
block b1:
ret %b0:p1:i32
block b2:
ret %b0:p2:i32
}
fun i32 @main () {
init:
bid: b0
allocations:
block b0:
%b0:i0:i32 = minus 1:i32
%b0:i1:i32 = call @foo:*[ret:i32 params:(i32, i32, i32)](0:i32, 1:i32, %b0:i0:i32)
%b0:i2:i32 = minus 1:i32
%b0:i3:u1 = cmp eq %b0:i1:i32 %b0:i0:i32
%b0:i4:i32 = typecast %b0:i3:u1 to i32
ret %b0:i4:i32
}

22
examples/ir4/foo2.ir Normal file
View File

@@ -0,0 +1,22 @@
fun i32 @main () {
init:
bid: b0
allocations:
block b0:
j b2(0:i32)
block b2:
%b2:p0:i32:i
%b2:i0:u1 = cmp lt %b2:p0:i32 10:i32
br %b2:i0:u1, b3(), b5()
block b3:
%b3:i0:i32 = add %b2:p0:i32 1:i32
j b2(%b3:i0:i32)
block b5:
ret 1:i32
}

28
examples/ir4/foo3.ir Normal file
View File

@@ -0,0 +1,28 @@
var i32 @g = 10
fun i32 @foo (i32, i32) {
init:
bid: b0
allocations:
block b0:
%b0:i0:i32 = add %b0:p0:i32 %b0:p1:i32
%b0:i1:i32 = load @g:*i32
%b0:i2:i32 = add %b0:i0:i32 %b0:i1:i32
ret %b0:i2:i32
}
fun i32 @main () {
init:
bid: b0
allocations:
block b0:
%b0:i0:i32 = load @g:*i32
%b0:i1:i32 = call @foo:*[ret:i32 params:(i32, i32)](%b0:i0:i32, %b0:i0:i32)
%b0:i2:u1 = cmp eq %b0:i1:i32 30:i32
%b0:i3:i32 = typecast %b0:i2:u1 to i32
ret %b0:i3:i32
}

47
examples/ir4/foo4.ir Normal file
View File

@@ -0,0 +1,47 @@
fun i32 @foo (i32, i32, i32) {
init:
bid: b0
allocations:
block b0:
%b0:i0:i32 = add %b0:p0:i32 %b0:p1:i32
%b0:i1:i32 = add %b0:i0:i32 %b0:p2:i32
ret %b0:i1:i32
}
fun *[ret:i32 params:(i32, i32, i32)] @foo2 () {
init:
bid: b0
allocations:
block b0:
ret @foo:*[ret:i32 params:(i32, i32, i32)]
}
fun *[ret:*[ret:i32 params:(i32, i32, i32)] params:()] @foo3 () {
init:
bid: b0
allocations:
block b0:
ret @foo2:*[ret:*[ret:i32 params:(i32, i32, i32)] params:()]
}
fun i32 @main () {
init:
bid: b0
allocations:
block b0:
%b0:i0:*[ret:*[ret:i32 params:(i32, i32, i32)] params:()] = call @foo3:*[ret:*[ret:*[ret:i32 params:(i32, i32, i32)] params:()] params:()]()
%b0:i1:*[ret:i32 params:(i32, i32, i32)] = call %b0:i0:*[ret:*[ret:i32 params:(i32, i32, i32)] params:()]()
%b0:i2:i32 = call %b0:i1:*[ret:i32 params:(i32, i32, i32)](2:i32, 2:i32, 2:i32)
%b0:i3:u1 = cmp eq %b0:i2:i32 6:i32
%b0:i4:i32 = typecast %b0:i3:u1 to i32
ret %b0:i4:i32
}

View File

@@ -0,0 +1,45 @@
fun i32 @foo () {
init:
bid: b0
allocations:
block b0:
j b2(0:i32, 0:i32)
block b2:
%b2:p0:i32:sum
%b2:p1:i32:i
%b2:i0:u1 = cmp eq %b2:p1:i32 5:i32
br %b2:i0:u1, b6(), b7()
block b6:
ret %b2:p0:i32
block b7:
%b7:i0:u1 = cmp eq %b2:p1:i32 3:i32
br %b7:i0:u1, b10(), b11()
block b10:
%b10:i0:i32 = add %b2:p1:i32 1:i32
j b2(%b2:p0:i32, %b10:i0:i32)
block b11:
%b11:i0:i32 = add %b2:p0:i32 %b2:p1:i32
%b11:i1:i32 = add %b2:p1:i32 1:i32
j b2(%b11:i0:i32, %b11:i1:i32)
}
fun i32 @main () {
init:
bid: b0
allocations:
block b0:
%b0:i0:i32 = call @foo:*[ret:i32 params:()]()
%b0:i1:u1 = cmp eq %b0:i0:i32 7:i32
%b0:i2:i32 = typecast %b0:i1:u1 to i32
ret %b0:i2:i32
}

68
examples/ir4/gcd.ir Normal file
View File

@@ -0,0 +1,68 @@
fun i32 @gcd (i32, i32) {
init:
bid: b0
allocations:
block b0:
%b0:i0:u1 = cmp gt %b0:p0:i32 0:i32
br %b0:i0:u1, b1(), b2()
block b1:
j b3(%b0:p0:i32)
block b2:
%b2:i0:i32 = minus %b0:p0:i32
j b3(%b2:i0:i32)
block b3:
%b3:p0:i32:t0
%b3:i0:u1 = cmp gt %b0:p1:i32 0:i32
br %b3:i0:u1, b4(), b5()
block b4:
j b6(%b0:p1:i32)
block b5:
%b5:i0:i32 = minus %b0:p1:i32
j b6(%b5:i0:i32)
block b6:
%b6:p0:i32:t1
j b7(%b3:p0:i32, %b6:p0:i32)
block b7:
%b7:p0:i32:a
%b7:p1:i32:b
%b7:i0:u1 = cmp ne %b7:p0:i32 %b7:p1:i32
br %b7:i0:u1, b8(), b9()
block b8:
%b8:i0:u1 = cmp gt %b7:p0:i32 %b7:p1:i32
br %b8:i0:u1, b10(), b11()
block b9:
ret %b7:p0:i32
block b10:
%b10:i0:i32 = sub %b7:p0:i32 %b7:p1:i32
j b7(%b10:i0:i32, %b7:p1:i32)
block b11:
%b11:i0:i32 = sub %b7:p1:i32 %b7:p0:i32
j b7(%b7:p0:i32, %b11:i0:i32)
}
fun i32 @main () {
init:
bid: b0
allocations:
block b0:
%b0:i0:i32 = call @gcd:*[ret:i32 params:(i32, i32)](18:i32, 21:i32)
%b0:i1:u1 = cmp eq %b0:i0:i32 3:i32
%b0:i2:i32 = typecast %b0:i1:u1 to i32
ret %b0:i2:i32
}

View File

@@ -0,0 +1,17 @@
fun i32 @main () {
init:
bid: b0
allocations:
block b0:
%b0:i0:i16 = typecast 0:i32 to i16
%b0:i1:u32 = typecast %b0:i0:i16 to u32
%b0:i2:u32 = xor %b0:i1:u32 4294967163:u32
%b0:i3:i8 = typecast %b0:i2:u32 to i8
%b0:i4:i32 = typecast %b0:i3:i8 to i32
%b0:i5:u1 = cmp eq %b0:i4:i32 123:i32
%b0:i6:i32 = typecast %b0:i5:u1 to i32
ret %b0:i6:i32
}

View File

@@ -0,0 +1,13 @@
fun i32 @main () {
init:
bid: b0
allocations:
block b0:
%b0:i0:u32 = typecast 0:i32 to u32
%b0:i1:u1 = cmp lt %b0:i0:u32 4294967295:u32
%b0:i2:i32 = typecast %b0:i1:u1 to i32
ret %b0:i2:i32
}

View File

@@ -0,0 +1,65 @@
fun i32 @main () {
init:
bid: b0
allocations:
block b0:
%b0:i0:u1 = cmp ne 1:i32 0:i32
br %b0:i0:u1, b4(), b5()
block b1:
%b1:i0:i32 = add %b6:p0:i32 1:i32
j b3(%b1:i0:i32)
block b3:
%b3:p0:i32:b
%b3:i0:u1 = cmp ne 1:i32 0:i32
br %b0:i0:u1, b10(), b11()
block b4:
j b6(0:i32, 1:u1)
block b5:
%b5:i0:u1 = cmp ne 1:i32 0:i32
j b6(1:i32, %b0:i0:u1)
block b6:
%b6:p0:i32:b
%b6:p1:u1:t0
br %b6:p1:u1, b1(), b3(%b6:p0:i32)
block b7:
%b7:i0:i32 = add %b12:p0:i32 1:i32
j b9(%b7:i0:i32)
block b9:
%b9:p0:i32:d
%b9:i0:u1 = cmp eq %b3:p0:i32 1:i32
br %b9:i0:u1, b13(), b14()
block b10:
%b10:i0:u1 = cmp ne 1:i32 0:i32
j b12(1:i32, %b0:i0:u1)
block b11:
j b12(0:i32, 0:u1)
block b12:
%b12:p0:i32:d
%b12:p1:u1:t1
br %b12:p1:u1, b7(), b9(%b12:p0:i32)
block b13:
%b13:i0:u1 = cmp eq %b9:p0:i32 2:i32
j b15(%b13:i0:u1)
block b14:
j b15(0:u1)
block b15:
%b15:p0:u1:t2
%b15:i0:i32 = typecast %b15:p0:u1 to i32
ret %b15:i0:i32
}

View File

@@ -0,0 +1,29 @@
var i32 @a = -(1)
var i64 @b = -(1l)
var f32 @c = -(1.5f)
var f64 @d = -(1.5)
fun i32 @main () {
init:
bid: b0
allocations:
block b0:
%b0:i0:i32 = load @a:*i32
%b0:i1:i64 = load @b:*i64
%b0:i2:i64 = typecast %b0:i0:i32 to i64
%b0:i3:i64 = add %b0:i2:i64 %b0:i1:i64
%b0:i4:f32 = load @c:*f32
%b0:i5:i32 = typecast %b0:i4:f32 to i32
%b0:i6:i64 = typecast %b0:i5:i32 to i64
%b0:i7:i64 = add %b0:i3:i64 %b0:i6:i64
%b0:i8:f64 = load @d:*f64
%b0:i9:i64 = typecast %b0:i8:f64 to i64
%b0:i10:i64 = add %b0:i7:i64 %b0:i9:i64
%b0:i11:i32 = minus 4:i32
%b0:i12:i64 = typecast %b0:i11:i32 to i64
%b0:i13:u1 = cmp eq %b0:i10:i64 %b0:i12:i64
%b0:i14:i32 = typecast %b0:i13:u1 to i32
ret %b0:i14:i32
}

32
examples/ir4/negate.ir Normal file
View File

@@ -0,0 +1,32 @@
fun i32 @foo (i32, i32, i32) {
init:
bid: b0
allocations:
block b0:
%b0:i0:u1 = cmp eq %b0:p0:i32 %b0:p1:i32
%b0:i1:u1 = negate %b0:i0:u1
br %b0:i1:u1, b1(), b2()
block b1:
ret %b0:p1:i32
block b2:
ret %b0:p2:i32
}
fun i32 @main () {
init:
bid: b0
allocations:
block b0:
%b0:i0:i32 = minus 1:i32
%b0:i1:i32 = call @foo:*[ret:i32 params:(i32, i32, i32)](0:i32, 1:i32, %b0:i0:i32)
%b0:i2:u1 = cmp eq %b0:i1:i32 1:i32
%b0:i3:i32 = typecast %b0:i2:u1 to i32
ret %b0:i3:i32
}

43
examples/ir4/pointer.ir Normal file
View File

@@ -0,0 +1,43 @@
fun *i32 @foo (*i32) {
init:
bid: b0
allocations:
block b0:
ret %b0:p0:*i32
}
fun i32 @main () {
init:
bid: b0
allocations:
%l0:i32:a
%l1:*i32:p
block b0:
%b0:i0:unit = store 1:i32 %l0:*i32
%b0:i1:unit = store %l0:*i32 %l1:**i32
%b0:i2:*i32 = load %l1:**i32
%b0:i3:*i32 = load %l1:**i32
%b0:i4:*i32 = call @foo:*[ret:*i32 params:(*i32)](%b0:i3:*i32)
%b0:i5:*i32 = load %l1:**i32
%b0:i6:*i32 = call @foo:*[ret:*i32 params:(*i32)](%b0:i5:*i32)
%b0:i7:*i32 = load %l1:**i32
%b0:i8:*i32 = call @foo:*[ret:*i32 params:(*i32)](%b0:i7:*i32)
%b0:i9:*i32 = load %l1:**i32
%b0:i10:*i32 = call @foo:*[ret:*i32 params:(*i32)](%b0:i9:*i32)
%b0:i11:i32 = load %b0:i10:*i32
%b0:i12:i32 = add %b0:i11:i32 1:i32
%b0:i13:unit = store %b0:i12:i32 %b0:i6:*i32
%b0:i14:*i32 = call @foo:*[ret:*i32 params:(*i32)](%b0:i2:*i32)
%b0:i15:*i32 = call @foo:*[ret:*i32 params:(*i32)](%b0:i2:*i32)
%b0:i16:i32 = load %b0:i15:*i32
%b0:i17:i32 = add %b0:i16:i32 1:i32
%b0:i18:unit = store %b0:i17:i32 %b0:i14:*i32
%b0:i19:i32 = load %l0:*i32
%b0:i20:u1 = cmp eq %b0:i19:i32 3:i32
%b0:i21:i32 = typecast %b0:i20:u1 to i32
ret %b0:i21:i32
}

View File

@@ -0,0 +1,21 @@
fun unit @foo () {
init:
bid: b0
allocations:
block b0:
ret unit:unit
}
fun i32 @main () {
init:
bid: b0
allocations:
block b0:
%b0:i0:unit = call @foo:*[ret:unit params:()]()
ret 1:i32
}

34
examples/ir4/shift.ir Normal file
View File

@@ -0,0 +1,34 @@
fun i32 @main () {
init:
bid: b0
allocations:
block b0:
%b0:i0:i8 = typecast 127:i32 to i8
%b0:i1:i32 = typecast %b0:i0:i8 to i32
%b0:i2:i32 = shl %b0:i1:i32 1:i32
%b0:i3:i8 = typecast %b0:i2:i32 to i8
%b0:i4:u8 = typecast %b0:i3:i8 to u8
%b0:i5:i32 = typecast %b0:i4:u8 to i32
%b0:i6:i32 = shr %b0:i5:i32 1:i32
%b0:i7:u8 = typecast %b0:i6:i32 to u8
%b0:i8:i32 = minus 2:i32
%b0:i9:i32 = typecast %b0:i3:i8 to i32
%b0:i10:u1 = cmp eq %b0:i9:i32 %b0:i8:i32
br %b0:i10:u1, b1(), b2()
block b1:
%b1:i0:i32 = typecast %b0:i7:u8 to i32
%b1:i1:u1 = cmp eq %b1:i0:i32 127:i32
j b3(%b1:i1:u1)
block b2:
j b3(0:u1)
block b3:
%b3:p0:u1:t0
%b3:i0:i32 = typecast %b3:p0:u1 to i32
ret %b3:i0:i32
}

10
examples/ir4/simple.ir Normal file
View File

@@ -0,0 +1,10 @@
fun i32 @main () {
init:
bid: b0
allocations:
block b0:
ret 1:i32
}

View File

@@ -0,0 +1,47 @@
fun i32 @f (i32) {
init:
bid: b0
allocations:
block b0:
%b0:i0:i32 = add %b0:p0:i32 8:i32
ret %b0:i0:i32
}
fun i32 @main () {
init:
bid: b0
allocations:
block b0:
%b0:i0:i32 = add 0:i32 1:i32
%b0:i1:u1 = cmp eq 0:i32 1:i32
br %b0:i1:u1, b1(), b2()
block b1:
j b3(1:i32)
block b2:
j b3(2:i32)
block b3:
%b3:p0:i32:t0
%b3:i0:u1 = cmp lt %b0:i0:i32 %b3:p0:i32
br %b3:i0:u1, b4(), b5()
block b4:
j b6(%b0:i0:i32)
block b5:
j b6(2:i32)
block b6:
%b6:p0:i32:t1
%b6:i0:i32 = call @f:*[ret:i32 params:(i32)](%b6:p0:i32)
%b6:i1:u1 = cmp eq %b6:i0:i32 9:i32
%b6:i2:i32 = typecast %b6:i1:u1 to i32
ret %b6:i2:i32
}

View File

@@ -0,0 +1,26 @@
fun i32 @main () {
init:
bid: b0
allocations:
block b0:
j b2(0:i32, 0:i32)
block b2:
%b2:p0:i32:i
%b2:p1:i32:sum
%b2:i0:u1 = cmp lt %b2:p0:i32 11:i32
br %b2:i0:u1, b3(), b5()
block b3:
%b3:i0:i32 = add %b2:p1:i32 %b2:p0:i32
%b3:i1:i32 = add %b2:p0:i32 1:i32
j b2(%b3:i1:i32, %b3:i0:i32)
block b5:
%b5:i0:u1 = cmp eq %b2:p1:i32 55:i32
%b5:i1:i32 = typecast %b5:i0:u1 to i32
ret %b5:i1:i32
}

34
examples/ir4/simple_if.ir Normal file
View File

@@ -0,0 +1,34 @@
fun i32 @fibonacci (i32) {
init:
bid: b0
allocations:
block b0:
%b0:i0:u1 = cmp lt %b0:p0:i32 2:i32
br %b0:i0:u1, b1(), b3(%b0:p0:i32)
block b1:
%b1:i0:i32 = add %b0:p0:i32 2:i32
j b3(%b1:i0:i32)
block b3:
%b3:p0:i32:n
%b3:i0:i32 = sub %b3:p0:i32 2:i32
%b3:i1:i32 = call @fibonacci:*[ret:i32 params:(i32)](%b3:i0:i32)
%b3:i2:i32 = sub %b3:p0:i32 1:i32
%b3:i3:i32 = call @fibonacci:*[ret:i32 params:(i32)](%b3:i2:i32)
%b3:i4:i32 = add %b3:i1:i32 %b3:i3:i32
ret %b3:i4:i32
}
fun i32 @main () {
init:
bid: b0
allocations:
block b0:
ret 1:i32
}

13
examples/ir4/sizeof.ir Normal file
View File

@@ -0,0 +1,13 @@
fun i32 @main () {
init:
bid: b0
allocations:
block b0:
%b0:i0:u64 = typecast 4:i32 to u64
%b0:i1:u1 = cmp eq 4:u64 %b0:i0:u64
%b0:i2:i32 = typecast %b0:i1:u1 to i32
ret %b0:i2:i32
}

73
examples/ir4/struct.ir Normal file
View File

@@ -0,0 +1,73 @@
struct %t1 : { i8, struct %t0, f64 }
struct %t0 : { [4 x [5 x i32]] }
fun unit @init (i32, i32, *[5 x i32]) {
init:
bid: b0
allocations:
block b0:
j b2(0:i32)
block b2:
%b2:p0:i32:i
%b2:i0:u1 = cmp lt %b2:p0:i32 %b0:p0:i32
br %b2:i0:u1, b3(), b5()
block b3:
j b7(0:i32)
block b5:
ret unit:unit
block b7:
%b7:p0:i32:j
%b7:i0:u1 = cmp lt %b7:p0:i32 %b0:p1:i32
br %b7:i0:u1, b8(), b10()
block b8:
%b8:i0:i64 = typecast %b2:p0:i32 to i64
%b8:i1:i64 = mul %b8:i0:i64 20:i64
%b8:i2:*[5 x i32] = getelementptr %b0:p2:*[5 x i32] offset %b8:i1:i64
%b8:i3:*i32 = getelementptr %b8:i2:*[5 x i32] offset 0:i32
%b8:i4:i64 = typecast %b7:p0:i32 to i64
%b8:i5:i64 = mul %b8:i4:i64 4:i64
%b8:i6:*i32 = getelementptr %b8:i3:*i32 offset %b8:i5:i64
%b8:i7:i32 = mul %b2:p0:i32 %b7:p0:i32
%b8:i8:unit = store %b8:i7:i32 %b8:i6:*i32
%b8:i9:i32 = add %b7:p0:i32 1:i32
j b7(%b8:i9:i32)
block b10:
%b10:i0:i32 = add %b2:p0:i32 1:i32
j b2(%b10:i0:i32)
}
fun i32 @main () {
init:
bid: b0
allocations:
%l0: struct %t1:temp
%l1: struct %t1:temp2
block b0:
%b0:i0:*[4 x [5 x i32]] = getelementptr %l0:* struct %t1 offset 4:i64
%b0:i1:*[5 x i32] = getelementptr %b0:i0:*[4 x [5 x i32]] offset 0:i32
%b0:i2:unit = call @init:*[ret:unit params:(i32, i32, *[5 x i32])](4:i32, 5:i32, %b0:i1:*[5 x i32])
%b0:i3: struct %t1 = load %l0:* struct %t1
%b0:i4:unit = store %b0:i3: struct %t1 %l1:* struct %t1
%b0:i5:*[4 x [5 x i32]] = getelementptr %l1:* struct %t1 offset 4:i64
%b0:i6:*[5 x i32] = getelementptr %b0:i5:*[4 x [5 x i32]] offset 0:i32
%b0:i7:i64 = typecast 2:i32 to i64
%b0:i8:i64 = mul %b0:i7:i64 20:i64
%b0:i9:*[5 x i32] = getelementptr %b0:i6:*[5 x i32] offset %b0:i8:i64
%b0:i10:*i32 = getelementptr %b0:i9:*[5 x i32] offset 0:i32
%b0:i11:i64 = typecast 3:i32 to i64
%b0:i12:i64 = mul %b0:i11:i64 4:i64
%b0:i13:*i32 = getelementptr %b0:i10:*i32 offset %b0:i12:i64
%b0:i14:i32 = load %b0:i13:*i32
%b0:i15:u1 = cmp eq %b0:i14:i32 6:i32
%b0:i16:i32 = typecast %b0:i15:u1 to i32
ret %b0:i16:i32
}

53
examples/ir4/struct2.ir Normal file
View File

@@ -0,0 +1,53 @@
struct %t0 : { [4 x i32] }
struct %t1 : { i8, struct %t0, i64 }
fun i32 @main () {
init:
bid: b0
allocations:
%l0:const struct %t1:temp
%l1: struct %t1:temp2
block b0:
%b0:i0:*i8 = getelementptr %l0:*const struct %t1 offset 0:i64
%b0:i1:i8 = typecast 1:i32 to i8
%b0:i2:unit = store %b0:i1:i8 %b0:i0:*i8
%b0:i3:* struct %t0 = getelementptr %l0:*const struct %t1 offset 4:i64
%b0:i4:*[4 x i32] = getelementptr %b0:i3:* struct %t0 offset 0:i64
%b0:i5:*i32 = getelementptr %b0:i4:*[4 x i32] offset 0:i32
%b0:i6:i64 = mul 0:i64 4:i64
%b0:i7:*i32 = getelementptr %b0:i5:*i32 offset %b0:i6:i64
%b0:i8:unit = store 2:i32 %b0:i7:*i32
%b0:i9:i64 = mul 1:i64 4:i64
%b0:i10:*i32 = getelementptr %b0:i5:*i32 offset %b0:i9:i64
%b0:i11:unit = store 3:i32 %b0:i10:*i32
%b0:i12:i64 = mul 2:i64 4:i64
%b0:i13:*i32 = getelementptr %b0:i5:*i32 offset %b0:i12:i64
%b0:i14:unit = store 4:i32 %b0:i13:*i32
%b0:i15:i64 = mul 3:i64 4:i64
%b0:i16:*i32 = getelementptr %b0:i5:*i32 offset %b0:i15:i64
%b0:i17:unit = store 5:i32 %b0:i16:*i32
%b0:i18:*i64 = getelementptr %l0:*const struct %t1 offset 24:i64
%b0:i19:i64 = typecast 6:i32 to i64
%b0:i20:unit = store %b0:i19:i64 %b0:i18:*i64
%b0:i21: struct %t1 = load %l0:*const struct %t1
%b0:i22:unit = store %b0:i21: struct %t1 %l1:* struct %t1
%b0:i23:*i8 = getelementptr %l1:* struct %t1 offset 0:i64
%b0:i24:i8 = load %b0:i23:*i8
%b0:i25:*[4 x i32] = getelementptr %l1:* struct %t1 offset 4:i64
%b0:i26:*i32 = getelementptr %b0:i25:*[4 x i32] offset 0:i32
%b0:i27:i64 = typecast 2:i32 to i64
%b0:i28:i64 = mul %b0:i27:i64 4:i64
%b0:i29:*i32 = getelementptr %b0:i26:*i32 offset %b0:i28:i64
%b0:i30:i32 = load %b0:i29:*i32
%b0:i31:i32 = typecast %b0:i24:i8 to i32
%b0:i32:i32 = add %b0:i31:i32 %b0:i30:i32
%b0:i33:*i64 = getelementptr %l1:* struct %t1 offset 24:i64
%b0:i34:i64 = load %b0:i33:*i64
%b0:i35:i64 = typecast %b0:i32:i32 to i64
%b0:i36:i64 = add %b0:i35:i64 %b0:i34:i64
%b0:i37:i32 = typecast %b0:i36:i64 to i32
%b0:i38:u1 = cmp eq %b0:i37:i32 11:i32
%b0:i39:i32 = typecast %b0:i38:u1 to i32
ret %b0:i39:i32
}

77
examples/ir4/struct3.ir Normal file
View File

@@ -0,0 +1,77 @@
struct Big : { struct Sub, struct Sub, struct Sub }
struct Sub : { i64, i64, i64, i64 }
fun struct Big @foo ( struct Big) {
init:
bid: b0
allocations:
%l0: struct Big:r
block b0:
%b0:i0:unit = store %b0:p0: struct Big %l0:* struct Big
%b0:i1:* struct Sub = getelementptr %l0:* struct Big offset 0:i64
%b0:i2:*i64 = getelementptr %b0:i1:* struct Sub offset 0:i64
%b0:i3:i64 = typecast 10:i32 to i64
%b0:i4:unit = store %b0:i3:i64 %b0:i2:*i64
%b0:i5: struct Big = load %l0:* struct Big
ret %b0:i5: struct Big
}
fun i32 @main () {
init:
bid: b0
allocations:
%l0: struct Big:a
%l1: struct Big:r
block b0:
%b0:i0:* struct Sub = getelementptr %l0:* struct Big offset 0:i64
%b0:i1:*i64 = getelementptr %b0:i0:* struct Sub offset 0:i64
%b0:i2:i64 = typecast 1:i32 to i64
%b0:i3:unit = store %b0:i2:i64 %b0:i1:*i64
%b0:i4:*i64 = getelementptr %b0:i0:* struct Sub offset 8:i64
%b0:i5:i64 = typecast 2:i32 to i64
%b0:i6:unit = store %b0:i5:i64 %b0:i4:*i64
%b0:i7:*i64 = getelementptr %b0:i0:* struct Sub offset 16:i64
%b0:i8:i64 = typecast 3:i32 to i64
%b0:i9:unit = store %b0:i8:i64 %b0:i7:*i64
%b0:i10:*i64 = getelementptr %b0:i0:* struct Sub offset 24:i64
%b0:i11:i64 = typecast 4:i32 to i64
%b0:i12:unit = store %b0:i11:i64 %b0:i10:*i64
%b0:i13:* struct Sub = getelementptr %l0:* struct Big offset 32:i64
%b0:i14:*i64 = getelementptr %b0:i13:* struct Sub offset 0:i64
%b0:i15:i64 = typecast 2:i32 to i64
%b0:i16:unit = store %b0:i5:i64 %b0:i14:*i64
%b0:i17:*i64 = getelementptr %b0:i13:* struct Sub offset 8:i64
%b0:i18:i64 = typecast 3:i32 to i64
%b0:i19:unit = store %b0:i8:i64 %b0:i17:*i64
%b0:i20:*i64 = getelementptr %b0:i13:* struct Sub offset 16:i64
%b0:i21:i64 = typecast 4:i32 to i64
%b0:i22:unit = store %b0:i11:i64 %b0:i20:*i64
%b0:i23:*i64 = getelementptr %b0:i13:* struct Sub offset 24:i64
%b0:i24:i64 = typecast 5:i32 to i64
%b0:i25:unit = store %b0:i24:i64 %b0:i23:*i64
%b0:i26:* struct Sub = getelementptr %l0:* struct Big offset 64:i64
%b0:i27:*i64 = getelementptr %b0:i26:* struct Sub offset 0:i64
%b0:i28:i64 = typecast 3:i32 to i64
%b0:i29:unit = store %b0:i8:i64 %b0:i27:*i64
%b0:i30:*i64 = getelementptr %b0:i26:* struct Sub offset 8:i64
%b0:i31:i64 = typecast 4:i32 to i64
%b0:i32:unit = store %b0:i11:i64 %b0:i30:*i64
%b0:i33:*i64 = getelementptr %b0:i26:* struct Sub offset 16:i64
%b0:i34:i64 = typecast 5:i32 to i64
%b0:i35:unit = store %b0:i24:i64 %b0:i33:*i64
%b0:i36:*i64 = getelementptr %b0:i26:* struct Sub offset 24:i64
%b0:i37:i64 = typecast 6:i32 to i64
%b0:i38:unit = store %b0:i37:i64 %b0:i36:*i64
%b0:i39: struct Big = load %l0:* struct Big
%b0:i40: struct Big = call @foo:*[ret: struct Big params:( struct Big)](%b0:i39: struct Big)
%b0:i41:unit = store %b0:i40: struct Big %l1:* struct Big
%b0:i42:* struct Sub = getelementptr %l1:* struct Big offset 0:i64
%b0:i43:*i64 = getelementptr %b0:i42:* struct Sub offset 0:i64
%b0:i44:i64 = load %b0:i43:*i64
%b0:i45:i64 = typecast 10:i32 to i64
%b0:i46:u1 = cmp eq %b0:i44:i64 %b0:i45:i64
%b0:i47:i32 = typecast %b0:i46:u1 to i32
ret %b0:i47:i32
}

31
examples/ir4/switch.ir Normal file
View File

@@ -0,0 +1,31 @@
fun i32 @main () {
init:
bid: b0
allocations:
block b0:
switch 1:i32 default b4() [
0:i32 b2()
1:i32 b3()
]
block b1:
%b1:p0:i32:b
%b1:i0:u1 = cmp eq %b1:p0:i32 2:i32
%b1:i1:i32 = typecast %b1:i0:u1 to i32
ret %b1:i1:i32
block b2:
%b2:i0:i32 = add 0:i32 1:i32
j b1(%b2:i0:i32)
block b3:
%b3:i0:i32 = add 0:i32 2:i32
j b1(%b3:i0:i32)
block b4:
%b4:i0:i32 = add 0:i32 3:i32
j b1(%b4:i0:i32)
}

28
examples/ir4/temp.ir Normal file
View File

@@ -0,0 +1,28 @@
fun i32 @fibonacci (i32) {
init:
bid: b0
allocations:
block b0:
%b0:i0:i32 = add %b0:p0:i32 %b0:p0:i32
%b0:i1:u1 = cmp ne %b0:i0:i32 0:i32
br %b0:i1:u1, b2(), b3()
block b2:
ret %b0:p0:i32
block b3:
ret undef:i32
}
fun i32 @main () {
init:
bid: b0
allocations:
block b0:
ret 1:i32
}

68
examples/ir4/temp2.ir Normal file
View File

@@ -0,0 +1,68 @@
struct color : { i32, i8 }
fun i32 @main () {
init:
bid: b0
allocations:
%l0: struct color:c
block b0:
%b0:i0:u64 = typecast 0:i32 to u64
%b0:i1:u64 = add %b0:i0:u64 1:u64
%b0:i2:i32 = typecast %b0:i1:u64 to i32
%b0:i3:u64 = typecast %b0:i2:i32 to u64
%b0:i4:u64 = add %b0:i3:u64 1:u64
%b0:i5:i32 = typecast %b0:i4:u64 to i32
%b0:i6:*i32 = getelementptr %l0:* struct color offset 0:i64
%b0:i7:unit = store 1:i32 %b0:i6:*i32
%b0:i8:*i8 = getelementptr %l0:* struct color offset 4:i64
%b0:i9:i8 = typecast 2:i32 to i8
%b0:i10:unit = store %b0:i9:i8 %b0:i8:*i8
%b0:i11:*i8 = getelementptr %l0:* struct color offset 4:i64
%b0:i12:i8 = load %b0:i8:*i8
%b0:i13:i32 = typecast %b0:i12:i8 to i32
%b0:i14:i32 = add %b0:i5:i32 %b0:i13:i32
%b0:i15:*i8 = getelementptr %l0:* struct color offset 4:i64
%b0:i16:i8 = load %b0:i8:*i8
%b0:i17:i32 = typecast %b0:i16:i8 to i32
%b0:i18:i32 = add %b0:i14:i32 %b0:i17:i32
j b2(%b0:i18:i32, 0:i32)
block b2:
%b2:p0:i32:temp
%b2:p1:i32:i
%b2:i0:u1 = cmp lt %b2:p1:i32 10:i32
br %b2:i0:u1, b3(), b5()
block b3:
%b3:i0:u1 = cmp eq %b2:p1:i32 2:i32
br %b3:i0:u1, b9(), b10()
block b5:
switch %b2:p0:i32 default b13(%b2:p0:i32) [
1:i32 b14()
]
block b7:
%b7:i0:i32 = add %b2:p0:i32 %b2:p1:i32
%b7:i1:i32 = add %b2:p1:i32 1:i32
j b2(%b7:i0:i32, %b7:i1:i32)
block b9:
%b9:i0:u1 = cmp eq 0:i32 0:i32
j b11(%b9:i0:u1)
block b10:
j b11(0:u1)
block b11:
%b11:p0:u1:t0
br %b11:p0:u1, b5(), b7()
block b13:
%b13:p0:i32:temp
ret %b13:p0:i32
block b14:
j b13(0:i32)
}

29
examples/ir4/test.ir Normal file
View File

@@ -0,0 +1,29 @@
fun i32 @main () {
init:
bid: b0
allocations:
block b0:
%b0:i0:i64 = typecast 1:i32 to i64
%b0:i1:i64 = typecast 2:i32 to i64
%b0:i2:i64 = typecast 3:i32 to i64
%b0:i3:i16 = typecast 4:i32 to i16
%b0:i4:i16 = typecast 5:i32 to i16
%b0:i5:i8 = typecast 7:i32 to i8
%b0:i6:i64 = add %b0:i0:i64 %b0:i1:i64
%b0:i7:i64 = add %b0:i6:i64 %b0:i2:i64
%b0:i8:i64 = typecast %b0:i3:i16 to i64
%b0:i9:i64 = add %b0:i7:i64 %b0:i8:i64
%b0:i10:i64 = typecast %b0:i4:i16 to i64
%b0:i11:i64 = add %b0:i9:i64 %b0:i10:i64
%b0:i12:i64 = typecast 6:i32 to i64
%b0:i13:i64 = add %b0:i11:i64 %b0:i12:i64
%b0:i14:i64 = typecast %b0:i5:i8 to i64
%b0:i15:i64 = add %b0:i13:i64 %b0:i14:i64
%b0:i16:i64 = typecast 28:i32 to i64
%b0:i17:u1 = cmp eq %b0:i15:i64 %b0:i16:i64
%b0:i18:i32 = typecast %b0:i17:u1 to i32
ret %b0:i18:i32
}

16
examples/ir4/typecast.ir Normal file
View File

@@ -0,0 +1,16 @@
var i8 @temp = 0x00l
fun i32 @main () {
init:
bid: b0
allocations:
block b0:
%b0:i0:i8 = typecast 61238:i64 to i8
%b0:i1:unit = store %b0:i0:i8 @temp:*i8
%b0:i2:i64 = typecast %b0:i0:i8 to i64
%b0:i3:u1 = cmp ge %b0:i2:i64 2:i64
%b0:i4:i32 = typecast %b0:i3:u1 to i32
ret %b0:i4:i32
}

13
examples/ir4/typedef.ir Normal file
View File

@@ -0,0 +1,13 @@
fun i32 @main () {
init:
bid: b0
allocations:
%l0:i32:a
block b0:
%b0:i0:unit = store 0:i32 %l0:*i32
%b0:i1:unit = store 1:i32 %l0:*i32
%b0:i2:i32 = load %l0:*i32
ret %b0:i2:i32
}

15
examples/ir4/unary.ir Normal file
View File

@@ -0,0 +1,15 @@
fun i32 @main () {
init:
bid: b0
allocations:
block b0:
%b0:i0:u8 = typecast 0:i64 to u8
%b0:i1:u8 = sub %b0:i0:u8 1:u8
%b0:i2:i32 = typecast %b0:i1:u8 to i32
%b0:i3:u1 = cmp gt 1:i32 %b0:i2:i32
%b0:i4:i32 = typecast %b0:i3:u1 to i32
ret %b0:i4:i32
}

View File

@@ -0,0 +1,47 @@
fun i32 @foo () {
init:
bid: b0
allocations:
block b0:
j b1(0:i32, 0:i32)
block b1:
%b1:p0:i32:sum
%b1:p1:i32:i
%b1:i0:u1 = cmp lt %b1:p1:i32 10:i32
br %b1:i0:u1, b2(), b3(%b1:p0:i32)
block b2:
%b2:i0:u1 = cmp eq %b1:p1:i32 3:i32
br %b2:i0:u1, b4(), b5()
block b3:
%b3:p0:i32:sum
ret %b3:p0:i32
block b4:
%b4:i0:i32 = add %b1:p1:i32 1:i32
j b1(%b1:p0:i32, %b4:i0:i32)
block b5:
%b5:i0:i32 = add %b1:p0:i32 %b1:p1:i32
%b5:i1:i32 = add %b1:p1:i32 1:i32
%b5:i2:u1 = cmp eq %b5:i1:i32 5:i32
br %b5:i2:u1, b3(%b5:i0:i32), b1(%b5:i0:i32, %b5:i1:i32)
}
fun i32 @main () {
init:
bid: b0
allocations:
block b0:
%b0:i0:i32 = call @foo:*[ret:i32 params:()]()
%b0:i1:u1 = cmp eq %b0:i0:i32 7:i32
%b0:i2:i32 = typecast %b0:i1:u1 to i32
ret %b0:i2:i32
}