✨
This commit is contained in:
265
tests/scan.asm
265
tests/scan.asm
@ -17,138 +17,169 @@
|
||||
_stop_:
|
||||
ori $2, $0, 10
|
||||
syscall
|
||||
# Function incr
|
||||
incr:
|
||||
sw $31, -4($29)
|
||||
addi $29, $29, -8
|
||||
# ori _param_a_1_,$2,0
|
||||
# ori _param_b_2_,$3,0
|
||||
# ori _plus_L_4_,_param_a_1_,0
|
||||
# ori _plus_R_5_,_param_b_2_,0
|
||||
add $2, $2, $3
|
||||
# was: add _incrres_3_, _plus_L_4_, _plus_R_5_
|
||||
# ori $2,_incrres_3_,0
|
||||
addi $29, $29, 8
|
||||
lw $31, -4($29)
|
||||
jr $31
|
||||
# Function writeInt
|
||||
writeInt:
|
||||
sw $31, -4($29)
|
||||
sw $16, -8($29)
|
||||
addi $29, $29, -12
|
||||
# ori _param_n_6_,$2,0
|
||||
ori $16, $2, 0
|
||||
# was: ori _tmp_8_, _param_n_6_, 0
|
||||
# ori _writeIntres_7_,_tmp_8_,0
|
||||
ori $2, $16, 0
|
||||
# was: ori $2, _writeIntres_7_, 0
|
||||
jal putint
|
||||
# was: jal putint, $2
|
||||
ori $2, $16, 0
|
||||
# was: ori $2, _writeIntres_7_, 0
|
||||
addi $29, $29, 12
|
||||
lw $16, -8($29)
|
||||
lw $31, -4($29)
|
||||
jr $31
|
||||
# Function main
|
||||
main:
|
||||
sw $31, -4($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, -32
|
||||
ori $4, $0, 3
|
||||
# was: ori _size_reg_3_, $0, 3
|
||||
ori $3, $28, 0
|
||||
# was: ori _letBind_2_, $28, 0
|
||||
sll $2, $4, 2
|
||||
# was: sll _tmp_6_, _size_reg_3_, 2
|
||||
addi $2, $2, 4
|
||||
# was: addi _tmp_6_, _tmp_6_, 4
|
||||
add $28, $28, $2
|
||||
# was: add $28, $28, _tmp_6_
|
||||
sw $4, 0($3)
|
||||
# was: sw _size_reg_3_, 0(_letBind_2_)
|
||||
addi $4, $3, 4
|
||||
# was: addi _addr_reg_4_, _letBind_2_, 4
|
||||
ori $2, $0, 1
|
||||
# was: ori _tmp_reg_5_, $0, 1
|
||||
sw $2, 0($4)
|
||||
# was: sw _tmp_reg_5_, 0(_addr_reg_4_)
|
||||
addi $4, $4, 4
|
||||
# was: addi _addr_reg_4_, _addr_reg_4_, 4
|
||||
ori $2, $0, 2
|
||||
# was: ori _tmp_reg_5_, $0, 2
|
||||
sw $2, 0($4)
|
||||
# was: sw _tmp_reg_5_, 0(_addr_reg_4_)
|
||||
addi $4, $4, 4
|
||||
# was: addi _addr_reg_4_, _addr_reg_4_, 4
|
||||
addi $29, $29, -28
|
||||
ori $2, $0, 3
|
||||
# was: ori _tmp_reg_5_, $0, 3
|
||||
sw $2, 0($4)
|
||||
# was: sw _tmp_reg_5_, 0(_addr_reg_4_)
|
||||
# was: ori _size_reg_11_, $0, 3
|
||||
ori $3, $28, 0
|
||||
# was: ori _letBind_10_, $28, 0
|
||||
sll $4, $2, 2
|
||||
# was: sll _tmp_14_, _size_reg_11_, 2
|
||||
addi $4, $4, 4
|
||||
# was: addi _addr_reg_4_, _addr_reg_4_, 4
|
||||
# ori _inp_reg_9_,_letBind_2_,0
|
||||
ori $8, $0, 0
|
||||
# was: ori _acc_reg_13_, $0, 0
|
||||
lw $4, 0($3)
|
||||
# was: lw _size_reg_10_, 0(_inp_reg_9_)
|
||||
addi $3, $3, 4
|
||||
# was: addi _inp_reg_9_, _inp_reg_9_, 4
|
||||
ori $2, $28, 0
|
||||
# was: ori _letBind_7_, $28, 0
|
||||
sll $5, $4, 2
|
||||
# was: sll _tmp_16_, _size_reg_10_, 2
|
||||
addi $5, $5, 4
|
||||
# was: addi _tmp_16_, _tmp_16_, 4
|
||||
add $28, $28, $5
|
||||
# was: add $28, $28, _tmp_16_
|
||||
# was: addi _tmp_14_, _tmp_14_, 4
|
||||
add $28, $28, $4
|
||||
# was: add $28, $28, _tmp_14_
|
||||
sw $2, 0($3)
|
||||
# was: sw _size_reg_11_, 0(_letBind_10_)
|
||||
addi $2, $3, 4
|
||||
# was: addi _addr_reg_12_, _letBind_10_, 4
|
||||
ori $4, $0, 1
|
||||
# was: ori _tmp_reg_13_, $0, 1
|
||||
sw $4, 0($2)
|
||||
# was: sw _size_reg_10_, 0(_letBind_7_)
|
||||
addi $6, $2, 4
|
||||
# was: addi _res_reg_8_, _letBind_7_, 4
|
||||
ori $5, $0, 0
|
||||
# was: ori _ind_var_11_, $0, 0
|
||||
_loop_beg_14_:
|
||||
sub $7, $5, $4
|
||||
# was: sub _tmp_reg_12_, _ind_var_11_, _size_reg_10_
|
||||
bgez $7, _loop_end_15_
|
||||
# was: bgez _tmp_reg_12_, _loop_end_15_
|
||||
lw $7, 0($3)
|
||||
# was: lw _tmp_reg_12_, 0(_inp_reg_9_)
|
||||
# ori _plus_L_18_,_acc_reg_13_,0
|
||||
# ori _plus_R_19_,_tmp_reg_12_,0
|
||||
add $8, $8, $7
|
||||
# was: add _fun_arg_res_17_, _plus_L_18_, _plus_R_19_
|
||||
# ori _acc_reg_13_,_fun_arg_res_17_,0
|
||||
sw $8, 0($6)
|
||||
# was: sw _acc_reg_13_, 0(_res_reg_8_)
|
||||
addi $6, $6, 4
|
||||
# was: addi _res_reg_8_, _res_reg_8_, 4
|
||||
addi $3, $3, 4
|
||||
# was: addi _inp_reg_9_, _inp_reg_9_, 4
|
||||
addi $5, $5, 1
|
||||
# was: addi _ind_var_11_, _ind_var_11_, 1
|
||||
j _loop_beg_14_
|
||||
_loop_end_15_:
|
||||
# ori _arr_reg_21_,_letBind_7_,0
|
||||
lw $17, 0($2)
|
||||
# was: lw _size_reg_20_, 0(_arr_reg_21_)
|
||||
# was: sw _tmp_reg_13_, 0(_addr_reg_12_)
|
||||
addi $2, $2, 4
|
||||
# was: addi _addr_reg_12_, _addr_reg_12_, 4
|
||||
ori $4, $0, 2
|
||||
# was: ori _tmp_reg_13_, $0, 2
|
||||
sw $4, 0($2)
|
||||
# was: sw _tmp_reg_13_, 0(_addr_reg_12_)
|
||||
addi $2, $2, 4
|
||||
# was: addi _addr_reg_12_, _addr_reg_12_, 4
|
||||
ori $4, $0, 3
|
||||
# was: ori _tmp_reg_13_, $0, 3
|
||||
sw $4, 0($2)
|
||||
# was: sw _tmp_reg_13_, 0(_addr_reg_12_)
|
||||
addi $2, $2, 4
|
||||
# was: addi _addr_reg_12_, _addr_reg_12_, 4
|
||||
# ori _arr_reg_17_,_letBind_10_,0
|
||||
ori $2, $0, 0
|
||||
# was: ori _nelem_reg_20_, $0, 0
|
||||
lw $17, 0($3)
|
||||
# was: lw _size_reg_16_, 0(_arr_reg_17_)
|
||||
ori $16, $28, 0
|
||||
# was: ori _mainres_1_, $28, 0
|
||||
sll $3, $17, 2
|
||||
# was: sll _tmp_31_, _size_reg_20_, 2
|
||||
addi $3, $3, 4
|
||||
# was: addi _tmp_31_, _tmp_31_, 4
|
||||
add $28, $28, $3
|
||||
# was: add $28, $28, _tmp_31_
|
||||
# was: ori _letBind_15_, $28, 0
|
||||
sll $4, $17, 2
|
||||
# was: sll _tmp_27_, _size_reg_16_, 2
|
||||
addi $4, $4, 4
|
||||
# was: addi _tmp_27_, _tmp_27_, 4
|
||||
add $28, $28, $4
|
||||
# was: add $28, $28, _tmp_27_
|
||||
sw $17, 0($16)
|
||||
# was: sw _size_reg_20_, 0(_mainres_1_)
|
||||
addi $18, $16, 4
|
||||
# was: addi _addr_reg_24_, _mainres_1_, 4
|
||||
ori $19, $0, 0
|
||||
# was: ori _i_reg_25_, $0, 0
|
||||
addi $20, $2, 4
|
||||
# was: addi _elem_reg_22_, _arr_reg_21_, 4
|
||||
_loop_beg_26_:
|
||||
sub $2, $19, $17
|
||||
# was: sub _tmp_reg_28_, _i_reg_25_, _size_reg_20_
|
||||
bgez $2, _loop_end_27_
|
||||
# was: bgez _tmp_reg_28_, _loop_end_27_
|
||||
lw $21, 0($20)
|
||||
# was: lw _res_reg_23_, 0(_elem_reg_22_)
|
||||
# was: sw _size_reg_16_, 0(_letBind_15_)
|
||||
addi $19, $16, 4
|
||||
# was: addi _addr_reg_21_, _letBind_15_, 4
|
||||
ori $18, $0, 0
|
||||
# was: ori _i_reg_22_, $0, 0
|
||||
addi $20, $3, 4
|
||||
# was: addi _elem_reg_18_, _arr_reg_17_, 4
|
||||
_loop_beg_23_:
|
||||
sub $3, $18, $17
|
||||
# was: sub _tmp_reg_25_, _i_reg_22_, _size_reg_16_
|
||||
bgez $3, _loop_end_24_
|
||||
# was: bgez _tmp_reg_25_, _loop_end_24_
|
||||
lw $3, 0($20)
|
||||
# was: lw _res_reg_19_, 0(_elem_reg_18_)
|
||||
addi $20, $20, 4
|
||||
# was: addi _elem_reg_22_, _elem_reg_22_, 4
|
||||
# ori _tmp_30_,_res_reg_23_,0
|
||||
# ori _fun_arg_res_29_,_tmp_30_,0
|
||||
ori $2, $21, 0
|
||||
# was: ori $2, _fun_arg_res_29_, 0
|
||||
jal putint
|
||||
# was: jal putint, $2
|
||||
# ori _res_reg_23_,_fun_arg_res_29_,0
|
||||
sw $21, 0($18)
|
||||
# was: sw _res_reg_23_, 0(_addr_reg_24_)
|
||||
addi $18, $18, 4
|
||||
# was: addi _addr_reg_24_, _addr_reg_24_, 4
|
||||
addi $19, $19, 1
|
||||
# was: addi _i_reg_25_, _i_reg_25_, 1
|
||||
j _loop_beg_26_
|
||||
_loop_end_27_:
|
||||
# was: addi _elem_reg_18_, _elem_reg_18_, 4
|
||||
# ori $2,_nelem_reg_20_,0
|
||||
# ori $3,_res_reg_19_,0
|
||||
jal incr
|
||||
# was: jal incr, $2 $3
|
||||
# ori _tmp_reg_26_,$2,0
|
||||
# ori _nelem_reg_20_,_tmp_reg_26_,0
|
||||
sw $2, 0($19)
|
||||
# was: sw _nelem_reg_20_, 0(_addr_reg_21_)
|
||||
addi $19, $19, 4
|
||||
# was: addi _addr_reg_21_, _addr_reg_21_, 4
|
||||
addi $18, $18, 1
|
||||
# was: addi _i_reg_22_, _i_reg_22_, 1
|
||||
j _loop_beg_23_
|
||||
_loop_end_24_:
|
||||
ori $2, $16, 0
|
||||
# was: ori $2, _mainres_1_, 0
|
||||
addi $29, $29, 32
|
||||
lw $21, -28($29)
|
||||
# was: ori _arr_reg_29_, _letBind_15_, 0
|
||||
lw $16, 0($2)
|
||||
# was: lw _size_reg_28_, 0(_arr_reg_29_)
|
||||
ori $17, $28, 0
|
||||
# was: ori _mainres_9_, $28, 0
|
||||
sll $3, $16, 2
|
||||
# was: sll _tmp_38_, _size_reg_28_, 2
|
||||
addi $3, $3, 4
|
||||
# was: addi _tmp_38_, _tmp_38_, 4
|
||||
add $28, $28, $3
|
||||
# was: add $28, $28, _tmp_38_
|
||||
sw $16, 0($17)
|
||||
# was: sw _size_reg_28_, 0(_mainres_9_)
|
||||
addi $18, $17, 4
|
||||
# was: addi _addr_reg_32_, _mainres_9_, 4
|
||||
ori $19, $0, 0
|
||||
# was: ori _i_reg_33_, $0, 0
|
||||
addi $20, $2, 4
|
||||
# was: addi _elem_reg_30_, _arr_reg_29_, 4
|
||||
_loop_beg_34_:
|
||||
sub $2, $19, $16
|
||||
# was: sub _tmp_reg_36_, _i_reg_33_, _size_reg_28_
|
||||
bgez $2, _loop_end_35_
|
||||
# was: bgez _tmp_reg_36_, _loop_end_35_
|
||||
lw $2, 0($20)
|
||||
# was: lw _res_reg_31_, 0(_elem_reg_30_)
|
||||
addi $20, $20, 4
|
||||
# was: addi _elem_reg_30_, _elem_reg_30_, 4
|
||||
# ori $2,_res_reg_31_,0
|
||||
jal writeInt
|
||||
# was: jal writeInt, $2
|
||||
# ori _tmp_reg_37_,$2,0
|
||||
# ori _res_reg_31_,_tmp_reg_37_,0
|
||||
sw $2, 0($18)
|
||||
# was: sw _res_reg_31_, 0(_addr_reg_32_)
|
||||
addi $18, $18, 4
|
||||
# was: addi _addr_reg_32_, _addr_reg_32_, 4
|
||||
addi $19, $19, 1
|
||||
# was: addi _i_reg_33_, _i_reg_33_, 1
|
||||
j _loop_beg_34_
|
||||
_loop_end_35_:
|
||||
ori $2, $17, 0
|
||||
# was: ori $2, _mainres_9_, 0
|
||||
addi $29, $29, 28
|
||||
lw $20, -24($29)
|
||||
lw $19, -20($29)
|
||||
lw $18, -16($29)
|
||||
|
Reference in New Issue
Block a user