我正在学习MIPS汇编,并想知道如何在MIPS中加载和存储内存地址。
例如,假设我有这个C代码:
int i;
i = 0xFFFF0000;
然后我将如何存储地址?例如,我想将i
的值存储到地址0x2000A000
。
LUI V0, 0xFFFF << load 0xffff0000 into v0
LUI A0, 0x2000
ORI A0, A0, 0xA000 << load address to A0
SW V0, (A0) << Stores V0 at address held in A0
或者,如果您的汇编程序支持宏操作码(我想这几天几乎所有人都这样做)
LUI V0, 0xFFFF
LI A0, 0x2000A0000
SW V0, (A0)
注意A0是WORD / 32bit对齐。
让编译器告诉你:
#define SOME_ADDRESS (*((volatile unsigned int *) 0x2000A000 ))
void fun ( void )
{
SOME_ADDRESS = 0xFFFF0000;
}
编译和反汇编
Disassembly of section .text:
00000000 <fun>:
0: 3c022000 lui $2,0x2000
4: 3442a000 ori $2,$2,0xa000
8: 3c03ffff lui $3,0xffff
c: ac430000 sw $3,0($2)
10: 03e00008 jr $31
14: 00000000 nop
正如评论中指出的那样,错过了优化,但这不是这个答案的重点。 1)学习asm 2)学会优化asm ......在路上。使用编译器,您将看到其中一些优化。但不是在这种情况下。
#define SOME_ADDRESS (*((volatile unsigned int *) 0x20004000 ))
void fun ( void )
{
SOME_ADDRESS = 0xFFFF0000;
}
00000000 <fun>:
0: 3c022000 lui $2,0x2000
4: 3c03ffff lui $3,0xffff
8: ac434000 sw $3,16384($2)
c: 03e00008 jr $31
10: 00000000 nop
是的,它是为mips32构建的,以获得此-march = mips1和-march = mips32r6生成相同的代码。评论。