Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
Lec_3_2.doc
Скачиваний:
6
Добавлен:
21.11.2019
Размер:
201.73 Кб
Скачать
        1. Образи процесу і потоку

Сукупність інформації, що відображає процес у пам'яті, називають образом про­цесу (process image), а всю інформацію про потік — образом потоку (thread image). До образу процесу належать:

  • керуючий блок процесу;

  • програмний код користувача;

  • дані користувача (глобальні дані програми, загальні для всіх потоків);

  • інформація образів потоків процесу.

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

До образу потоку належать:

  • керуючий блок потоку;

  • стек ядра (стек потоку, який використовується під час виконання коду потоку в режимі ядра);

  • стек користувача (стек потоку, доступний у користувацькому режимі).

Усі потоки конкретного процесу можуть користуватися загальною ін­формацією його образу.

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

Соседние файлы в предмете [НЕСОРТИРОВАННОЕ]