- •17 Базовые типы операндов: данные логического типа, строки, адреса
- •18 Базовые типы операндов: числа, разрядность основных форматов, размещение в памяти
- •19, 20 Данные символьного типа: общие сведения, принципы кодирования, стандарты ascii и iso 8859, кодовые страницы, юникод.
- •21. Архитектура на основе общей магистрали. Характеристики системной магистрали.
- •22. Алгоритм функционирования системной магистрали. Взаимодействие устройств.
- •23. Иерархия магистралей: двух- и трехшинная архитектура.
- •24. Шинный арбитраж: предпосылки введения, схемы приоритетов.
- •25. Шинный арбитраж: алгоритмы динамического изменения приоритетов.
- •26. Централизованный параллельный и многоуровневый арбитраж шины.
- •27. Централизованный последовательный арбитраж.
- •28. Децентрализованный арбитраж шин.
- •29. Опросные схемы арбитража шин.
- •30. Протокол шины: понятие, виды протоколов. Транзакции синхронной шины.
- •31. Асинхронные протоколы шины: транзакции, тайм-ауты.
- •32. Пакетный режим пересылки информации. Конвейеризация транзакций.
- •33. Расщепление транзакций. Увеличение полосы пропускания шины.
- •Локализация данных;
- •Управление и синхронизация
- •Обмен информацией
- •Буферизация данных
- •Обнаружение ошибок
- •36. Структурная организация модуля ввода-вывода.
- •37. Алгоритм обмена информацией между центральным процессором и внешним устройством.
- •38 Способы организации ввода-вывода. Программно управляемый ввод-вывод.
- •39. Команды, используемые при программно управляемом вводе-выводе.
- •40. Механизм ввода-вывода по прерываниям
- •41. Методы идентификации устройств, запрашивающих прерывание.
- •42. Векторные прерывания: принципы реализации, виды.
- •43 Приоритеты прерываний. Отличие последовательной обработки прерываний от обработки вложенных прерываний.
- •44. Контроллер прямого доступа к памяти: состав и назначение компонентов, инициализация.
- •45. Алгоритм обмена на основе пдп. Буферизация данных.
- •Варианты реализации механизма пдп. Достоинства и недостатки.
- •Понятия канала ввода-вывода и процессора ввода-вывода.
- •Канальная программа. Управляющее слово канала.
- •Алгоритм функционирования канала ввода-вывода. Способы организации взаимодействия ву с каналом.
- •Режимы канала ввода-вывода.
- •Методы доступа к данным в памяти компьютера.
- •Параметры оценки быстродействия памяти.
- •Иерархическая архитектура памяти компьютера: предпосылки внедрения, принципы реализации и функционирования.
- •Локальность по обращению: виды, использование в архитектурных решениях.
- •Иерархия памяти компьютера: характеристики, описание уровней.
- •Основная память компьютера: назначение, типы запоминающих устройств, способы организации.
- •57 Адресная организация памяти
- •58. Блочная организация памяти: назначение, виды, факторы эффективности применения
- •59. Расслоение памяти и чередование адресов: назначение, принцип реализации
- •60. Ассоциативная память: логическая организация, функционирование
- •63 Логическая и функциональная организация кэш-памяти прямого отображения.
- •64 Логическая и функциональная организация полностью ассоциативной кэш-памяти.
- •65 Логическая и функциональная организация множественно-ассоциативной кэш-памяти.
- •66 Алгоритмы замещения информационных блоков в кэш-памяти: назначение, виды, реализация.
- •67 Согласование содержимого кэш-памяти и оп. Стратегии записи в кэш-памяти.
- •68 Многоуровневая кэш-память. Принстонская и гарвардская архитектуры кэш-памяти.
- •69 Виртуализация памяти компьютеров: предпосылки внедрения, принцип реализации, виды виртуальной памяти.
- •70 Концепция страничной организации памяти. Взаимодействие виртуальной памяти с кэш-памятью.
- •71 Варианты реализации страничной таблицы. Tlb.
- •72 Ограничения страничной организации памяти. Сегментация памяти.
- •73 Проблемы динамического распределения памяти при сегментации. Сегментно-страничная организация памяти.
- •74 Метод колец защиты памяти.
- •75 Метод граничных регистров памяти.
- •76 Защита памяти по ключам.
- •Концепция raid: принципы построения массивов дисковой памяти, назначение, способы реализации.
- •78. Дисковые массивы raid уровней 0, 1, 10: назначение, принципы реализации, свойства.
- •79. Дисковые массивы raid уровней 5, 6: назначение, принципы реализации, свойства.
- •81. Прерывания: фаза прерывания, поток данных, классы прерываний.
- •82. Арифметический конвейер: назначение, принципы реализации. Понятие суперковейера.
- •83. Конвейерная обработка данных: предпосылки внедрения, принципы реализации, способы синхронизации ступеней.
- •1. Синхронный конвейер
- •2. Асинхронный конвейер
- •84. Синхронный конвейер: реализация 6-ступенчатого конвейера, метрики эффективности, оценка выигрыша от внедрения.
- •Ускорение
- •2. Эффективность
- •3 . Пропускная способность (производительность)
- •85. Виды рисков синхронного конвейера.
- •86. Методы снижения приостановок конвейера.
- •88. Risc-архитектура: средства оптимизации использования регистров.
- •89. Параллелизм уровня команд. Концепция vliw-архитектуры.
- •90. Суперскалярные компьютеры: принципы построения, структура процессора.
- •1) Преобразовать выражение в постфиксную форму;
- •2) Показать последовательность стековых операций при использовании полиз.
Ускорение
Теоретически наилучшее время обработки входного потока из N команд:
Ускорение
2. Эффективность
Д оля ускорения, приходящаяся на одну ступень конвейера:
3 . Пропускная способность (производительность)
Номинальная производительность (при полной загрузке)
Оценки выигрыша от конвейеризации
В синхронном конвейере:
Т.к. tT ≥ ti, имеем:
В соответствии с (ti + ti+1 > tT, ):
или
Далее:
< <
или
Учитывая, что
получаем
Издержки конвейерной обработки
пропускная способность процессора повышается;
практическая длина конвейера ограничена (вследствие накладных расходов);
каждая команда проходит все стадии обработки;
время выполнения отдельной команды несколько увеличивается;
некоторые стадии предполагают одновременное обращение к памяти;
из-за команд условного перехода могут аннулироваться ранее извлеченные команды; подобное и в случае прерывания.
85. Виды рисков синхронного конвейера.
Проблема
Потенциальная производительность конвейера команд на практике недостижима по причине конфликтных ситуаций (риск, hazard).
Причины рисков:
попытка нескольких команд одновременно обратиться к одному и тому же ресурсу компьютера (структурный риск);
взаимосвязь команд по данным (риск по данным);
неоднозначность при выборке следующей команды в случае команд перехода (риск по управлению).
Структурный риск
Конфликт по ресурсам: несколько команд, находящихся на разных ступенях конвейера, пытаются одновременно использовать один и тот же ресурс (чаще всего память).
Конвейер приостанавливает выполнение одной из команд до тех пор, пока не станет доступным требуемое ФУ.
Примеры:
машины с не полностью конвейерными ФУ:
время работы такого устройства может составлять несколько тактов синхронизации конвейера;
последовательные команды, использующие данное ФУ, не могут поступать в него в каждом такте;
недостаточное дублирование некоторых ресурсов, (только один порт записи в регистровый файл и т.п.);
единственный конвейер памяти для команд и данных.
Конфликт по данным
Две команды в конвейере (i и j) предусматривают обращение к одной и той же переменной х, причем команда i предшествует команде j.
Конфликт возникает, если имеет место зависимость между командами, и они расположены по отношению друг к другу достаточно близко
Следствиe: совмещение операций может привести к изменению порядка обращения к операндам.
В общем случае между i и j ожидаемы три типа конфликтов:
«Чтение после записи» (RAW);
«Запись после чтения» (WAR);
«Запись после записи» (WAW).
Условия отсутствия конфликта по данным
Условия Бернстейна (Bernstein's Conditions):
где О(m) – множество ячеек, изменяемых командой m;
I(n) – множество ячеек, читаемых командой n.
Соблюдение соотношений является достаточным, но не необходимым условием (в ряде случаев коллизий может и не быть).
Конфликт по управлению
Два фактора:
выборка команды из точки перехода для любой команды перехода;
выполнение команд условного перехода.