69772

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

Лекция

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

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

Украинкский

2014-10-10

28 KB

3 чел.

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

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

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

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

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

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

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

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

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

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

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

Наступний потік для виконання вибирають відповідно до принципів планування потоків, які ми розглянемо в розділі 4.

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

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

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

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

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

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

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

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

Контрольні запитання:

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

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


 

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

6031. Активне мережеве обладнання 366 KB
  Активне мережеве обладнання. Мета роботи:ознайомитись з основними токологіями комп'ютерних мереж та загальною характеристикою і класифікацією активного мережевого обладнання та функціонуванням мереж типу Ethernet. Теоретична частина ...
6032. Нелінійні радіоелектронні схеми 23.74 KB
  Нелінійні радіоелектронні схеми У даній роботі досліджується ряд схем, у яких використовуються нелінійні елементи. Властивістю таких схем є поява у спектрі сигналу нових частот, зокрема, гармонік вхідного сигналу та комбінаційних частот. Це можна ви...
6033. Розробка лексичного аналізатора (сканеру, scanner) 300 KB
  Розробка лексичного аналізатора (сканеру, scanner) Постановка задачі Розробити програму лексичного аналізатора (ЛА) для підмножини мови програмування SIGNAL. Програма має забезпечувати наступне (якщо це передбачається граматикою варіанту): зг...
6034. Дослідження RC-підсилювача 291.19 KB
  Дослідження RC-підсилювача 1. Розрахувати елементи схеми рис.1. за формулами. Значення параметрів для розрахунку взяти з попередньої роботи. Рис.1. Для цього скористатися файлом lab2.nbдля пакету Mathematica. 2. Побудувати амплітудно-частотну ...
6035. Характеристики та параметри біполярного транзистора 29.96 KB
  Характеристики та параметри біполярного транзистора Завдання Для транзистора, тип якого вказано в вашому індивідуальному завданні, побудуйте вхідну характеристику. Замалюйте її і поставте на ній робочу точку. Визначіть в ній режимну напругу Ub...
6036. Организация VPN средствами протокола SSL в Windows Server 2003 144 KB
  Организация VPN средствами протокола SSL в Windows Server 2003 Предположим, нам необходимо организовать защищенный обмен информацией между web-сервером и произвольным клиентом. Для организации воспользуемся ОС Windows Server 2003, в качестве web-сер...
6037. Символи Лежандра та Якобі 101.5 KB
  Символи Лежандра та Якобі Означення. Нехай p - просте, a - ціле число. Символ Лежандра визначається так: Критерій Ейлера. Число a, яке не ділиться на непарне просте p, є квадратичним лишком за модулем p тоді і тільки тоді, коли...
6038. Зміст логістичних функціональних галузей 69.5 KB
  Зміст логістичних функціональних галузей План Логістика постачання Виробнича логістика Логістика збуту Логістика переробки та утилізації відходів Транспортна логістика Логістика постачання Логістика постачання охоплює ф...
6039. Классификация и основные свойства единиц информации 39.48 KB
  Классификация и основные свойства единиц информации: Общие понятия и задачи проектирования информационного обеспечения. Имя, структура и значение единиц информации. Экономические показатели и документы. Операции над единицами информации. Классификац...