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

 
 
> IAR, вопросы по дизасемблеру
Zelepuk
сообщение Mar 5 2011, 12:27
Сообщение #1


Знающий
****

Группа: Участник
Сообщений: 634
Регистрация: 27-10-10
Пользователь №: 60 464



Стало интересно посмотреть кол-во тактов на операцию из дизасемблера.
Сравнил плавучку, целочисленные вычисления.
Появились вопросы:

1) По дизасемблеру видно что умножение двух short занимает 4 такта,умножение двух long тоже 4 такта.
Такое возможно?

2) умножение двух float занимает тоже 4 инструкции. Но сколько тактов непонятно. Что означают интрисики в дизасемблере и сколько тактов они занимают (__aeabi_fmul, __aeabi_fadd ... и пр.)


Заранее признателен за коментарии.

Сообщение отредактировал Zelepuk - Mar 5 2011, 12:30
Эскизы прикрепленных изображений
Прикрепленное изображение
 
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
Zelepuk
сообщение Mar 8 2011, 10:28
Сообщение #2


Знающий
****

Группа: Участник
Сообщений: 634
Регистрация: 27-10-10
Пользователь №: 60 464



Спасибо за информацию.

Процессор у меня AT91SAM9260.

Кстати а чем отличается для процессора умножение 32*32->64 от 32*32->32
Я всегда полагал что умножение 32-х разрядных операндов даёт всегда 64 разрядный результат и этот результат можно просто усеч до 32 в последствии. Следовательно 32*32->32 займёт больше времени потому что это фактически 32*32->64->32 ... разве не так?
Go to the top of the page
 
+Quote Post



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

 


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


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