Проблема с кодом в том, что вы используете не адрес, по которому хранится размер, а сам размер:
Здесь вы загружаете адрес в A0, а размер (7) в A1:
la $a0,array
lw $a1,size #a1 = size of array
Здесь вы загружаете первое слово, хранящееся в вашем массиве (которое будет загружать 10). Это не то, что вы намеревались.
lw $s0,0($a0) #copy arg1 = address array
addi $s1,$zero,7
Здесь вы загружаете первое слово, хранящееся в месте 0x000007. (твой размер). это
вероятно также не предназначено и вызовет исключение, потому что адрес не выровнен:
lw $s1,0($a1) #copy arg2 = size of array
и т. Д.
Мне кажется, что вы неправильно понимаете, что делает инструкция LW. Он читает ячейку памяти в регистр. В прологе цикла вы хотите сделать копии регистра.
Для этого вы можете использовать псевдоинструкцию перемещения, если ваш ассемблер поддерживает ее. В противном случае используйте инструкцию OR для копирования регистров следующим образом:
COUNT:
or $s0, $a0, $a0 #copy arg1 = address array
addi $s1, $zero,7
or $s1, $a1, $a1 #copy arg2 = size of array
or $s2, $a2, $a2 #copy arg3 = search key (n)
addi $s2, $zero,30
COUNTLOOP:
...
для полного примера линейного цикла поиска попробуйте это (не проверено и ожидает, что ассемблер заботится о слотах задержки)
main:
la $a0,array # $a0 = address of array
lw $a1,size # $a1 = size of array
lw $a2,search # $a2 = search key
beq $a1, $zero, NOTFOUND # handle the size==0 case..
or $v0, $zero, $zero # init counter to zero
LOOP:
lw $s0, 0($a0) # load element
beq $s0, $a2, FOUND # branch if key found:
addiu $a0, $a0, 4 # increment array pointer
addiu $v0, $v0, 1 # increment loop counter
bne $v0, $a1, LOOP # repeat until we've processed the array.
NOTFOUND:
# --------------------------------------
# if you reach this, key does not exist:
# --------------------------------------
li $v0, -1 # load a -1 to signal key not found.
jr $lr # return to caller
FOUND:
# -----------------------------------------
# v0 now contains the position of the key.
# -----------------------------------------
jr $lr