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

 
 
 
Reply to this topicStart new topic
> Подскажите опкоды команд, у кого ИАР под рукой,, есть неясность в усер гиде
Сергей Борщ
сообщение Aug 12 2008, 05:58
Сообщение #1


Гуру
******

Группа: Модераторы
Сообщений: 8 455
Регистрация: 15-05-06
Из: Рига, Латвия
Пользователь №: 17 095



Кому не сложно, гляньте во что ассемблируются команды DECDA R5 и INCDA R5 (это от ядра 430Х). Пишу поддержку 430Х для binutils, мануал уже мозоли на глазах натер, а все равно не могу понять, как они при эмуляции этой инструкции константу #2 получают - как immediate operand или как-то из CG выуживают. А также проверьте TSTA R5 - у меня получился опкод 0x03D5, правильно?


--------------------
На любой вопрос даю любой ответ
"Write code that is guaranteed to work, not code that doesn’t seem to break" (C++ FAQ)
Go to the top of the page
 
+Quote Post
АДИКМ
сообщение Aug 12 2008, 19:29
Сообщение #2


Знающий
****

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



Цитата(Сергей Борщ @ Aug 12 2008, 08:58) *
Кому не сложно, гляньте во что ассемблируются команды DECDA R5 и INCDA R5 (это от ядра 430Х). Пишу поддержку 430Х для binutils, мануал уже мозоли на глазах натер, а все равно не могу понять, как они при эмуляции этой инструкции константу #2 получают - как immediate operand или как-то из CG выуживают. А также проверьте TSTA R5 - у меня получился опкод 0x03D5, правильно?





clr r5
003104 4305 clr.w R5
DECDA R5
003106 03F5 decda R5
INCDA R5
003108 03E5 incda R5
TSTA R5
00310A 03D5 tsta R5


--------------------
летаю на пепелаце...
Go to the top of the page
 
+Quote Post
msalov
сообщение Aug 13 2008, 06:47
Сообщение #3


Знающий
****

Группа: Свой
Сообщений: 526
Регистрация: 24-08-07
Из: Беларусь, Минск
Пользователь №: 30 045



Цитата(Сергей Борщ @ Aug 12 2008, 08:58) *
Пишу поддержку 430Х для binutils, мануал уже мозоли на глазах натер, а все равно не могу понять, как они при эмуляции этой инструкции константу #2 получают - как immediate operand или как-то из CG выуживают

decda Rdst эмулируется командой suba #2,Rdst (slau144e Таблица 4-15 Extended Emulation Instructions), а suba #2,Rdst - это suba #imm20,Rdst согласно таблицы 4-16 MSP430X Address Instructions в slau144e
Go to the top of the page
 
+Quote Post
Сергей Борщ
сообщение Aug 20 2008, 06:49
Сообщение #4


Гуру
******

Группа: Модераторы
Сообщений: 8 455
Регистрация: 15-05-06
Из: Рига, Латвия
Пользователь №: 17 095



Цитата(gotty @ Aug 13 2008, 09:47) *
decda Rdst эмулируется командой suba #2,Rdst (slau144e Таблица 4-15 Extended Emulation Instructions), а suba #2,Rdst - это suba #imm20,Rdst согласно таблицы 4-16 MSP430X Address Instructions в slau144e
Вот и я так думал. А оказалось, что suba #2, Rdst это suba R3, Rdst. Получается, для всех Rsrc кроме R3 suba, adda имеют as = 0, а для R3 as = 2. В то время как для cmpa as = 0 для всех регистров.

Спасибо, АДИКМ!


--------------------
На любой вопрос даю любой ответ
"Write code that is guaranteed to work, not code that doesn’t seem to break" (C++ FAQ)
Go to the top of the page
 
+Quote Post

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

 


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


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