реклама на сайте
подробности

 
 
> Так как же все-таки работает команда LDM {}^, Кто не прав - я или симулятор IAR?
Сергей Борщ
сообщение May 17 2006, 12:56
Сообщение #1


Гуру
******

Группа: Модераторы
Сообщений: 8 455
Регистрация: 15-05-06
Из: Рига, Латвия
Пользователь №: 17 095



Итак имеем: процессор в IRQ mode, выполняет команду
Код
    LDMFD    LR, {R0-LR}^

результат в железе: значения попадают в R0...R12, SP_user, LR_user, CPSR не тронут.
результат в симуляторе IAR EWARM4.30A: значения попадают в R0...R12, SP_user, LR_user, в CPSR копируется значение из SPSR_irq.
Согласно документу ARM DDI 0029E:
LDM with R15 in transfer list and S bit set (Mode changes)
If the instruction is a LDM then SPSR_<mode> is transferred to CPSR at the same time as R15 is loaded.

R15 not in list and S bit set (User bank transfer)
For both LDM and STM instructions, the User bank registers are transferred rather than the register bank corresponding to the current mode.

В данном случае R15 нет в списке и по моим понятиям копирования SPSR_irq быть не должно. Однако вот тут:
http://electronix.ru/forum/index.php?s=&sh...ndpost&p=113699
коллега утверждает что копирование SPSR_irq происходит всегда. Кто из нас прав?


--------------------
На любой вопрос даю любой ответ
"Write code that is guaranteed to work, not code that doesn’t seem to break" (C++ FAQ)
Go to the top of the page
 
+Quote Post

Сообщений в этой теме


Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 22nd July 2025 - 05:23
Рейтинг@Mail.ru


Страница сгенерированна за 0.01351 секунд с 7
ELECTRONIX ©2004-2016