Форум программистов «Весельчак У»
  *
Добро пожаловать, Гость. Пожалуйста, войдите или зарегистрируйтесь.
Вам не пришло письмо с кодом активации?

  • Рекомендуем проверить настройки временной зоны в вашем профиле (страница "Внешний вид форума", пункт "Часовой пояс:").
  • У нас больше нет рассылок. Если вам приходят письма от наших бывших рассылок mail.ru и subscribe.ru, то знайте, что это не мы рассылаем.
   Начало  
Наши сайты
Помощь Поиск Календарь Почта Войти Регистрация  
 
Страниц: [1]   Вниз
  Печать  
Автор Тема: THUMB (ARM), как вычисляются адреса?  (Прочитано 4724 раз)
0 Пользователей и 1 Гость смотрят эту тему.
MasterMan342
Участник

ru
Offline Offline
Пол: Мужской

« : 17-08-2014 20:00 » new

Доброго времени суток!
В общем, разбираю дезасемблированный код...
Все шло хорошо, код лаконичен и понятен, но!
я остановился на следующих командах:

ADD r0, pc, #0x1
BX r0                              ; << 0x0118

Как я понимаю, первая команда устанавливает младший бит адреса следующей команды,
и получается, что т.к. команда BX r0, имеет адрес 0x0118, в r0 будет лежать значение 0x0119.

А что дальше?
BX как я понимаю, определяет к какому режиму принадлежит адрес, и если установлен младший бит,
команда поднимает флаг T в регистре состояния процессора, а сам процессор при переходе обнуляет
нулевой бит адреса (т.е. адрес все-же будет 0x0118).

В этом случае ведь произойдет цикл? как это понимать?   
Записан
Страниц: [1]   Вверх
  Печать  
 

Powered by SMF 1.1.21 | SMF © 2015, Simple Machines