Я работаю над программой в сборке ARM (Raspberry pi), но у меня есть проблема.ARM Assembly - CMP неправильный вывод
У меня есть этот код, но нижняя часть всегда выполняется (пропустить $).
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$:
Что мне не хватает?
Функция отладки просто отправляет r0-r4 через UART на мой компьютер.
Когда я запускаю это, в конце концов, г3 7. Какой должна быть еще 4.
Заранее спасибо
Лоренса Уитс
Edit: Вот другие функции, которые используются.
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}
второй Edit: Я использовал этот код для установки указателя стека.
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 = .;
Так что 'Debug' сохраняет и восстанавливает все регистры, которые он использует? – Notlikethat
@Notlikethat Да, я использовал push и pop для всех используемых регистров. –
поэтому, когда вы комментируете строку «Отладка» bl, тогда это также не удается? –