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

 
 
 
Reply to this topicStart new topic
> ARM GNU Assembler; генерация адресной константы в директиве .word
AndrewN
сообщение Sep 29 2009, 16:06
Сообщение #1


Местный
***

Группа: Участник
Сообщений: 336
Регистрация: 7-03-07
Из: Петербург
Пользователь №: 25 961



Столкнулся с такой константой:
Код
INITTAB:    .word    . - 0xFC

Какое значение адреса сгенерирует gas? По идее, должно быть (lc + 4),
а закодировано как (lc - 252). Или -0xFC дополняется до -4?

У меня не установлены GNU tools, поэтому проверить экспериментально не могу...

Спасибо.
Go to the top of the page
 
+Quote Post
AndrewN
сообщение Sep 30 2009, 10:36
Сообщение #2


Местный
***

Группа: Участник
Сообщений: 336
Регистрация: 7-03-07
Из: Петербург
Пользователь №: 25 961



Ясно. (. + 0xFC) это действительно lc - 254, но подразумевается
lc + 4. В том смысле, что это компенсация предыдущих и последующих
ошибок на стадиях сборки и загрузки (ARM9 в DM6446); в точности как
в контрольной работе - сделал две ошибки и получил правильный
результат - ошибки взаимно уничтожились. Загадка разрешилась.
Go to the top of the page
 
+Quote Post

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

 


RSS Текстовая версия Сейчас: 24th July 2025 - 01:57
Рейтинг@Mail.ru


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