Система с циклическим запросом
IO, I1,…, IN – запросы на прерывание. Система должна сформировать код номера запроса и общий запрос по прерыванию. По сигналу RESET счетчик и триггер установить в нулевое состояние. На тактовый ход счетчика начинает поступать сигнала CLK. Код со счетчика поступает на вход дешифратора,на выходе которого будет только один активный сигнал, соответствующий входному коду. Если единичный уровень одного из выходов дешифратора совпадает с соответствующим запросом на прерывание, триггер устанавливает едичное состояние, запрещающее подачу тактовых импульсов на вход счетчика.С выхода триггера снимается общий запрос на прерывание, с выхода счетчика – код номера запроса. “+” необходимы минимальные аппаратные затраты, а также простота реализации. “-“ значительное время реакции на прерывание. Увеличении запросов приводит к резкому возрастанию затрат. В системе отсутствует ранжировка запросов по приоритету(одноур сист).
Блок приоритетных прерываний: 1-шифратор уровней приоритетов. 2-регистр текущего состояния (память). Схема имеет два режима работы: ¾ активно происходит обработка запросов на прерывание, триггер 1 устанавливается в 1, триггер 2 в 0-ое состояние. С помощью компаратора сравнивается приоритет поступающего запроса и текущего состояния. Если приоритет поступившего запроса выше, то по сигналу занесения микрокомандой T2 устанавливается в 1, а Т2 - в ноль и система переходит в неактивный режим. ¾ В этом состоянии схема находится до тех пор, пока процесс не обработает запрос и не запишет приоритет текущего состояния в элемент памяти 2.
|