forked from alexdantas/mips-examples
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path004-matrix-mult-scalar.s
91 lines (71 loc) · 1.86 KB
/
004-matrix-mult-scalar.s
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
# Multiplies a matrix by a scalar
# In this case, we'll multiply this matrix:
#
# 1 2
# 3 4
# 5 6
#
# By a scalar, say, 3
.data
scalar: .word 3
mat: .word 1, 2, 3, 4, 5, 6
lines: .word 3
cols: .word 2
tab: .asciiz "\t"
endl: .asciiz "\n"
.text
main:
addi $s0, $zero, 13 # Setting $s0 just to be sure my function doesnt
# override it
lw $a0, scalar
la $a1, mat
lw $a2, lines
lw $a3, cols
jal mul_mat_scalar
li $v0, 10 # exit
syscall
## Multiplies a matrix by a scalar
# $a0 scalar
# $a1 matrix
# $a2 n_lines
# $a3 n_cols
mul_mat_scalar:
addi $sp, $sp, -4
sw $s0, 0($sp) # saving previous $s0
move $s0, $a0 # $s0 = $a0
add $t0, $zero, $zero # i = 0
mul_mat_scalar_test1:
seq $t7, $t0, $a2 # if (i == n_lines)
bne $t7, $zero, mul_mat_scalar_end1 # then exit
# else continue
add $t1, $zero, $zero # j = 0
mul_mat_scalar_test2:
seq $t7, $t1, $a3 # if (j == n_cols)
bne $t7, $zero, mul_mat_scalar_end2 # then go to the next line
# else, keep going
mul $t7, $a3, $t0 # b = lines * i
add $t7, $t7, $t1 # b += j
sll $t7, $t7, 2 # b *= 4 (converting to word address)
add $t7, $t7, $a1 # b = matrix[b]
# (or b = matrix[i * lines + j])
# (of b = matrix[i][j])
lw $t6, 0($t7)
mul $t7, $t6, $s0 # Finally, matrix[i][j] * num
li $v0, 1 # Will print integer
add $a0, $zero, $t7 # printf($t7)
syscall
li $v0, 4 # Will print string
la $a0, tab # printf("\t")
syscall
addi $t1, $t1, 1 # j++
j mul_mat_scalar_test2
mul_mat_scalar_end2:
li $v0, 4 # Will print string
la $a0, endl # printf("\n")
syscall
addi $t0, $t0, 1 # i++
j mul_mat_scalar_test1 # Finished this line, lets go to the next!
mul_mat_scalar_end1:
lw $s0, 0($sp)
addi $sp, $sp, 4 # restore previous $s0
jr $ra # return