[an error occurred while processing this directive]
Я думаю, для AVR проблема именно в слишком большом количестве регистров.
(«Телесистемы»: Конференция «Микроконтроллеры и их применение»)

миниатюрный аудио-видеорекордер mAVR

Отправлено Bill 18 ноября 2005 г. 12:01
В ответ на: Без идеологии регистров, наверное, не обойтись... отправлено CD_Eater 18 ноября 2005 г. 11:01

При этом, половина регистров не поддерживает хотя бы тот же режим косвенной адресации. Кроме того, некоторые команды не работают с данным режимом адресации. Например, EOR. Я не могу написать


eori r16, 0x80 ; Требуется 1 регистр

Вместо этого, требуется писать

ldi r17, 0x80 ; Требуется 2 регистра
eor r16, r17 ;

Дополнительный минус - уменьшенное поле адреса порта в командах in и out. А самое главное, все операции над данными производятся ТОЛЬКО в регистрах, что влечет за собой дополнительные расходы на пересылку данных из памяти в регистры и обратно. Опять же, для сохранения множества регистров в стеке и восстановления их из стека требуется время, а это не есть хорошо в RTOS. Я думаю, от сокращения количества регистров в два раза AVR только бы выиграл. То же самое относится и к MSP430.
И вообще, количество регистров не должно быть слишком большим, или слишком маленьким. Оно должно быть оптимальным.

Составить ответ  |||  Конференция  |||  Архив

Ответы


Отправка ответа

Имя (обязательно): 
Пароль: 
E-mail: 
NoIX ключ Запомнить

Тема (обязательно):
Сообщение:

Ссылка на URL: 
Название ссылки: 

URL изображения: 


Rambler's Top100 Рейтинг@Mail.ru
Перейти к списку ответов  |||  Конференция  |||  Архив  |||  Главная страница  |||  Содержание

E-mail: info@telesys.ru