Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Лекции_Р2.doc
Скачиваний:
1
Добавлен:
01.04.2025
Размер:
1.63 Mб
Скачать

2.5 Тема Перемикання контексту й обробка переривань

Самостійна робота №7

План

1. Організація перемикання контексту.

2. Обробка переривань.

Мета: Вивчити організацію перемикання контексту. Знати поняття обробки переривань.

2.5.1Організація перемикання контексту

Найважливішим завданням операційної системи під час керування процесами і потоками є організація перемикання контексту — передачі керування від одного потоку до іншого зі збереженням стану процесора.

Загальних принципів перемикання контексту дотримуються у більшості систем, але їхня реалізація обумовлена конкретною архітектурою. Звичайно потрібно ви­конати такі операції:

      • зберегти стан процесора потоку в деякій ділянці пам’яті (області зберігання стану процесора потоку);

      • визначити, який потік слід виконувати наступним;

      • завантажити стан процесора цього потоку із його області зберігання;

      • продовжити виконання коду нового потоку.

Перемикання контексту звичайно здійснюється із залученням засобів апаратної підтримки. Можуть бути використані спеціальні регістри та ділянки пам’яті, які дають можливість зберігати інформацію про поточну задачу (коли розгляда­ють апаратне забезпечення, аналогом поняття «потік» є поняття «задача»), а також спеціальні інструкції процесора для роботи з цими регістрами та ділянками пам’яті.

Розглянемо апаратну підтримку перемикання задач в архітектурі ІА-32. Для збереження стану процесора кожної задачі (вмісту пов’язаних із нею регістрів процесора) використовують спеціальну ділянку пам’яті — сегмент стану задачі TSS. Адресу цієї області можна одержати з регістра задачі TR (це системний ад­ресний регістр).

Для перемикання задач досить завантажити нові дані в регістр TR. У резуль­таті значення регістрів процесора поточної задачі автоматично збережуться в її сегменті стану, після чого в регістри процесора буде завантажено стан процесора нової (або раніше перерваної) задачі й почнеться виконання її інструкцій.

Наступний потік для виконання вибирають відповідно до принципів плану­вання потоків.

2.5.2 Обробка переривань

У процесі виконання потік може бути перерваний не лише для перемикання кон­тексту на інший потік, але й у зв'язку із програмним або апаратним перериванням (перемикання контексту теж пов'язане із перериваннями, власне, із перериванням від таймера). Із кожним перериванням надходить додаткова інформація (наприклад, його номер). На підставі цієї інформації система визначає, де буде розміщена ад­реса процедури оброблювача переривання (список таких адрес зберігають у спе­ціальній ділянці пам'яті і називають вектором переривань).

Наведемо приклад послідовності дій під час обробки переривання:

        1. збереження стану процесора потоку;

        2. встановлення стека оброблювача переривання;

        3. початок виконання оброблювача переривання (коду операційної системи); для цього з вектора переривання завантажується нове значення лічильника команд;

        4. відновлення стану процесора потоку після закінчення виконання оброблюва­ча і продовження виконання потоку.

Передача керування оброблювачеві переривання, як і перемикання контексту, може відбутися практично у будь-який момент. Основна відмінність полягає в то­му, що адресу, на яку передається керування, задають на основі номера перери­вання і зберігають у векторі переривань, а також у тому, що код оброблювача не продовжується з місця, де було перерване виконання, а починає виконуватися щораз заново.