fun i32 @main { init: bid: b0 allocations: %l0:[5 x i32]:a %l1:i32:len %l2:i32:i block b0: %b0:i0:unit = store 5:i32 %l1:*i32 j b1() block b1: %b1:i0:unit = store 0:i32 %l2:*i32 j b2() block b2: %b2:i0:i32 = load %l2:*i32 %b2:i1:i32 = load %l1:*i32 %b2:i2:u1 = cmp lt %b2:i0:i32 %b2:i1:i32 br %b2:i2:u1, b3(), b5() block b3: %b3:i0:*i32 = getelementptr %l0 offset 0 %b3:i1:i32 = load %l2:*i32 %b3:i2:i64 = typecast %b3:i1:i32 to i64 %b3:i3:i64 = mul %b3:i2:i64 4:i64 %b3:i4:*i32 = getelementptr %b3:i0 offset %b3:i3 %b3:i5:i32 = load %l2:*i32 %b3:i6:unit = store %b3:i5:i32 %b3:i4:*i32 j b4() block b4: %b4:i0:i32 = load %l2:*i32 %b4:i1:i32 = add %b4:i0:i32 1:i32 %b4:i2:unit = store %b4:i1:i32 %l2:*i32 j b2() block b5: %b5:i0:i32 = load %l1:*i32 %b5:i1:*i32 = getelementptr %l0 offset 0 %b5:i2:i32 = call @sum(%b5:i0:i32, %b5:i1:*i32) %b5:i3:u1 = cmp eq %b5:i2:i32 10:i32 %b5:i4:i32 = typecast %b5:i3:u1 to i32 ret %b5:i4:i32 block b6: ret 0:i32 } fun i32 @sum { init: bid: b0 allocations: %l0:i32:len %l1:*i32:p %l2:i32:result %l3:i32:i block b0: %b0:i0:unit = store %b0:p0:i32 %l0:*i32 %b0:i1:unit = store %b0:p1:*i32 %l1:**i32 %b0:i2:unit = store 0:i32 %l2:*i32 j b1() block b1: %b1:i0:unit = store 0:i32 %l3:*i32 j b2() block b2: %b2:i0:i32 = load %l3:*i32 %b2:i1:i32 = load %l0:*i32 %b2:i2:u1 = cmp lt %b2:i0:i32 %b2:i1:i32 br %b2:i2:u1, b3(), b5() block b3: %b3:i0:i32 = load %l2:*i32 %b3:i1:*i32 = load %l1:**i32 %b3:i2:i32 = load %l3:*i32 %b3:i3:i64 = typecast %b3:i2:i32 to i64 %b3:i4:i64 = mul %b3:i3:i64 4:i64 %b3:i5:*i32 = getelementptr %b3:i1 offset %b3:i4 %b3:i6:i32 = load %b3:i5:*i32 %b3:i7:i32 = add %b3:i0:i32 %b3:i6:i32 %b3:i8:unit = store %b3:i7:i32 %l2:*i32 j b4() 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 %l2:*i32 ret %b5:i0:i32 block b6: ret undef:i32 }