2847

Прерывания в ОС MS-DOS

Контрольная

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

Прерывания в ОС MS-DOS Драйвер – это программа, являющаяся посредником между устройством и программой пользователя и предоставляющая набор функций для работы с устройством. В MS-DOS существуют драйверы символьных устройств (за одну операцию обм...

Русский

2012-10-20

36 KB

15 чел.

Прерывания в ОС MS-DOS

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

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

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

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

  •  внутренние – возникают в процессе работы ЦП (деление на 0, переполнение регистра);
  •  аппаратные – инициируются аппаратурой ПК (нажатие клавиш клавиатуры, перемещение мыши);
  •  программные – вызываются пользовательскими приложениями или операционной системой (печать на экран, ввод с клавиатуры).

Каждое прерывание представляется 4-байтовым адресом начала (первой команды) программы обработки прерывания, которая может быть драйвером или входить в состав ОС или BIOS. Этот адрес называется вектором прерывания. В ОС MS-DOS определены 256 различных прерываний, имеющих номера от 00h до FFh. Положение векторов прерываний в ОЗУ строго фиксировано на протяжении всего времени работы ПК. В ОС MS-DOS вектора прерываний располагаются в диапазоне адресов 00000h-003FFh и занимают объём памяти 1K, каждый адрес имеет размер 4 байта (по два байта на адреса сегмента и смещения) для адресации к любому участку 1M памяти ОС. Адрес расположения начала вектора прерывания можно вычислить, умножив номер этого вектора на 4 (так как каждый вектор имеет размер 4 байта).

Каждое прерывание связано с каким-либо устройством или системной операцией. Так как с каждым устройством или системной операцией можно выполнять различные действия (определить положение курсора мыши, состояние кнопок мыши), то каждое прерывание имеет несколько режимов работы, называемых функциями прерывания.

В дальнейшем будем рассматривать только аппаратные и программные прерывания.

Действия, выполняемые системой при обработке прерывания.

  1.  Прерывание инициируется источником прерывания. Если это программное прерывание, то выполняется команда процессора int с номером соответствующего прерывания. Если это аппаратное прерывание, то сигнал от устройства поступает на вход контроллера прерываний, который посылает по соответствующей линии на вход процессора сигнал запроса прерывания.
  2.  Процессор приступает к обработке прерывания. Он сохраняет в стеке выполняемой программы содержимое регистра флагов, регистров CS и IP.
  3.  Процессор читает номер прерывания, определяющий вектор прерывания (для программного прерывания номер задается в команде, для аппаратного прерывания он читается процессором из контроллера прерываний), то есть новые значения регистров CS и IP. Таким образом, выполняется переход по адресу программы обработки прерывания.
  4.  Выполняется программа обработки прерывания, в конце которой должна стоять команда возврата.
  5.  При выполнении команды возврата из стека прерванной программы извлекается содержимое регистра флагов, регистров CS и IP, продолжается выполнение прерванной программы.

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

Регистры процессора Intel8086.

Регистры данных: AX(AH и AL), BX(BH и BL), CX(CH и CL), DX(DH и DL). Это двухбайтовые регистры, однако возможно обращение отдельно к старшему или младшему байту регистра.

Регистры указатели: SI, DI, BP, SP, IP.

Сегментные регистры:  CS, DS, ES, SS.

Регистр флагов, содержит набор специальных битовых переменных (флагов).

Пара регистров CS (сегмент) и IP (смещение) определяют адрес выполняемой команды.

Через регистры передаются данные от инициатора прерывания к программе обработки при вызове прерываний и от программы обработки к инициатору при возврате из программы обработки. Регистры на входе – регистры до выполнения прерывания, регистры на выходе – регистры после выполнения прерывания. Назначение регистров и характер передаваемых через них данных строго фиксированы и описываются в соответствующей документации по ОС MS-DOS.

Средства Borland C++ 3.1 для работы с регистрами процессора Intel8086.

В файле dos.h для работы с регистрами процессора объявлены агрегативные типы данных.

struct  SREGS   {

   unsigned int    es;

   unsigned int    cs;

   unsigned int    ss;

   unsigned int    ds;

};

struct WORDREGS {

   unsigned int    ax, bx, cx, dx, si, di, cflag, flags;

};

struct BYTEREGS {

   unsigned char   al, ah, bl, bh, cl, ch, dl, dh;

};

union   REGS    {

   struct  WORDREGS x;

   struct  BYTEREGS h;

};

Структура SREGS предназначена для работы с сегментными регистрами, структура WORDREGS – для работы с двухбайтовыми регистрами, структура BYTEREGS – для работы с однобайтовыми регистрами, объединение REGS – для возможности доступа к регистрам данных одновременно как двухбайтовым и однобайтовым регистрам.

int int86(int intno, REGS * in, REGS * out);

int int86x(int intno, REGS * in, REGS * out, SREGS * seg);

Функции int86() и int86x() выполняют вызов программного прерывания, номер которого задается параметром intno. Параметры in и out задают регистры на входе и выходе прерывания соответственно. Для функции int86x() параметр seg задает значения сегментных регистров. Перед выполнением прерывания функции копируют значения переменных параметра in в регистры процессора (функция int86x() перед вызовом прерывания также копирует в сегментные регистры DS и ES соответствующие значения из полей cтруктуры seg), после выполнения – значения регистров копируются в параметр out. Функции возвращают значение регистра AX после выполнения прерывания.

unsigned FP_SEG(void far *p);

unsigned FP_OFF(void far *p);

Макросы FP_SEG и FP_OFF выполняют для указателя p выделение сегментной части или смещения соответственно, которое и является результатом макрорасширения.

void far * MK_FP(unsigned seg, unsigned off);

Макрос MK_FP позволяет получить значение указателя из параметров seg и off, задающих сегментную часть и смещение соответственно.


 

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

23740. Степень числа 42 KB
  Сначала определяем значение степени а затем проходим произведение. Найдите значение выражения: 5 23 362 81 : 32 . 3 1 2 4 9 7 5 6 8 12 11 10 5 23 362 81 : 32 = 5  2  2  2 36  5  2  2  2 36 81 : 3  3 Проанализируйте каков порядок действий в нашем выражении Сначала находим значение степени в скобке затем значение произведения значение разности значение степени результата получившегося в скобках значение степени числа 3 значение...
23741. Степень числа 44 KB
  При выполнении каких заданий мы можем получить произведение одинаковых множителей При разложении чисел на простые множители. Что интересного вы можете сказать о полученном ряде чисел Все числа кратны 10. Найдите НОК и НОД чисел а и b если: а = 23 3 52 b = 22 32 7. Что необходимо сделать что бы выполнить задание Надо расписать степени чисел и применить известные алгоритмы А можно ли выполнить задание не расписывая степени Этот вопрос может вызвать затруднение.
23742. Высказывания 228 KB
  Назовите число из полученного ряда сумма цифр в котором равна 6. Какое число данного ряда может быть лишним Например число 50 двузначное а остальные трехзначные. На сколько 150 больше 50 во сколько раз 150 больше 50 на сколько 50 меньше 150 Придумайте числовые выражения частное в которых равно 3. Найдите число которого равны 21.
23743. Взаимно простые числа 72.5 KB
  2 Тренировать способности к использованию: а понятий простого и составного числа; б признаков делимости на 2 5 10 3 9; в различных способов нахождения НОД; г алгоритмов объединения и пересечения множеств. На доске остаются числа: 375 164 2310 171. Разложите получившиеся числа на простые множители.
23744. Делимость произведения 48.5 KB
  Делится ли на 37 число 555 555 555 555 − Сформулируйте в общем виде свойство делимости которое вы наблюдаете. Если первое число делится на второе число второе число делится на третье число то первое число делится на третье число. Докажите используя введение обозначений что если первое число делится на второе а второе делится на третье то и первое число делится на третье. Первое число a второе число b третье число c.
23745. Делимость произведения 48.5 KB
  Что означает что число а делится на число b Это означает что существует такое число с которое при умножении на b дает а. И что Можно заменить число 16 произведением 4 и 4 и получится произведение 4 4 а. Если ктолибо из учащихся по аналогии с предыдущим заданием верно найдет ответ последнего примера число 555 то учитель просит его обосновать как выполнены действия. А как можно разделить произведение на число Разделить один множитель а потом полученный результат умножить на второй множитель.
23746. Делимость произведения 85.5 KB
  Делится ли: на 13 на 5 на 2 на10 На 13 делится так как 39 делится на 13; на 5 не делится так как ни один из множителей не делится на 5; на 2 делится так как 356 кратно 2; на 10 не делится так как ни один из множителей не делится на 10. Делится ли 225 на 3 если известно что 225 делится на 15 Да делится т. 15 делится на3. Известно что: а 686 делится на 49.
23747. Делимость суммы и разности 45.5 KB
  Преобразуйте второе выражение используя распределительное свойство умножения. Для ответа на этот вопрос и для обоснования этого ответа учащиеся могут либо вычислить значения данных выражений либо воспользоваться распределительным свойством умножения. Всегда ли сумма и разность чисел кратных двум будут кратны двум А сумма и разность чисел кратных трем четырем пяти будут соответственно кратны трем четырем пяти Затем учитель предлагает учащимся обобщить наблюдаемое свойство: Сформулируйте гипотезу. Скажите с помощью...
23748. Урок Делимость суммы и разности 33.5 KB
  Сумма 50 и 11 не будет кратна 5 так как значением данной суммы является число 61 а оно не кратно 5 Что можно сказать о слагаемых 50 и 11 Слагаемое 50 делится на 5 а слагаемое 11 не делится. Если одно из двух чисел делится на некоторое число а другое не делится на это число то их сумма и разность не делятся на это число. Данные числа обозначим буквами a и b третье число буквой c Что нам известно Что одно из двух чисел делится на третье число а другое не делится Пусть например что a делится на c...