LDR - piscina literal - ARM
Eu sei como carregar um valor imediato usando a instrução LDR no ARM.
Por exemplo:
LDR R0,=0x0804c088
Esta instrução carrega o valor (0x0804c088
) para o registor0
. Quando tento acessar o endereço, ele é armazenado usandox/x $r0
usandogdb
. Eu recebo a mensagem:Cannot access memory at address
0x0804c088. Mas esse não é o endereço, é o valor armazenado nesse registro e o endereço é um
PC
endereço relativo que é armazenado no pool literal.
Qual é o erro que eu estou fazendo aí? Eu entendi algo errado aí?
Além disso, como devo definir o pool literal, você pode me dar um exemplo, por favor?
@ Carl Norum: Aqui está o código.
__asm__("LDR R0,=0x0804c088");
__asm__("LDR R1,[PC, #34];");
O / p do gdb
(gdb) info registers
r0 0x804c088 134529160
r1 0xf2c00300 4072669952
r2 0x0 0
r3 0x1 1
r4 0x8961 35169
r5 0x0 0
r6 0x0 0
r7 0xbe8f4b74 3197062004
r8 0x0 0
r9 0xef99 61337
r10 0xf00d 61453
r11 0x0 0
r12 0x0 0
sp 0xbe8f4b74 0xbe8f4b74
lr 0x89a7 35239
pc 0x8a62 0x8a62 <test46+34>
cpsr 0x60000030 1610612784
(gdb) x/x $r0
0x804c088: Cannot access memory at address 0x804c088
(gdb) p/x$r0
$1 = 0x804c088
(gdb) p/x $r1
$2 = 0xf2c00300
(gdb) x/x $r1
0xf2c00300: Cannot access memory at address 0xf2c00300
(gdb) x/x $r15
0x8a62 <test46+34>: 0x1022f8df