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

119 lines
2.7 KiB
Plaintext

struct color : { i32, i8 }
fun i32 @main () {
init:
bid: b0
allocations:
%l0:i32:temp
%l1: struct color:c
%l2:* struct color:cp
%l3:i32:i
%l4:i32:j
%l5:u1:t0
block b0:
%b0:i0:unit = store 0:i32 %l0:*i32
%b0:i1:i32 = load %l0:*i32
%b0:i2:u64 = typecast %b0:i1:i32 to u64
%b0:i3:u64 = add %b0:i2:u64 1:u64
%b0:i4:i32 = typecast %b0:i3:u64 to i32
%b0:i5:unit = store %b0:i4:i32 %l0:*i32
%b0:i6:i32 = load %l0:*i32
%b0:i7:u64 = typecast %b0:i6:i32 to u64
%b0:i8:u64 = add %b0:i7:u64 1:u64
%b0:i9:i32 = typecast %b0:i8:u64 to i32
%b0:i10:unit = store %b0:i9:i32 %l0:*i32
%b0:i11:*i32 = getelementptr %l1:* struct color offset 0:i64
%b0:i12:unit = store 1:i32 %b0:i11:*i32
%b0:i13:*i8 = getelementptr %l1:* struct color offset 4:i64
%b0:i14:i8 = typecast 2:i32 to i8
%b0:i15:unit = store %b0:i14:i8 %b0:i13:*i8
%b0:i16:i32 = load %l0:*i32
%b0:i17:*i8 = getelementptr %l1:* struct color offset 4:i64
%b0:i18:i8 = load %b0:i17:*i8
%b0:i19:i32 = typecast %b0:i18:i8 to i32
%b0:i20:i32 = add %b0:i16:i32 %b0:i19:i32
%b0:i21:unit = store %b0:i20:i32 %l0:*i32
%b0:i22: struct color = load %l1:* struct color
%b0:i23:unit = store %l1:* struct color %l2:** struct color
%b0:i24:i32 = load %l0:*i32
%b0:i25:* struct color = load %l2:** struct color
%b0:i26:*i8 = getelementptr %b0:i25:* struct color offset 4:i64
%b0:i27:i8 = load %b0:i26:*i8
%b0:i28:i32 = typecast %b0:i27:i8 to i32
%b0:i29:i32 = add %b0:i24:i32 %b0:i28:i32
%b0:i30:unit = store %b0:i29:i32 %l0:*i32
j b1()
block b1:
%b1:i0:unit = store 0:i32 %l3:*i32
%b1:i1:unit = store 0:i32 %l4:*i32
j b2()
block b2:
%b2:i0:i32 = load %l3:*i32
%b2:i1:u1 = cmp lt %b2:i0:i32 10:i32
br %b2:i1:u1, b3(), b5()
block b3:
%b3:i0:i32 = load %l3:*i32
%b3:i1:u1 = cmp eq %b3:i0:i32 2:i32
br %b3:i1:u1, b9(), b10()
block b4:
%b4:i0:i32 = load %l3:*i32
%b4:i1:i32 = add %b4:i0:i32 1:i32
%b4:i2:unit = store %b4:i1:i32 %l3:*i32
j b2()
block b5:
%b5:i0:i32 = load %l0:*i32
switch %b5:i0:i32 default b15() [
1:i32 b14()
]
block b6:
j b5()
block b7:
j b8()
block b8:
%b8:i0:i32 = load %l0:*i32
%b8:i1:i32 = load %l3:*i32
%b8:i2:i32 = add %b8:i0:i32 %b8:i1:i32
%b8:i3:unit = store %b8:i2:i32 %l0:*i32
j b4()
block b9:
%b9:i0:i32 = load %l4:*i32
%b9:i1:u1 = cmp eq %b9:i0:i32 0:i32
%b9:i2:unit = store %b9:i1:u1 %l5:*u1
j b11()
block b10:
%b10:i0:unit = store 0:u1 %l5:*u1
j b11()
block b11:
%b11:i0:u1 = load %l5:*u1
br %b11:i0:u1, b6(), b7()
block b12:
j b8()
block b13:
%b13:i0:i32 = load %l0:*i32
ret %b13:i0:i32
block b14:
%b14:i0:unit = store 0:i32 %l0:*i32
j b13()
block b15:
j b13()
block b16:
ret 0:i32
}