✨
This commit is contained in:
422
tests/filter.asm
422
tests/filter.asm
@ -2,194 +2,293 @@
|
||||
.globl main
|
||||
la $28, _heap_
|
||||
la $4, _true
|
||||
# was: la _true_addr, _true
|
||||
ori $3, $0, 4
|
||||
# was: ori _true_init, $0, 4
|
||||
sw $3, 0($4)
|
||||
# was: sw _true_init, 0(_true_addr)
|
||||
la $3, _false
|
||||
# was: la _false_addr, _false
|
||||
ori $4, $0, 5
|
||||
# was: ori _false_init, $0, 5
|
||||
sw $4, 0($3)
|
||||
# was: sw _false_init, 0(_false_addr)
|
||||
jal main
|
||||
_stop_:
|
||||
ori $2, $0, 10
|
||||
syscall
|
||||
write_int:
|
||||
sw $31, -4($29)
|
||||
sw $16, -8($29)
|
||||
addi $29, $29, -12
|
||||
ori $16, $2, 0
|
||||
ori $2, $16, 0
|
||||
jal putint
|
||||
ori $2, $16, 0
|
||||
addi $29, $29, 12
|
||||
lw $16, -8($29)
|
||||
lw $31, -4($29)
|
||||
jr $31
|
||||
write_int_arr:
|
||||
sw $31, -4($29)
|
||||
sw $20, -24($29)
|
||||
sw $19, -20($29)
|
||||
sw $18, -16($29)
|
||||
sw $17, -12($29)
|
||||
sw $16, -8($29)
|
||||
addi $29, $29, -28
|
||||
lw $16, 0($2)
|
||||
ori $17, $28, 0
|
||||
sll $3, $16, 2
|
||||
addi $3, $3, 4
|
||||
add $28, $28, $3
|
||||
sw $16, 0($17)
|
||||
addi $18, $17, 4
|
||||
ori $19, $0, 0
|
||||
addi $20, $2, 4
|
||||
_loop_beg_12_:
|
||||
sub $2, $19, $16
|
||||
bgez $2, _loop_end_13_
|
||||
lw $2, 0($20)
|
||||
addi $20, $20, 4
|
||||
jal write_int
|
||||
sw $2, 0($18)
|
||||
addi $18, $18, 4
|
||||
addi $19, $19, 1
|
||||
j _loop_beg_12_
|
||||
_loop_end_13_:
|
||||
ori $2, $17, 0
|
||||
addi $29, $29, 28
|
||||
lw $20, -24($29)
|
||||
lw $19, -20($29)
|
||||
lw $18, -16($29)
|
||||
lw $17, -12($29)
|
||||
lw $16, -8($29)
|
||||
lw $31, -4($29)
|
||||
jr $31
|
||||
isMul16:
|
||||
sw $31, -4($29)
|
||||
addi $29, $29, -8
|
||||
ori $3, $0, 16
|
||||
div $4, $2, $3
|
||||
ori $3, $0, 16
|
||||
mul $3, $4, $3
|
||||
ori $4, $0, 0
|
||||
bne $3, $2, _false_25_
|
||||
ori $4, $0, 1
|
||||
_false_25_:
|
||||
ori $2, $4, 0
|
||||
addi $29, $29, 8
|
||||
lw $31, -4($29)
|
||||
jr $31
|
||||
# Function main
|
||||
main:
|
||||
sw $31, -4($29)
|
||||
sw $22, -32($29)
|
||||
sw $21, -28($29)
|
||||
sw $20, -24($29)
|
||||
sw $19, -20($29)
|
||||
sw $18, -16($29)
|
||||
sw $17, -12($29)
|
||||
sw $16, -8($29)
|
||||
addi $29, $29, -36
|
||||
addi $29, $29, -32
|
||||
jal getint
|
||||
bgez $2, _safe_lab_35_
|
||||
# was: jal getint, $2
|
||||
# ori _letBind_2_,$2,0
|
||||
# ori _size_reg_9_,_letBind_2_,0
|
||||
bgez $2, _safe_lab_10_
|
||||
# was: bgez _size_reg_9_, _safe_lab_10_
|
||||
ori $5, $0, 10
|
||||
# was: ori $5, $0, 10
|
||||
la $6, _Msg_IllegalArraySize_
|
||||
# was: la $6, _Msg_IllegalArraySize_
|
||||
j _RuntimeError_
|
||||
_safe_lab_35_:
|
||||
_safe_lab_10_:
|
||||
# dynalloc
|
||||
ori $7, $28, 0
|
||||
# was: ori _arr_reg_5_, $28, 0
|
||||
sll $3, $2, 2
|
||||
# was: sll _tmp_16_, _size_reg_9_, 2
|
||||
addi $3, $3, 4
|
||||
# was: addi _tmp_16_, _tmp_16_, 4
|
||||
add $28, $28, $3
|
||||
# was: add $28, $28, _tmp_16_
|
||||
sw $2, 0($7)
|
||||
addi $3, $7, 4
|
||||
ori $5, $0, 0
|
||||
_loop_beg_38_:
|
||||
sub $4, $5, $2
|
||||
bgez $4, _loop_end_39_
|
||||
sw $5, 0($3)
|
||||
addi $3, $3, 4
|
||||
addi $5, $5, 1
|
||||
j _loop_beg_38_
|
||||
_loop_end_39_:
|
||||
lw $3, 0($7)
|
||||
ori $2, $28, 0
|
||||
sll $4, $3, 2
|
||||
addi $4, $4, 4
|
||||
add $28, $28, $4
|
||||
sw $3, 0($2)
|
||||
addi $4, $2, 4
|
||||
ori $6, $0, 0
|
||||
ori $5, $0, 0
|
||||
addi $7, $7, 4
|
||||
_loop_beg_45_:
|
||||
sub $8, $6, $3
|
||||
bgez $8, _loop_end_46_
|
||||
lw $10, 0($7)
|
||||
addi $7, $7, 4
|
||||
ori $9, $10, 0
|
||||
ori $8, $0, 2
|
||||
div $8, $9, $8
|
||||
ori $9, $0, 2
|
||||
mul $9, $8, $9
|
||||
ori $8, $0, 0
|
||||
bne $10, $9, _false_56_
|
||||
ori $8, $0, 1
|
||||
_false_56_:
|
||||
beq $8, $0, _not_true_47_
|
||||
sw $10, 0($4)
|
||||
addi $5, $5, 1
|
||||
addi $4, $4, 4
|
||||
_not_true_47_:
|
||||
addi $6, $6, 1
|
||||
j _loop_beg_45_
|
||||
_loop_end_46_:
|
||||
sw $5, 0($2)
|
||||
lw $5, 0($2)
|
||||
ori $4, $28, 0
|
||||
sll $3, $5, 2
|
||||
addi $3, $3, 4
|
||||
add $28, $28, $3
|
||||
sw $5, 0($4)
|
||||
addi $7, $4, 4
|
||||
ori $6, $0, 0
|
||||
addi $3, $2, 4
|
||||
_loop_beg_65_:
|
||||
sub $2, $6, $5
|
||||
bgez $2, _loop_end_66_
|
||||
lw $2, 0($3)
|
||||
addi $3, $3, 4
|
||||
ori $8, $2, 0
|
||||
mul $2, $8, $2
|
||||
sw $2, 0($7)
|
||||
addi $7, $7, 4
|
||||
addi $6, $6, 1
|
||||
j _loop_beg_65_
|
||||
_loop_end_66_:
|
||||
lw $17, 0($4)
|
||||
ori $16, $28, 0
|
||||
sll $2, $17, 2
|
||||
# was: sw _size_reg_9_, 0(_arr_reg_5_)
|
||||
addi $5, $7, 4
|
||||
# was: addi _addr_reg_11_, _arr_reg_5_, 4
|
||||
ori $3, $0, 0
|
||||
# was: ori _i_reg_12_, $0, 0
|
||||
_loop_beg_13_:
|
||||
sub $4, $3, $2
|
||||
# was: sub _tmp_reg_15_, _i_reg_12_, _size_reg_9_
|
||||
bgez $4, _loop_end_14_
|
||||
# was: bgez _tmp_reg_15_, _loop_end_14_
|
||||
sw $3, 0($5)
|
||||
# was: sw _i_reg_12_, 0(_addr_reg_11_)
|
||||
addi $5, $5, 4
|
||||
# was: addi _addr_reg_11_, _addr_reg_11_, 4
|
||||
addi $3, $3, 1
|
||||
# was: addi _i_reg_12_, _i_reg_12_, 1
|
||||
j _loop_beg_13_
|
||||
_loop_end_14_:
|
||||
lw $5, 0($7)
|
||||
# was: lw _size_reg_4_, 0(_arr_reg_5_)
|
||||
# dynalloc
|
||||
ori $6, $28, 0
|
||||
# was: ori _letBind_3_, $28, 0
|
||||
sll $2, $5, 2
|
||||
# was: sll _tmp_32_, _size_reg_4_, 2
|
||||
addi $2, $2, 4
|
||||
# was: addi _tmp_32_, _tmp_32_, 4
|
||||
add $28, $28, $2
|
||||
sw $17, 0($16)
|
||||
addi $19, $16, 4
|
||||
ori $18, $0, 0
|
||||
ori $20, $0, 0
|
||||
addi $21, $4, 4
|
||||
_loop_beg_81_:
|
||||
sub $2, $18, $17
|
||||
bgez $2, _loop_end_82_
|
||||
lw $22, 0($21)
|
||||
addi $21, $21, 4
|
||||
ori $2, $22, 0
|
||||
jal isMul16
|
||||
beq $2, $0, _not_true_83_
|
||||
sw $22, 0($19)
|
||||
addi $20, $20, 1
|
||||
addi $19, $19, 4
|
||||
_not_true_83_:
|
||||
addi $18, $18, 1
|
||||
j _loop_beg_81_
|
||||
_loop_end_82_:
|
||||
sw $20, 0($16)
|
||||
ori $2, $16, 0
|
||||
jal write_int_arr
|
||||
addi $29, $29, 36
|
||||
lw $22, -32($29)
|
||||
# was: add $28, $28, _tmp_32_
|
||||
sw $5, 0($6)
|
||||
# was: sw _size_reg_4_, 0(_letBind_3_)
|
||||
addi $4, $6, 4
|
||||
# was: addi _addr_reg_17_, _letBind_3_, 4
|
||||
ori $3, $0, 0
|
||||
# was: ori _i_reg_18_, $0, 0
|
||||
ori $2, $0, 0
|
||||
# was: ori _j_reg_19_, $0, 0
|
||||
addi $7, $7, 4
|
||||
# was: addi _elem_reg_6_, _arr_reg_5_, 4
|
||||
_loop_beg_20_:
|
||||
sub $8, $3, $5
|
||||
# was: sub _tmp_reg_23_, _i_reg_18_, _size_reg_4_
|
||||
bgez $8, _loop_end_21_
|
||||
# was: bgez _tmp_reg_23_, _loop_end_21_
|
||||
lw $10, 0($7)
|
||||
# was: lw _res_reg_7_, 0(_elem_reg_6_)
|
||||
addi $7, $7, 4
|
||||
# was: addi _elem_reg_6_, _elem_reg_6_, 4
|
||||
# ori _eq_L_25_,_res_reg_7_,0
|
||||
ori $9, $10, 0
|
||||
# was: ori _divide_L_29_, _res_reg_7_, 0
|
||||
ori $8, $0, 2
|
||||
# was: ori _divide_R_30_, $0, 2
|
||||
div $9, $9, $8
|
||||
# was: div _times_L_27_, _divide_L_29_, _divide_R_30_
|
||||
ori $8, $0, 2
|
||||
# was: ori _times_R_28_, $0, 2
|
||||
mul $9, $9, $8
|
||||
# was: mul _eq_R_26_, _times_L_27_, _times_R_28_
|
||||
ori $8, $0, 0
|
||||
# was: ori _fun_arg_res_24_, $0, 0
|
||||
bne $10, $9, _false_31_
|
||||
# was: bne _eq_L_25_, _eq_R_26_, _false_31_
|
||||
ori $8, $0, 1
|
||||
# was: ori _fun_arg_res_24_, $0, 1
|
||||
_false_31_:
|
||||
# ori _bool_reg_8_,_fun_arg_res_24_,0
|
||||
beq $8, $0, _not_true_22_
|
||||
# was: beq _bool_reg_8_, $0, _not_true_22_
|
||||
sw $10, 0($4)
|
||||
# was: sw _res_reg_7_, 0(_addr_reg_17_)
|
||||
addi $2, $2, 1
|
||||
# was: addi _j_reg_19_, _j_reg_19_, 1
|
||||
addi $4, $4, 4
|
||||
# was: addi _addr_reg_17_, _addr_reg_17_, 4
|
||||
_not_true_22_:
|
||||
addi $3, $3, 1
|
||||
# was: addi _i_reg_18_, _i_reg_18_, 1
|
||||
j _loop_beg_20_
|
||||
_loop_end_21_:
|
||||
sw $2, 0($6)
|
||||
# was: sw _j_reg_19_, 0(_letBind_3_)
|
||||
# map
|
||||
ori $2, $6, 0
|
||||
# was: ori _arr_reg_35_, _letBind_3_, 0
|
||||
lw $3, 0($2)
|
||||
# was: lw _size_reg_34_, 0(_arr_reg_35_)
|
||||
# dynalloc
|
||||
ori $4, $28, 0
|
||||
# was: ori _letBind_33_, $28, 0
|
||||
sll $5, $3, 2
|
||||
# was: sll _tmp_46_, _size_reg_34_, 2
|
||||
addi $5, $5, 4
|
||||
# was: addi _tmp_46_, _tmp_46_, 4
|
||||
add $28, $28, $5
|
||||
# was: add $28, $28, _tmp_46_
|
||||
sw $3, 0($4)
|
||||
# was: sw _size_reg_34_, 0(_letBind_33_)
|
||||
addi $6, $4, 4
|
||||
# was: addi _addr_reg_38_, _letBind_33_, 4
|
||||
ori $5, $0, 0
|
||||
# was: ori _i_reg_39_, $0, 0
|
||||
addi $2, $2, 4
|
||||
# was: addi _elem_reg_36_, _arr_reg_35_, 4
|
||||
_loop_beg_40_:
|
||||
sub $7, $5, $3
|
||||
# was: sub _tmp_reg_42_, _i_reg_39_, _size_reg_34_
|
||||
bgez $7, _loop_end_41_
|
||||
# was: bgez _tmp_reg_42_, _loop_end_41_
|
||||
lw $7, 0($2)
|
||||
# was: lw _res_reg_37_, 0(_elem_reg_36_)
|
||||
addi $2, $2, 4
|
||||
# was: addi _elem_reg_36_, _elem_reg_36_, 4
|
||||
# ori _times_L_44_,_res_reg_37_,0
|
||||
ori $8, $7, 0
|
||||
# was: ori _times_R_45_, _res_reg_37_, 0
|
||||
mul $7, $7, $8
|
||||
# was: mul _fun_arg_res_43_, _times_L_44_, _times_R_45_
|
||||
# ori _res_reg_37_,_fun_arg_res_43_,0
|
||||
sw $7, 0($6)
|
||||
# was: sw _res_reg_37_, 0(_addr_reg_38_)
|
||||
addi $6, $6, 4
|
||||
# was: addi _addr_reg_38_, _addr_reg_38_, 4
|
||||
addi $5, $5, 1
|
||||
# was: addi _i_reg_39_, _i_reg_39_, 1
|
||||
j _loop_beg_40_
|
||||
_loop_end_41_:
|
||||
ori $2, $4, 0
|
||||
# was: ori _arr_reg_49_, _letBind_33_, 0
|
||||
lw $4, 0($2)
|
||||
# was: lw _size_reg_48_, 0(_arr_reg_49_)
|
||||
# dynalloc
|
||||
ori $5, $28, 0
|
||||
# was: ori _letBind_47_, $28, 0
|
||||
sll $3, $4, 2
|
||||
# was: sll _tmp_68_, _size_reg_48_, 2
|
||||
addi $3, $3, 4
|
||||
# was: addi _tmp_68_, _tmp_68_, 4
|
||||
add $28, $28, $3
|
||||
# was: add $28, $28, _tmp_68_
|
||||
sw $4, 0($5)
|
||||
# was: sw _size_reg_48_, 0(_letBind_47_)
|
||||
addi $7, $5, 4
|
||||
# was: addi _addr_reg_53_, _letBind_47_, 4
|
||||
ori $6, $0, 0
|
||||
# was: ori _i_reg_54_, $0, 0
|
||||
ori $8, $0, 0
|
||||
# was: ori _j_reg_55_, $0, 0
|
||||
addi $9, $2, 4
|
||||
# was: addi _elem_reg_50_, _arr_reg_49_, 4
|
||||
_loop_beg_56_:
|
||||
sub $2, $6, $4
|
||||
# was: sub _tmp_reg_59_, _i_reg_54_, _size_reg_48_
|
||||
bgez $2, _loop_end_57_
|
||||
# was: bgez _tmp_reg_59_, _loop_end_57_
|
||||
lw $10, 0($9)
|
||||
# was: lw _res_reg_51_, 0(_elem_reg_50_)
|
||||
addi $9, $9, 4
|
||||
# was: addi _elem_reg_50_, _elem_reg_50_, 4
|
||||
# ori _divide_L_65_,_res_reg_51_,0
|
||||
ori $2, $0, 16
|
||||
# was: ori _divide_R_66_, $0, 16
|
||||
div $2, $10, $2
|
||||
# was: div _times_L_63_, _divide_L_65_, _divide_R_66_
|
||||
ori $3, $0, 16
|
||||
# was: ori _times_R_64_, $0, 16
|
||||
mul $2, $2, $3
|
||||
# was: mul _eq_L_61_, _times_L_63_, _times_R_64_
|
||||
# ori _eq_R_62_,_res_reg_51_,0
|
||||
ori $3, $0, 0
|
||||
# was: ori _fun_arg_res_60_, $0, 0
|
||||
bne $2, $10, _false_67_
|
||||
# was: bne _eq_L_61_, _eq_R_62_, _false_67_
|
||||
ori $3, $0, 1
|
||||
# was: ori _fun_arg_res_60_, $0, 1
|
||||
_false_67_:
|
||||
# ori _bool_reg_52_,_fun_arg_res_60_,0
|
||||
beq $3, $0, _not_true_58_
|
||||
# was: beq _bool_reg_52_, $0, _not_true_58_
|
||||
sw $10, 0($7)
|
||||
# was: sw _res_reg_51_, 0(_addr_reg_53_)
|
||||
addi $8, $8, 1
|
||||
# was: addi _j_reg_55_, _j_reg_55_, 1
|
||||
addi $7, $7, 4
|
||||
# was: addi _addr_reg_53_, _addr_reg_53_, 4
|
||||
_not_true_58_:
|
||||
addi $6, $6, 1
|
||||
# was: addi _i_reg_54_, _i_reg_54_, 1
|
||||
j _loop_beg_56_
|
||||
_loop_end_57_:
|
||||
sw $8, 0($5)
|
||||
# was: sw _j_reg_55_, 0(_letBind_47_)
|
||||
# map
|
||||
# ori _arr_reg_70_,_letBind_47_,0
|
||||
lw $16, 0($5)
|
||||
# was: lw _size_reg_69_, 0(_arr_reg_70_)
|
||||
# dynalloc
|
||||
ori $17, $28, 0
|
||||
# was: ori _mainres_1_, $28, 0
|
||||
sll $2, $16, 2
|
||||
# was: sll _tmp_80_, _size_reg_69_, 2
|
||||
addi $2, $2, 4
|
||||
# was: addi _tmp_80_, _tmp_80_, 4
|
||||
add $28, $28, $2
|
||||
# was: add $28, $28, _tmp_80_
|
||||
sw $16, 0($17)
|
||||
# was: sw _size_reg_69_, 0(_mainres_1_)
|
||||
addi $18, $17, 4
|
||||
# was: addi _addr_reg_73_, _mainres_1_, 4
|
||||
ori $19, $0, 0
|
||||
# was: ori _i_reg_74_, $0, 0
|
||||
addi $20, $5, 4
|
||||
# was: addi _elem_reg_71_, _arr_reg_70_, 4
|
||||
_loop_beg_75_:
|
||||
sub $2, $19, $16
|
||||
# was: sub _tmp_reg_77_, _i_reg_74_, _size_reg_69_
|
||||
bgez $2, _loop_end_76_
|
||||
# was: bgez _tmp_reg_77_, _loop_end_76_
|
||||
lw $21, 0($20)
|
||||
# was: lw _res_reg_72_, 0(_elem_reg_71_)
|
||||
addi $20, $20, 4
|
||||
# was: addi _elem_reg_71_, _elem_reg_71_, 4
|
||||
# ori _tmp_79_,_res_reg_72_,0
|
||||
# ori _fun_arg_res_78_,_tmp_79_,0
|
||||
ori $2, $21, 0
|
||||
# was: ori $2, _fun_arg_res_78_, 0
|
||||
jal putint
|
||||
# was: jal putint, $2
|
||||
# ori _res_reg_72_,_fun_arg_res_78_,0
|
||||
sw $21, 0($18)
|
||||
# was: sw _res_reg_72_, 0(_addr_reg_73_)
|
||||
addi $18, $18, 4
|
||||
# was: addi _addr_reg_73_, _addr_reg_73_, 4
|
||||
addi $19, $19, 1
|
||||
# was: addi _i_reg_74_, _i_reg_74_, 1
|
||||
j _loop_beg_75_
|
||||
_loop_end_76_:
|
||||
ori $2, $17, 0
|
||||
# was: ori $2, _mainres_1_, 0
|
||||
addi $29, $29, 32
|
||||
lw $21, -28($29)
|
||||
lw $20, -24($29)
|
||||
lw $19, -20($29)
|
||||
@ -292,6 +391,7 @@ _RuntimeError_:
|
||||
syscall
|
||||
j _stop_
|
||||
.data
|
||||
# Fixed strings for I/O
|
||||
_ErrMsg_:
|
||||
.asciiz "Runtime error at line "
|
||||
_colon_space_:
|
||||
@ -300,12 +400,14 @@ _cr_:
|
||||
.asciiz "\n"
|
||||
_space_:
|
||||
.asciiz " "
|
||||
# Message strings for specific errors
|
||||
_Msg_IllegalArraySize_:
|
||||
.asciiz "negative array size"
|
||||
_Msg_IllegalIndex_:
|
||||
.asciiz "array index out of bounds"
|
||||
_Msg_DivZero_:
|
||||
.asciiz "division by zero"
|
||||
# String Literals
|
||||
.align 2
|
||||
_true:
|
||||
.space 4
|
||||
|
Reference in New Issue
Block a user