我正在研究ARM程序集(Raspberry pi)中的程序,但我遇到了问题。
我有这个代码,但是下半部分总是在执行(跳过$)。
mov r1, #3
mov r3, #4
add r2, r1, r3
bl Debug
cmp r2, #0x0A
ble skip$
mov r0, #10
sub r0, r0, r1
mov r3, r0
bl Debug
skip$:
我错过了什么?
Debug函数只是将r0-r4通过UART发送到我的电脑。
当我运行时,最后,r3为7.哪个应该仍为4.
提前致谢
Laurens Wuyts
编辑: 以下是使用的其他功能。
Debug:
push {r0 - r4, lr}
mov r4, r0
mov r0, #10
bl UART_write
mov r0, r4
bl UART_write
mov r0, #11
bl UART_write
mov r0, r1
bl UART_write
mov r0, #12
bl UART_write
mov r0, r2
bl UART_write
mov r0, #13
bl UART_write
mov r0, r3
bl UART_write
pop {r0 - r4, pc}
UART_write:
push {r0 - r2, lr}
ldr r1, =UART0_FR
wait_write$:
ldr r2, [r1]
tst r2, #0x20
bne wait_write$
ldr r1, =UART0_DR
and r0, #0x000000ff
str r0, [r1]
pop {r0 - r2, pc}
第二编辑: 我已经使用这段代码来设置堆栈指针。
setup_stack:
mov r0, #0xD1 @ FIQ
msr cpsr, r0
ldr sp, =stack_fiq
mov r0, #0xD2 @ IRQ
msr cpsr, r0
ldr sp, =stack_irq
mov r0, #0xD7 @ ABT
msr cpsr, r0
ldr sp, =stack_abt
mov r0, #0xDB @ UND
msr cpsr, r0
ldr sp, =stack_und
mov r0, #0xDF @ SYS
msr cpsr, r0
ldr sp, =stack_sys
mov r0, #0xD3 @ SVC
msr cpsr, r0
ldr sp, =stack_svc
mov pc, lr
这是我的链接器:
.= ALIGN(0x1000);
/* Stack space */
. = . + 0x800;
stack_svc = .;
. = . + 0x800;
stack_und = .;
. = . + 0x800;
stack_abt = .;
. = . + 0x800;
stack_irq = .;
. = . + 0x800;
stack_fiq = .;
. = . + 0x400000;
stack_sys = .;
答案 0 :(得分:1)
所以我创建了这个函数来测试它。
.globl TEST
TEST:
mov r1, #3
mov r3, #4
add r2, r1, r3
cmp r2, #0x0A
ble skip
mov r0,#0x30
bx lr
skip:
mov r0,#0x31
bx lr
我将结果(r0)发送给uart。并获得一个0x31(数字1),如预期的那样,7小于10。
这是一个覆盆子pi A +。
当你使用相同的代码时,你会得到什么?
答案 1 :(得分:1)
我发现了这个问题的问题(和答案)。
问题是,我正在使用ldr读取字节和地址,因此输出字在前24位有一些垃圾。
我应该使用ldrb(加载字节)而不是ldr。
UART0_write函数只发送寄存器的最低字节,所以看起来是正确的。
Laurens的