Перейти к содержанию
    

Так как же все-таки работает команда LDM {}^

Итак имеем: процессор в 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 происходит всегда. Кто из нас прав?

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Присоединяйтесь к обсуждению

Вы можете написать сейчас и зарегистрироваться позже. Если у вас есть аккаунт, авторизуйтесь, чтобы опубликовать от имени своего аккаунта.

Гость
К сожалению, ваш контент содержит запрещённые слова. Пожалуйста, отредактируйте контент, чтобы удалить выделенные ниже слова.
Ответить в этой теме...

×   Вставлено с форматированием.   Вставить как обычный текст

  Разрешено использовать не более 75 эмодзи.

×   Ваша ссылка была автоматически встроена.   Отображать как обычную ссылку

×   Ваш предыдущий контент был восстановлен.   Очистить редактор

×   Вы не можете вставлять изображения напрямую. Загружайте или вставляйте изображения по ссылке.

×
×
  • Создать...