Студопедия

КАТЕГОРИИ:


Архитектура-(3434)Астрономия-(809)Биология-(7483)Биотехнологии-(1457)Военное дело-(14632)Высокие технологии-(1363)География-(913)Геология-(1438)Государство-(451)Демография-(1065)Дом-(47672)Журналистика и СМИ-(912)Изобретательство-(14524)Иностранные языки-(4268)Информатика-(17799)Искусство-(1338)История-(13644)Компьютеры-(11121)Косметика-(55)Кулинария-(373)Культура-(8427)Лингвистика-(374)Литература-(1642)Маркетинг-(23702)Математика-(16968)Машиностроение-(1700)Медицина-(12668)Менеджмент-(24684)Механика-(15423)Науковедение-(506)Образование-(11852)Охрана труда-(3308)Педагогика-(5571)Полиграфия-(1312)Политика-(7869)Право-(5454)Приборостроение-(1369)Программирование-(2801)Производство-(97182)Промышленность-(8706)Психология-(18388)Религия-(3217)Связь-(10668)Сельское хозяйство-(299)Социология-(6455)Спорт-(42831)Строительство-(4793)Торговля-(5050)Транспорт-(2929)Туризм-(1568)Физика-(3942)Философия-(17015)Финансы-(26596)Химия-(22929)Экология-(12095)Экономика-(9961)Электроника-(8441)Электротехника-(4623)Энергетика-(12629)Юриспруденция-(1492)Ядерная техника-(1748)

Типы прерываний




Прерывания могут возникать вследствие внешних событий (внешние прерывания), генерироваться специальными инструкциями (программные прерывания), либо из-за ошибок, возникающих в процессе выполнения программы (исключений). Независимо от типа прерывания микропроцессор обрабатывает их одинаково.

Внешние прерывания возникают вне микропроцессора. Запросы прерываний поступают по специальным входным линиям микросхемы микропроцессора. Внешние прерывания инициируются аппаратурой. Они могут быть вызваны сигналом микросхемы таймера, сигналом от принтера, нажатием клавиши на клавиатуре и множеством других причин. Внешние прерывания не координируются с работой программного обеспечения. Различают немаскируемые и маскируемые внешние прерывания.

Немаскируемые прерывания. Микропроцессор извещается о возникновении немаскируемого внешнего прерывания с помощью сигнала, поступающего по его линии NMI (Non Mask Interrupt). Получив сигнал, микропроцессор после выполнения очередной инструкции производит переход по вектору 2, постоянно назначенному для немаскируемых прерываний.

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

Когда происходит немаскируемое прерывание, микропроцессор блокирует обработку новых запросов немаскируемых прерываний до тех пор, пока не будет выполнена инструкция возврата из прерывания IRET. Таким образом, немаскируемые прерывания не могут быть «вложенными».

Немаскируемое прерывание не может быть маскировано (игнорировано) средствами самого микропроцессора. Однако обычно имеются внешние по отношению к микропроцессору схемы, позволяющие запретить немаскируемые прерывания путём блокировки прохождения сигнала по линии NMI.

Маскируемые прерывания. Сигнал о запросе маскируемого прерывания поступает в микропроцессор по линии INT. Выполнение текущей инструкции завершается обычным образом и в стеке сохраняется адрес следующей инструкции.

Маскируемые прерывания могут быть запрещены средствами самого микропроцессора – для этого в регистре флагов должен быть сброшен флаг прерываний IF. В таком случае микропроцессор игнорирует сигнал на линии INT и продолжает выполнять инструкции в обычном порядке. Однако когда этот флаг установлен и поступает запрос маскируемого прерывания, микропроцессор завершает выполнение текущей инструкции, после чего передаёт управление подпрограмме обработки прерывания.

Ассемблерная команда CLI сбрасывает флаг прерываний IF, а команда STI вновь его устанавливает. Вызовы этих команд должны быть сбалансированы, и всегда завершаться вызовом команды STI. В противном случае, система окажется недоступной для управления. Кроме того, не следует сбрасывать флаг прерываний IF на время, превышающее период следования импульсов от таймера-счетчика, т.к. иначе операции, зависящие от времени, будут выполняться некорректно.

В отличие от немаскируемых прерываний, маскируемым не назначается какой-либо фиксированный вектор прерывания. Вместо этого микропроцессор, начиная процедуру выполнения маскируемого прерывания, выдаёт сигнал INTA, получив который, устройство, запросившее прерывание, передает микропроцессору один байт информации, являющийся номером вектора прерывания, которое должно быть выполнено. Для обработки маскируемых прерываний можно использовать до 256 векторов.

Компания Intel зарезервировала векторы 0–31 для внутренних нужд микропроцессора. Поэтому настоятельно не рекомендуется использовать инструкции INT с номерами 0–31, а также назначать этим векторам маскируемые аппаратные прерывания.

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

Программные прерывания могут быть вложенными. Они инициируются командой INT с номером от 0 до 0FFh. Базовая система ввода-вывода BIOS и операционная система MS-DOS предоставляют множество функций в виде программных прерываний. Некоторые программные прерывания обеспечивают несколько функций. Например, большинство полезных для пользователя функций MS-DOS закреплено за прерыванием 21h. Номер конкретной функции должен быть указан в регистре AH, а подфункции – в регистре AL.

Аппаратное прерывание может получить управление при выполнении программного. При этом не возникает конфликтов, т.к. каждая подпрограмма обработки прерывания сохраняет значения всех используемых регистров и затем восстанавливает их при выходе. Схема обработки программного прерывания показана на рис. 41

 

 
 

 


Рис. 41. Схема обработки программного прерывания.

 

 

Прерывания по исключению разделяются на несколько видов – исключения по ошибке деления, по точке остановка, по переполнению и по трассировке.

Прерывание по ошибке деления возникает при выполнении инструкции DIV или IDIV, если результат превышает максимально допустимую величину, а также при попытке деления на ноль. В результате управление передаётся обработчику прерывания по вектору 0.

Прерывание по точке останова возникает, если в программе встретилась инструкция INT 3. Выполнение инструкции приводит к передаче управления обработчику прерывания по вектору 3. Система команд микропроцессора 8086 обеспечивает два формата инструкции INT 3 – однобайтовый (код команды CC) и двухбайтовый (код команды CD 03). Функционально они не отличаются, но двухбайтовый формат принято относить к программным прерываниям, а однобайтовый – к исключениям.

Прерывание по переполнению происходит, если при выполнении инструкции INTO установлен флаг переполнения OF. Когда флаг сброшен, инструкция INTO не производит никаких действий. Обработчик прерывания по переполнению использует вектор 4.

Прерывания по трассировке происходят после выполнения каждой инструкции, когда в регистре флагов установлен флаг трассировки TF. В этом случае, завершив выполнение инструкции, микропроцессор передаёт управление обработчику прерывания по вектору 1.

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

Например, если при завершении обработчика прерывания по трассировке с помощью команды IRET в восстановленном содержимом регистра флагов флаг TF окажется установлен, то новое прерывание по трассировке произойдёт не сразу после выполнения инструкции IRET, а по завершении команды, на которую инструкцией IRET будет возвращено управление.




Поделиться с друзьями:


Дата добавления: 2014-11-16; Просмотров: 1662; Нарушение авторских прав?; Мы поможем в написании вашей работы!


Нам важно ваше мнение! Был ли полезен опубликованный материал? Да | Нет



studopedia.su - Студопедия (2013 - 2024) год. Все материалы представленные на сайте исключительно с целью ознакомления читателями и не преследуют коммерческих целей или нарушение авторских прав! Последнее добавление




Генерация страницы за: 0.007 сек.