[an error occurred while processing this directive]
Грубо: переход разрушает конвейер. Чтобы от этого уйти - вводится задержанный переход, который ВСЕГДА выполняется ПОСЛЕ следующей команды. (+)
(«Телесистемы»: Конференция «Микроконтроллеры и их применение»)

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

Отправлено ReAl 13 ноября 2006 г. 22:20
В ответ на: Ответ: Что происходит на команде 102 - jump 106, или без задержанного перехода - на 105?Понятно если JMP допустим дольше остальных, за время ее выполнения выполнить какието другие? или я не так понимаю? отправлено <font color=gray>legych</font> 13 ноября 2006 г. 22:08

Следующая после перехода команда (уже выбранная, декодированная - т.е. прошедшая часть конвейера) выполняется всегда, при условном переходе - независимо от условия. В это время выбирается/декодируется следующая команда, меньше простой конвейера.
Без оптимизации в следующую ячейку пишется NOP, чтобы и порядок команд был "простой", и лишенего не быол сделано. При оптимизации - последняя команда из тех, которые должны быть выполнены перед переходом и она и буде выполнена перед ним.

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

Ответы


Отправка ответа
Имя (обязательно): 
Пароль: 
E-mail: 

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

Ссылка на URL: 
URL изображения: 


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