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

 
 
> Вопросы по R15, Счётчик команд
Diablic
сообщение Dec 22 2010, 10:18
Сообщение #1





Группа: Новичок
Сообщений: 2
Регистрация: 22-12-10
Пользователь №: 61 795



Здравствуйте, недавно начал разбираться в архитектуре 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?
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
muravei
сообщение Dec 23 2010, 14:13
Сообщение #2


Гуру
******

Группа: Свой
Сообщений: 2 538
Регистрация: 13-08-05
Пользователь №: 7 591



А как засовывается 32 бита в регистр? Что константа следует за командой -сомнительно , а в саму MOV -нелезет. sm.gif
Go to the top of the page
 
+Quote Post
scifi
сообщение Dec 23 2010, 17:07
Сообщение #3


Гуру
******

Группа: Свой
Сообщений: 3 020
Регистрация: 7-02-07
Пользователь №: 25 136



Цитата(muravei @ Dec 23 2010, 20:13) *
А как засовывается 32 бита в регистр? Что константа следует за командой -сомнительно , а в саму MOV -нелезет. sm.gif

Стыдно такое не знать. Посмотрите листинг дизассемблера любого более-менее нетривиального кода и увидите, что обычно для этого используется LDR Rm, [PC, #n]. Как раз константа следует, но не за командой, а, как правило, за функцией.
Go to the top of the page
 
+Quote Post



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

 


RSS Текстовая версия Сейчас: 31st July 2025 - 06:51
Рейтинг@Mail.ru


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