- •Классификация эвм, краткие характеристики суперЭвм, мейнфреймов и мини-эвм
- •Настольная вычислительная система.
- •Классификация процессоров.
- •Регистровая модель процессора x86.
- •Режимы работы процессора 80386.
- •1.Реальный режим
- •2. Защищенный режим
- •Процессор х86: непосредственная и регистровая адресация.
- •Процессор х86: прямая адресация и прямая со сдвигом.
- •Процессор х86: косвенная адресация и косвенная со сдвигом.
- •Процессор х86: регистровая адресация и регистровая с масштабированием.
- •Адресация с масштабированием
- •Размещение в памяти многомерных статических массивов и доступ к их элементам.
- •Размещение в памяти многомерных динамических массивов и доступ к их элементам.
- •Формирование исполнительного адреса из трех и четырех составляющих.
- •Процессор х86: инструкции копирования данных.
- •Процессор х86: инструкции ввода-вывода.
- •Представление целых чисел: прямой код, дополнительный код, bsd.
- •Процессор х86: инструкции сложения, сложения с переносом и сложение чисел в формате bcd.
- •Процессор х86: инструкции вычитания, вычитания с заемом и вычитание чисел в формате bcd.
- •Процессор х86: инструкции умножения.
- •Процессор х86: инструкция деления и операции расширения знакового бита.
- •Процессор х86: поразрядные логические инструкции, использование масок.
- •Процессор х86: инструкции сдвига. Умножение и деление на константы.
- •Процессор х86: инструкции цикла. Ожидание готовности пу с тайм-аутом.
- •Процессор х86: безусловный переход и виды меток.
- •Процессор х86: вызов процедуры; рамка стека функции в с.
- •Процессор х86: инструкции условного перехода.
- •Процессор х86: строковый примитив копирования данных.
- •Процессор х86: строковые примитивы сравнения данных, сканирования данных и заполнения данных.
- •Сегменты реального и защищенного режима. Глобальная и локальная таблицы дескрипторов.
- •Селектор сегмента. Механизм получения линейного адреса в защищенном режиме процессора x86.
- •Механизм преобразования линейного адреса в физический в процессоре x86.
- •Преимущества виртуального отображения страниц и адресное пространство процесса.
- •Формат дескриптора сегмента в процессорах x86. Прикладные сегменты.
- •Формат вентиля вызова и исключения. Область применения вентилей вызова.
- •Основные исключения защиты; обработка исключения отсутствие страницы в памяти.
- •Уровни привилегий и кольца защиты защищенного режима.
- •Аппаратная поддержка многозадачности, формат сегмента состояния задачи - tss.
- •Карта ввода/вывода. Прямой доступ к портам ввода/вывода в Windows и Linux.
- •Методы управления пу
- •Использование буферов при проведении обменов
- •Принципы, заложенные в подсистему управления вводом-выводом в ос unix
- •Система управления данными (файловая система)
- •Логическая организация файлов
- •1. Последовательная организация.
- •2. Библиотечная организация.
- •Физическая организация файлов
- •1. Распределение при помощи цепочек блоков.
- •2. Распределение при помощи цепочек индексов
- •Дескриптор файла (дф)
- •Матрица управления доступом (МтУд)
- •Управление доступом в зависимости от класса пользователей
- •Копирование и восстановление информации
- •Свопинг и пейджинг
- •2. Стратегии подкачки страниц
- •3. Стратегии размещения
Использование буферов при проведении обменов
Скорость приема-передачи данных периферийным устройством как правиломного меньше скорости приема-передачи данных каналом. Для сглаживания эффекта несоответствия скоростей этих устройств между ними включают в работу один или несколь буферов, роль которых выполняют непрерывные области ОП.
Рис.3. Использование одного буфера в процессе обмена с ПУ
Буфер является критическим ресурсом в отношении программных и внешних процессов, которые при параллельном существовании информационно взаимодействуют.
Подсистема ОС, управляющая вводом-выводом, должна выполнять следующие функции:
выделять и уничтожать буферы в ОП;
определять их назначение (для ввода или для вывода);
производить синхронизацию внешнего и программного процессов, взаимодействующих через буфер; цель синхронизации состоит в устранении возможности одновременного обращения этих процессов к буферу; например, программный процесс, заказавший считывание данных с некоторого ПУ, не должен обращаться к буферу, куда записываются данные с этого ПУ, до тех пор, пока эта передача не будет завершена; это может быть обеспечено с помощью так называемых семафоров.
При решении задачи синхронизации важным фактором является определение числа буферов, закрепляемых за отдельным каналом или ПУ, а также размер буфера, т.е. число байтов или слов в нем. Для устранения длительных задержек при ожидании наплнения буфера при передаче данных часто используют несколько буферов, порядок доступа к которым определяется подсистемой ОС, управляющей вводом-выводом.
Рис.4. Использование двух буферов в процессе обмена с ПУ
При определении длины буфера находят компромисс между эффективностью функционирования ПУ, канала и ОП. Каналу и внешнему ЗУ (ВЗУ) более "выгодны" большие порции данных, которые можно хранить непрерывными участками на носителях ВЗУ и пересылать за одну операцию ввода-вывода, реализуемую каналом: чем длиннее блок, тем дольше канал работает автономно от ЦП. Однако в отношении эффективности использования ОП требования к длине буфера противоположны, т.е. длина буфера должна быть сравнительно невелика при мультипрограммной работе ЭВМ, но в настоящее время ввиду значительного удешевления стоимости компонентов ОП и соответственно значительного возрастания объема ОП в современных ЭВМ длина буферов может выбираться сравнительно большой. На рис.5 изображена временная диаграмма, поясняющая возрастание производительности ЭВМ при использовании для обмена с ПУ двух буферов вместо одного.
|
ПУ - буфер 1 |
|
ПУ - буфер 2 |
|
|
|
|
||||||||||
|
|
|
|
|
|
|
|
t |
|
||||||||
|
|
|
|
|
|
|
|
|
|
||||||||
|
|
|
|
|
|
|
|
t |
|
||||||||
|
|
|
перепись из буфера 1 в рабочую зону программы |
|
перепись из буфера 2 в рабочую зону программы |
||||||||||||
|
|
|
|
Рис.5. Временная диаграмма использования двух буферов
При управлении буферами важным фактором является оперативность обновления данных в них. Во многих случаях оказывается выгодным для повышения эффективности вычислительного процесса данные, записанные в буфер программным процессом, не передавать сразу в ВЗУ. Так, в ОС UNIX на основе управления буферами строится программный аналог кэш-памяти при работе с ВЗУ. Физическая запись заполненных блоков (буферов) в ВЗУ производится только тогда, когда требуется свободный буфер, но все они оказываются занятыми. Такая задержка предполагает, что программным процессам через относительно небольшой промежуток времени необходимо будет сосчитать данные, которые были подготовлены ранее для записи в ВЗУ, но вместо этого хранятся пока в буферах. Очевидно, что в этом случае ввиду отсутствия обращения к ВЗУ для чтения запрошенных данных ввод этих данных с буферов будет произведен существенно быстрее, чем в случае, когда данные сразу были бы отправлены на хранение в ВЗУ.