Помощь - Поиск - Пользователи - Календарь
Полная версия этой страницы: Вопросы по R15
Форум разработчиков электроники ELECTRONIX.ru > Микроконтроллеры (MCs) > ARM
Diablic
Здравствуйте, недавно начал разбираться в архитектуре ARM процессоров.
Изучал описание по этому адресу, а также на www.gaw.ru.

собственно мой вопрос заключается вот в чём:

Цитата
Если подразумевается переход на инструкцию ARM режима, все команды которого хранятся по адресам кратным 4, два самых младших разряда адреса должны быть 0, иначе результат непредсказуем.
При чтении регистра R15 в ARM режиме, в регистр результата попадает значение, равное: адресу команды чтения + 8.

thisAddr: MOV R1,R15 ; R1:= R15+8 (thisAddr+8)


Если регистр R15 указывает на инструкцию, которая должна выполнятся после текущей инструкции, то почему при чтении происходит смещение на 8?

аналогичный вопрос про запись:

Цитата
Исключением из этого правила является сохранение R15 командами STR или STM. Они могут сохранять значение R15 как со смещением 8 подобно остальным инструкциям, либо со смещением 12.


почему смещение происходит на 8 или 12?
scifi
Это вызвано наличием конвейера. Как пишет ARM7TDMI Technical Reference Manual,
Цитата
The program counter points to the instruction being fetched rather than to the instruction being executed. This is important because it means that the Program Counter (PC) value used in an executing instruction is always two instructions ahead of the address.
Diablic
Спасибо.
Тогда, в случае записи:
если инструкция не содержит регистр смещения - происходит смещение на 8(благодаря конвееру)
если такой регистр есть, то происходит смещение на 8+4(регистр)=12.
я правильно понимаю?
scifi
Другая цитата, на этот раз из ARM Architecture Reference Manual:
Цитата
An exception to the above rule occurs when an ARM STR or STM instruction stores R15. Such instructions can store either the address of the instruction plus 8 bytes, like other instructions that read R15, or the address of the instruction plus 12 bytes. Whether the offset of 8 or the offset of 12 is used is IMPLEMENTATION DEFINED. An implementation must use the same offset for all ARM STR and STM instructions that store R15. It cannot use 8 for some of them and 12 for others.

То есть ВСЕ инструкции STR и STM используют одно и то же смещение в данном процессоре ARM. Один процессор может использовать смещение 8, другой - 12. Там даже есть пример кода, выясняющий величину этого смещения для данного процессора, если очень хочется его узнать.
muravei
А как засовывается 32 бита в регистр? Что константа следует за командой -сомнительно , а в саму MOV -нелезет. sm.gif
scifi
Цитата(muravei @ Dec 23 2010, 20:13) *
А как засовывается 32 бита в регистр? Что константа следует за командой -сомнительно , а в саму MOV -нелезет. sm.gif

Стыдно такое не знать. Посмотрите листинг дизассемблера любого более-менее нетривиального кода и увидите, что обычно для этого используется LDR Rm, [PC, #n]. Как раз константа следует, но не за командой, а, как правило, за функцией.
Для просмотра полной версии этой страницы, пожалуйста, пройдите по ссылке.
Invision Power Board © 2001-2025 Invision Power Services, Inc.