Files
cs420/examples/asmgen/fib5.ir
2020-06-05 00:54:00 +09:00

79 lines
1.4 KiB
Plaintext

fun i32 @fibonacci (i32) {
init:
bid: b0
allocations:
%l0:i32:n
%l1:i32:i
%l2:i32:t1
%l3:i32:t2
%l4:i32:next_term
block b0:
%b0:i0:unit = store %b0:p0:i32 %l0:*i32
%b0:i1:unit = store 0:i32 %l1:*i32
%b0:i2:unit = store 0:i32 %l2:*i32
%b0:i3:unit = store 1:i32 %l3:*i32
%b0:i4:unit = store 0:i32 %l4:*i32
%b0:i5:i32 = load %l0:*i32
%b0:i6:u1 = cmp lt %b0:i5:i32 2:i32
br %b0:i6:u1, b1(), b2()
block b1:
%b1:i0:i32 = load %l0:*i32
ret %b1:i0:i32
block b2:
j b3()
block b3:
%b3:i0:unit = store 1:i32 %l1:*i32
j b5()
block b4:
j b3()
block b5:
%b5:i0:i32 = load %l2:*i32
%b5:i1:i32 = load %l3:*i32
%b5:i2:i32 = add %b5:i0:i32 %b5:i1:i32
%b5:i3:unit = store %b5:i2:i32 %l4:*i32
%b5:i4:i32 = load %l3:*i32
%b5:i5:unit = store %b5:i4:i32 %l2:*i32
%b5:i6:i32 = load %l4:*i32
%b5:i7:unit = store %b5:i6:i32 %l3:*i32
%b5:i8:i32 = load %l1:*i32
%b5:i9:i32 = add %b5:i8:i32 1:i32
%b5:i10:unit = store %b5:i9:i32 %l1:*i32
j b6()
block b6:
%b6:i0:i32 = load %l1:*i32
%b6:i1:i32 = load %l0:*i32
%b6:i2:u1 = cmp lt %b6:i0:i32 %b6:i1:i32
br %b6:i2:u1, b5(), b7()
block b7:
%b7:i0:i32 = load %l3:*i32
ret %b7:i0:i32
block b8:
ret undef: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
block b1:
ret 0:i32
}