Табло

топ 100 блогов thesz02.09.2024 https://en.wikipedia.org/wiki/Scoreboarding

Для каждой команды мы можем отмечать возможность её выполнения на основании доступности результатов предыдущих команд - если все аргументы команды записаны в регистровый файл, её можно выполнять.

Однако, можно пойти ещё дальше.

Как известно, название процессора MIPS означает Microprocessor without Interlocked Pipeline Stages - процессор, этапы конвейера которого не взаимодействуют друг с другом.

Однако, в MIPS есть исключения на этапе "обращение к памяти," куда можно запихнуть и исключения по переполнению команд сложения и вычитания чисел со знаком. Обращение к памяти, так же, может удерживать конвейер от продолжения работы, если данные пришлось тащить издалека.

То есть, MIPS не так, чтобы уж очень хорошо соответствовал своему имени.

Это можно исправить, добавив в логику работы с табло команд и регистров возможность выдавать частичные команды.

Те же загрузка из памяти и запись в память вычисляют адрес, проверяют его доступность в TLB (исключение, если адреса нет) и, затем, читают или пишут данные. Мы можем для всех загрузок и записей вычислить адреса и проверить их наличие в TLB, не взирая на зависимости по регистру-приёмнику (для загрузки) или по регистру-источнику (для записи).

Далее, мы можем выдать запрос на подкачку данных в кеш до того, как регистр-приёмник станет доступным. В результате мы сэкономим несколько тактов ожидания. А можем просто ждать, пока (физический) адрес загрузки команды появится в кеше.

Команды наподобие "проверь, находится ли адрес в TLB" или "находится ли физический адрес в кеше" позволяют не останавливать конвейер, устраняя то, чему MIPS не соответствовал.

Поэтому я считаю, что табло команд и регистров (scoreboarding) является недооценённым способом извлекать параллелизм по командам из программы. Он и прост, и позволяет устранить взаимодействие между этапами конвейера.

Просто все переключились на переименование регистров и использование контекстно-адресуемой памяти со спекулятивным выполнением, что и привело к интересным результатам. ;)

Оставить комментарий

Предыдущие записи блогера :
Архив записей в блогах:
Я сожалею, что разбил чьи-то хрустальные мечты, предварительно туда плюнув. Сожалею - но на данный момент мои прогнозы именно таковы, каковы есть. Изменится текущая обстановка настолько, что нужно будет корректировать прогноз - сделаю это с ...
SpaceX впервые посадила первую ступень ракеты Falcon 9 на платформу в океане. Технически конечно интересно, но финансово очень еще не все так однозначно. View Poll: #2041774 Видео под катом ... Ракета Falcon 9 была запущена сегодня с Мыса Канаверал с грузом для Междуна ...
Мульгикапсад ...
Например, как долго проживет теперь Русе Болтон? Или вот Миссандея и Серый Червь. Волнуюсь за них: они такие трогательные, что одного из них могут убить. Хотя, конечно, на самом деле они наверняка потерянные в детстве брат и сестра. А какие сюжеты трогают ваше сердце? За кого вы болеет ...
В хорватской газете опубликована статья "Педофилия и сексуализация детей находится вне контроля!" . со множеством фотографий с детских площадок где-то в Европе (видимо в Хорватии). Как это комментировать - не знаю, слов не хватает. Всё-таки, Запад стремительно движется к тому, чтобы "пр ...