4. Обработчик прерывания
Перечислим основные действия, который должен выполнить обработчик прерываний:
Сохранять при необходимости содержимое всех или части программно-доступных регистров (эту процедуру иногда называют переключением контекста);
Заблокировать все прерывания, возникновение которых в процессе выполнения обработчика может привести к конфликту (часто это выполняется аппаратурой ЭВМ без участия программы);
Разрешить все прерывания, которые имеют право возникать во время обработки данного прерывания;
Определить источник прерывания;
Выполнить запланированную обработку прерывания;
Восстановить ССП;
Разрешить все прерывания, которые были запрещены при обработке данного прерывания.
Возобновлять выполнение прерванного процесса; вместо этого обработчик прерывания может заканчивать свою работу переводом ЭВМ в состояние ожидания (например, при машинных сбоях) или передачей управления ОС.
Основные типы прерываний в ЭВМ типа IBM PC с МП 80х86
Прерывания в этой ЭВМ могут быть разбиты на следующие группы:
Немаскируемое аппаратное прерывание, возникающее в результате серьезного аппаратного сбоя в работе МП и внутренней памяти.
Внешние аппаратные прерывания, возникающие при возникновении сигналов прерывания от таймера, клавиатуры и различных ПУ;
Внутренние события, называемые исключениями и возникающие в том случае, если процессор не может выполнить очередную команду, например, вследствие равенства делителя нулю при выполнении операции деления, недопустимом коде команды и т.д.; к этой же группе относится прерывание, называемое исключением отладки и возникающее в том случае, если по заданию программиста в команде при трансляции ???? был установлен признак так называемой ловушки;
Программные прерывания, возникающие при выполнении процессором команды int с числовым аргументом.
Таймер. Интервальный таймер
Другим аппаратным устройством, имеющим важнейшее значение для организации вычислительного процесса, является таймер. Его использование позволяет программно-аппаратным способом задавать программные события, наступающие по истечении заданного промежутка времени, считая от момента задания этих событий. Эти события реализуются путем выработки сигнала прерывания от таймера и включения оответствующего обработчика прерывания. Рассмотрим более подробно работу таймера на примере его устройства в ЭВМ типа IBM PC с МП типа 80х86.
Этот таймер состоит из трех почти одинаковых каналов – каналов "0", "1" и "2". При работе программ главным образом используется канал "0", поэтому он и будет рассмотрен; на рис.1 приведена его схема. Генератор импульсов (ГИ) вырабатывает с частотой f=1193180 Гц непрерывную последовательность импульсов, поступающих на импульсные входы всех трех каналов. При каждом поступлении импульса на вход 16-разрядного счетчика из содержимого последнего вычитается "1" и при переходе этого счетчика из состояния 000...01 в состояние 000...00 вырабатывается сигнал прерывания, поступающий в СПП для включения последним программы-обработчика прерывания от таймера. Если исходно состояние счетчика таймера равно 00...0, то при поступлении очередного импульса из ГИ состояние счетчика становится равным 11...1 и далее уменьшается на "1" при каждом поступлении импульса из ГИ. В этом случае сигнал прерывания будет выработан таймером после поступления на его вход 65536 импульсов, т.е. по прошествии интервала времени, примерно равного 55 мсек, что соответствует частоте срабатывания таймера, примерно равной 18,2 Гц. В случае, если интервал времени срабатывания таймера должен иметь меньшее значение, чем 55 мсек, то в счетчик таймера необходимо занести код, соответствующий числу импульсов N, вычисляемому по формуле
где F - требуемое значение частоты срабатывания таймера, причем долно выполняться неравенство F > 18,2 Гц. Например, для F = 72,8 Гц получим, что N = 16389,8; округляя, получим, что в счетчик таймера должен быть занесен двоичный код 0 100 000 000 000 110.
Занесение требуемого кода в счетчик таймера производится следующим образом. Сначала МП х86 должен выполнить команду программы, которая производит передачу в порт таймера с шестнадцатеричным номером
40h требуемый двоичный код. Затем МП х86 должен выполнить команду программы, которая производит передачу в порт таймера с шестнадцатеричным номером 43h байта, в котором указывается номер программируемого канала таймера, режим работы этого канала и количество передаваемых в счетчик таймера байтов - 1 или 2. После этого в запрограммированном канале таймера немедленно начинает функционировать сначала схема управления занесением кода в счетчик таймера и затем сам счетчик таймера в соответствии с полученным заданием.
Рис.1. Схема таймера в ПЭВМ IBM PC для канала "0"
Рассмотрим теперь работу программы, которую обычно называют интервальным таймером. Необходимость использования этой программы определяется тем обстоятельством, что в большинстве типов ЭВМ, в том числе и в ЭВМ типа IBM PC, используется только один таймер, хотя во многих случаях при функционировании достаточно сложных программ возникает необходимость организации нескольких параллельно существующих программ, которые должны быть включены в различные заранее опре деленные моменты времени. Один из возможных способов организации интервального таймера состоит в следующем. Этой программой, для управления процессом параллельного выполнения нескольких программ, в оперативной памяти составляется таблица, в которой для каждой из этих программ выделяется несколько строк, содержащих следующие параметры:
адрес начала i-й программы;
значение Т(i) интервала времени, по истечении которого должна быть включена эта программа, причем отсчет этого интервала начинается с момента организации интервальным таймером этой программы;
текущее значение интервала времени t(i), по истечении которого должна быть включена эта программа;
признак c(i) режима включения этой программы - циклический или разовый (пусть, например, с(i)=0 для разового режима).
Кроме того, в этой таблице должна быть еще одна строка, общая для всех программ, в которой содержится значение интервала времени Т, которое задано для текущего включения таймера.
Тогда при каждом включении программы-обработчика прерывания от таймера в этой таблице корректируются все интервалы времени, величина которых больше нуля, путем уменьшения их значений на величину Т. Если после корректировки окажется, что для каких-то программ величина t(i)=0 или t(i)<0, то должно быть организовано последовательное включение этих программ. Если для каких-то программ с(i)=1, то должно быть выполнено присвоение t(i)=T(i) и затем организовано очередное включение этих программ по истечении соответствующих им интервалов времени, равных t(i).
Лекция N 3
- Предмет курса "Организация вычислительного процесса"
- Определение термина "ос" и перечень функций, выполняемых ос
- Терминология, принятая при рассмотрении ос
- Основные принципы построения ос
- Общие принципы управления ресурсами
- Эволюция аппаратных средств поддержки ос и режимов работы в эвм первого - четвертого поколений
- Cистема прерывания программ (спп)
- 1. Понятие о состоянии программы. Вектор (слово) состояния
- 2. Принципы организации спп
- 3. Векторное прерывание
- 4. Обработчик прерывания
- Концепции процесса
- Блок управления процессом
- Основные функции ядра ос
- Планирование загрузки процессоров
- Уровни планирования
- Планирование с переключением и без переклячения
- Использование приоритетов при планировании процессов
- Дисциплины распределения ресурсов, используемые в ос
- О выборе величины кванта времени
- Управление памятью
- Иерархия памяти
- Связное и несвязное распределение памяти
- Блочная организация памяти
- Виртуальная память
- Программно-аппаратные средства защиты виртуальной памяти
- Управление виртуальной памятью
- 1. Стратегии выталкивания страниц
- 2. Стратегии подкачки страниц
- 3. Стратегии размещения
- Управление вводом-выводом данных в эвм
- Методы управления пу
- Использование буферов при проведении обменов
- Принципы, заложенные в подсистему управления вводом-выводом в ос unix
- Система управления данными (файловая система)
- Логическая организация файлов
- 1. Последовательная организация.
- 2. Библиотечная организация.
- Физическая организация файлов
- 1. Распределение при помощи цепочек блоков.
- 2. Распределение при помощи цепочек индексов
- 3. Распределение при помощи таблиц поблочного отображения
- Организация каталогов файлов в ос
- Дескриптор файла (дф)
- Матрица управления доступом (МтУд)
- Управление доступом в зависимости от класса пользователей
- Копирование и восстановление информации
- Оценка производительности вычислительной системы (вс)
- Необходимость контроля и оценки производительности вс
- Показатели производительности вс
- Методы оценки производительности
- 1. Элементарные времена
- 2. Смеси команд
- 3. Аналитические модели
- 4. Измерительные программы (ип)
- 5. Имитационные модели
- 6. Измерительные мониторы
- Локальные вычислительные сети
- Классификация лвс
- Модель протоколов взаимодействия открытых систем
- Устройства передачи данных (упд) для лвс
- Локальные вычислительные сети (окончание)
- Функционирование лвс под управлением сос NetWare
- Функционирование рс в лвс под управлением сос NetWare
- Функционирование сервера в лвс под управлением сос NetWare
- Файловая система сервера
- Система отказоустойчивости в лвс с сос nw
- Система слежения за транзакциями
- Обзор средств обеспечения отказоустойчивости и безопасности работы лвс
- Базы и банки данных
- Преимущества использования БнД
- Требования к БнД
- Языковые средства БнД
- Типы описания данных
- Последовательность действий в БнД при обработке запросов пользователей
- Типы моделей данных (мд), используемых при построении бд
- Общие принципы функционирования операционной системы ms dos
- 1. Модуль bios.
- 2. Блок начальной загрузки (бнз)
- 3. Модуль расширения базовой системы ввода-вывода
- 4. Модуль обработки прерываний (моп)
- 5. Командный процессор (кп)
- 6. Утилиты ms dos
- 7. Файл config.Sys
- 8. Файл autoexec.Bat
- Резидентные программы
- Проблема реентерабельности ms dos
- Реальный режим работы цп 80386
- Защищенный режим работы цп 80386
- Виртуальный режим работы цп 80386 (режим v86). Эмуляция ms dos в режиме v86
- Принципы обеспечения в ос многозадачного и многопользовательского режимов (на примере ос типа Windows)
- Характерные свойства современных многозадачных и многопользовательских ос