- •Московская государственная академия приборостроения и информатики
- •Содержание
- •1. Понятие архитектуры процессора и элементная база
- •1.1 Понятие архитектуры эвм и архитектуры процессора
- •1.2 Элементная база (физическая база) процессора
- •1.3 Пути совершенствования элементной базы
- •1.3.1 Молекулярные компьютеры.
- •1.3.2 Биокомпьютеры или нейрокомпьютеры.
- •1.3.3 Квантовые компьютеры
- •1.3.4 Оптические компьютеры
- •2. Процессоры с классической архитектурой
- •2.1. Основные принципы классической архитектуры:
- •2.2 Организация памяти в классической архитектуре
- •2.3 Набор команд фон - Неймановского процессора
- •2.4 Обработка особых ситуаций и прерывания
- •3. Стековые процессоры
- •3.1 Этапы выполнения команды в фон Неймановском процессоре
- •3.2 Архитектурные особенности стекового процессора
- •3.3 Операции с оперативной памятью
- •3.4 Программирование на стековом процессоре
- •3.5 Замечания по реализации
- •4. Конвейерные процессоры
- •4.1 Предпосылки создания конвейера данных
- •4.2 Структура конвейера данных
- •4.3 Сокращение времени при использовании конвейера данных
- •4.4 Конвейер команд
- •4.5 Многооперационные конвейеры
- •4.6 Проблемы конвейерных процессоров:
- •4.7 Особенности программирования конвейерных процессоров.
- •4.8 Замечания по реализации
- •5. Cray - процессор
- •5.3.2 Регистровый трёхадресный ассемблер
- •5.3.3 Регистровая буферизация и «прозрачная память»
- •5.3.4 Функциональные конвейерные блоки операций
- •5.3.5 Буферизация команд
- •5.4 Общая структура и состав процессора cray.
- •5.5 Производительность и области применения
- •6. Процессор пересылок
- •6.1 Иерархия памяти в классической архитектуре
- •6.2 Организация памяти в процессоре пересылок
- •6.3 Организация процессора пересылок
- •6.3.1 Адресная фиксация схем исполнения машинных команд
- •6.3.2 Механизм запуска машинной команды
- •6.4 Пример программы в процессоре пересылок
- •6.5 Реализация перехода по адресу и сравнения
- •6.6 Замечания по реализации процессора пересылок
- •7. Архитектуры процессоров
- •7.1. Процессоры с универсальным набором команд
- •7.2Risc– процессоры
- •7.3 Теговые машины
- •7.4 Гарвардская архитектура
- •8. Подходы к организации вычислительного процесса и потоковые машины
- •8.1 Процедурное программирование.
- •8.2 Функциональное программирование
- •8.3 Потоковое программирование
- •9. Архитектуры памяти
- •9.1 Классификация архитектур памяти
- •9.2 Память с чередование адресов
- •9.3 Кэш память
- •9.4. Ассоциативная память (безадресная память)
- •10. Архитектурные решения
- •10.1 Проблемы организации и управления вводом/выводом
- •10.2 Основные архитектурные решения
- •10.3 Канальный ввод/вывод
- •10.4 Архитектура с общей шиной
- •10.5 Архитектура ввода/вывода с общей памятью
- •11. Параллельная обработка
- •11.1 Мультипрограммирование (многозадачность)
- •11.1.1 Однопроцессорная обработка
- •11.1.2 Многопроцессорная обработка
- •11.2 Параллелизм независимых ветвей
- •11.3 Параллелизм объектов
- •12. Матричные системы
- •12.1 Однородные системы - параллелизм этапов задач
- •12.2 Матрицы волнового фронта данных - параллелизм команд
- •12.3 Классические матричные системы - параллелизм объектов
- •107846, Москва, ул. Стромынка, 20
3. Стековые процессоры
3.1 Этапы выполнения команды в фон Неймановском процессоре
Для понимания принципов, на которых основывается идеология стекового процессора необходимо более подробно рассмотреть этапы выполнения команд в классической фон - Неймановской архитектуре и ряд узких мест, приводящих к определенной потере времени при выполнении последовательности операций.
Можно выделить следующие этапы выполнения команды в классической фон - Неймановской архитектуре:
выборка устройством управления команды из ОП (или из кэш памяти) в регистр команд;
модификация адреса в регистре команд на длину выбранной команды;
обработка кода операции - коммутация АЛУ на соответствующую микропрограмму или операционную схему;
коммутация регистров и АЛУ в соответствии с информацией команды;
вычисление адреса операнда в ОП;
выборка операнда из ОП в АЛУ;
выполнение команды процессором (АЛУ);
обработка результата выполнения команды - запись результата.
Схема взаимодействия регистров процессора и АЛУ представлена на рис 3.1:
Схема взаимодействия регистров процессора и АЛУ
Рис 3.1
3.2 Архитектурные особенности стекового процессора
Основной идеей разработчиков стекового процессора был отказ от программно адресуемых регистров в пользу аппаратного стека. Стек представляет собой блок памяти с двумя фиксированными операциями - операцией помещения информации в стек, при этом новая информация размещается вверху стека, а все ранее хранимые элементы проталкиваются вниз, и операцией выборки из стека, при которой верхний элемент стека выталкивается и передается на обработку, а все остальные элементы продвигаются на единицу вверх. Таким образом, непосредственно доступным является только верхний элемент стека. Схема стека приведена на рис 3.2.
Упрощенная схема стека
Рис 3.2
Прямое использование стека вместо регистров приводит к структуре, в которой остаются внутренние регистры АЛУ. Эта структура обладает тем недостатком, что остаются операции пересылки операндов в АЛУ, приводящие к увеличению времени выполнения операции. Структура простого стекового процессора приведена на рис 3.3
Структура простого стекового процессора
Рис 3.3
Очевидное усовершенствование такой структуры связано с использованием верхних элементов стека в качестве регистров АЛУ. Таким образом, мы приходим к структуре стекового процессора с прямой коммутацией, работающего по следующему принципу:
выполнение команды, операндами которой всегда являются верхний и непосредственно следующий за ним элементы стека (для бинарных операций);
формируемый в АЛУ результат пересылается по месту операнда №2 в стеке;
стек продвигается на один элемент вверх - тем самым результат предыдущей команды автоматически становится операндом следующей команды.
Отметим, что в этом случае АЛУ работает не с чисто стековой структурой, так как доступными (коммутированными) являются два элемента стека.
Отметим положительные особенности данной архитектуры:
- отсутствие этапа коммутации АЛУ с операндами приводит к сокращению времени выполнения команды;
- прямая передача результатов операций от одной к другой через верхний элемент стека позволяет упростить подготовку следующей команды;
- короткие команды без операндов, так как положение операндов фиксировано в двух верхних элементах стека, приводят к более короткому машинному коду программы.
Схема стекового процессора с прямой коммутацией приведена на рис 3.4
Схема стекового процессора с прямой коммутацией
Рис 3.4
Специфика стекового процессора заключается, прежде всего, в необходимости специальных подходов к программированию, связанных с представлением арифметических выражений в так называемой польской постфиксной записи и проблеме хранения промежуточных результатов, которая решается введением специальной команды, дублирующей содержимое верхнего элемента стека вниз.