我试图做出直接翻译成MIPS这个C代码,而无需修改任何指示:一个C转换为MIPS
for (i=0; i<128; i++)
{ a[i] = b[i] - c[i] + 5; }
我只是想了解一些事情。这里是我到目前为止
add $t4, $zero, $zero # I1 i is initialized to 0, $t4 = 0
Loop:
add $t5, $t4, $t1 # I2 temp reg $t5 = address of b[i]
lw $t6, 0($t5) # I3 temp reg $t6 = b[i]
add $t5, $t4, $t2 # I4 temp reg $t5 = address of c[i]
lw $t7, 0($t5) # I5 temp reg $t7 = c[i] + 5
sub $t6, $t6, $t7 # I6 temp reg $t6 = b[i] - c[i] + 5
add $t5, $t4, $t0 # I7 temp reg $t5 = address of a[i]
sw $t6, 0($t5) # I8 a[i] = b[i] - c[i] + 5
addi $t4, $t4, 4 # I9 i = i + 1
slti $t5, $t4, 256 # I10 $t5 = 1 if $t4 < 128, i.e. i < 10
bne $t5, $zero, Loop # I11 go to Loop if $t4 < 128
exit:
我不知道我是否需要通过自身或者其确定我有它的方式来加载5在那里与C [1]加载?任何提示都会有帮助,因为我仍然在尝试学习mips。谢谢!
你真正的问题是什么?提示:问题通常应该在最后有一个问号,特别是在这样的质量保证网站中:-) – hyde
我添加了一个问号,但让我知道是否需要更多解释 – Nuf