1
for (i=0, i<10000, i=i+2)
{

    A[i]=B[i]+C[i]
    A[i+1]=B[i+1]+C[i+1]

}

给定前面的代码,MIPS 程序集是什么样的?我正在尝试构建汇编代码,其中 R9 = A 的基地址,R9 = B 的基地址,R10 = C 的基地址

我知道这种展开 ONCE 的方法应该更有效,但很难看到 MIPS 的样子。

有人可以帮我吗?

4

1 回答 1

2

循环体将是这样的:

LW    r1, 0(r9)    // B[i]
LW    r2, 4(r9)    // B[i+1]
LW    r3, 0(r10)   // C[i]
LW    r4, 4(r10)   // C[i+1]
ADDU  r5, r1, r3   // B[i] + C[i]
ADDU  r6, r2, r4   // B[i+1] + C[i+1]
SW    r5, 0(r8)    // A[i] 
SW    r5, 4(r8)    // A[i+1]
ADDIU r9,  8
ADDIU r10, 8
ADDIU r8,  8

MIPS 有很多寄存器,因此可能值得再展开循环几次。

于 2012-08-21T20:37:48.933 回答