24515

Мультипрограммирование на основе прерываний. Механизм прерываний

Доклад

Информатика, кибернетика и программирование

Мультипрограммирование на основе прерываний. Механизм прерываний.Мультипрограммирование на основе прерываний. Назначение и типы прерываний.

Русский

2013-08-09

25.58 KB

37 чел.

Вопрос 20. Мультипрограммирование на основе прерываний. Механизм прерываний.

§4.3.1.Мультипрограммирование на основе прерываний.

Назначение и типы прерываний.

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

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

В зависимости от источника прерывания делятся на три больших класса: внешние, внутренние и программные.

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

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

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

Прерываниям приписывается приоритет, с помощью которого они ранжируются по степени важности и срочности (рис. 4.7).

Прерывания обычно обрабатываются модулями операционной системы, так как действия, выполняемые по прерыванию, относятся к управлению разделяемыми ресурсами ВС. Процедуры, вызываемые по прерываниям, обычно называют обработчиками прерываний или процедурами обслуживания прерываний (Interrupt Service Routine, ISK). Аппаратные прерывания обрабатываются драйверами соответствующих внешних устройств, исключения – специальными модулями ядра, а программные прерывания – процедурами ОС, обслуживающими системные вызовы. Кроме этих модулей в операционной системе может находиться так называемый диспетчер прерываний, который координирует работу отдельных обработчиков прерываний.

Рис. 4.7. Распределение прерываний по уровням приоритета

§4.3.2.Механизм прерываний.

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

Механизм обработки прерываний независимо от архитектуры вычислительной системы включает следующие элементы:

1. Установление факта прерывания (прием сигнала на прерывание) и идентификация прерывания (в операционных системах иногда осуществляется повторно, на шаге 4).

2. Запоминание состояния прерванного процесса. Состояние процесса определяется значением счетчика команд (адресом следующей команды), содержимым регистров процессора и другой информацией.

3. Управление аппаратно передастся подпрограмме обработки прерывания. В простейшем случае в счетчик команд заносится начальный адрес подпрограммы обработки прерываний, а в соответствующие регистры – информация из слова состояния.

4. Сохранение информации о прерванной программе, которую с помощью действий аппаратуры не удалось спасти на шаге 2.

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

6. Восстановление информации, относящейся к прерванному процессу (этап, обратный шагу 4).

7. Возврат в прерванную программу.

Шаги 1-3 реализуются аппаратно, а шаги 4-7 – программно. Аппаратная поддержка прерываний зависит от типа процессора и аппаратных компонентов, передающих сигнал запроса прерывания от внешнего устройства к процессору (контроллер внешнего устройства, шины подключения внешних устройств, контроллер прерываний, являющийся посредником между сигналами шины и сигналами процессора). Особенности аппаратной реализации прерываний оказывают влияние на средства программной поддержки прерываний, работающие в составе ОС.

Существуют два основных способа, с помощью которых шины выполняют прерывания: векторный и опрашиваемый. В обоих способах процессору предоставляется информация об уровне приоритета прерывания на шине подключения внешних устройств. В случае векторных прерываний в процессор передастся также информация о начальном адресе программы обработки возникшего прерывания – обработчика прерываний.

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


 

А также другие работы, которые могут Вас заинтересовать

65515. МЕТОД РОЗРАХУНКУ ТЕМПЕРАТУРНОГО НАПРУЖЕНО-ДЕФОРМОВАНОГО СТАНУ КОМПОЗИТНИХ СТРИНГЕРІВ ПАНЕЛЕЙ ОБШИВКИ 1.26 MB
  Наукова новизна одержаних результатів полягає у такому: уперше виявлено і обґрунтовано механізм виникнення згинально-крутильних деформацій композитних стержнів з неоднорідним перерізом при зміні температури та або внаслідок усадки...
65516. ФОРМУВАННЯ ДУХОВНО-ТВОРЧОГО ПОТЕНЦІАЛУ СТУДЕНТСЬКОЇ МОЛОДІ В ТРАНСФОРМАЦІЙНОМУ СУСПІЛЬСТВІ 154 KB
  Зрозуміло кожен з нас зацікавлений щоб цей вигляд був гуманістичним культурним людським і людяним і оскільки це так кожен зацікавлений у формуванні відповідних норм в свідомості та поведінці молоді у більш широкому розумінні...
65517. Методи та алгоритми диспетчеризації завдань у розподілених комп’ютерних системах 572.5 KB
  Сьогодні участь у міжнародних програмах стає стратегічним питанням інформаційного розвитку держав. Україна також стоїть на шляху науково-технічної інтеграції у європейський та світовий простір, про що говорить низка проектів, в яких Україна є повноправним учасником.
65519. ДІАГНОСТИЧНА ЗНАЧИМІСТЬ НОВОГО МЕТОДУ ДОВГОХВИЛЬОВОЇ ОФТАЛЬМОГРАФІЇ У ХВОРИХ З ВІКОВОЮ МАКУЛЯРНОЮ ДЕГЕНЕРАЦІЄЮ 226 KB
  Патологія макулярної ділянки очного дна займає одне з перших місць в світі як причина слабкого зору та сліпоти і на теперішній час вважається найбільш складною для діагностики та лікування. Одним із найбільш розповсюджених та найтяжчих захворювань органа зору серед патології очного дна...
65520. Особливості використання сучасних сортів ячменю ярого в селекції на пивоварну якість та продуктивність 222.5 KB
  Актуальність теми полягає в необхідності встановлення ефективності селекції ячменю ярого на пивоварну якість і урожайність на основі використання в схрещуванні сучасних сортів виділених за цінними ознаками продуктивності...
65521. Підвищення точності зміцнювальної накатки зубців за рахунок розробки принципово нової геометрії накатного інструмента 191 KB
  Підвищення продуктивності та якості виготовлення циліндричних зубчастих коліс із одночасним зниженням їх собівартості є однією з найбільш актуальних задач технологів та інструментальників усього світу.
65522. Диференціальний розчинонасос із вертикальним проточним плунжером 1.09 MB
  У будівельній промисловості при спорудженні будівель як промислового так і цивільного призначення до чверті загальної трудомісткості становлять роботи повязані з використанням будівельних розчинів: штукатурні роботи улаштування наливних підлог замонолічування стиків будівельних елементів тощо.
65523. ЕКОЛОГІЧНЕ ОБГРУНТУВАННЯ ЗАХИСТУ ЧОРНОЇ СМОРОДИНИ ВІД ЛУСКОКРИЛИХ ШКІДНИКІВ В ЦЕНТРАЛЬНОМУ ЛІСОСТЕПУ УКРАЇНИ 222 KB
  В агроекологічних умовах Центрального Лісостепу в останні роки значної шкоди агроценозу смородини чорної завдає комплекс лускокрилих фітофагів зокрема смородинова склівка листовійки аґрусова вогнівка та смородинова брунькова міль.