курсовые,контрольные,дипломы,рефераты
Новосибирский Государственный Технический Университет
ОПЕРАЦИОННЫЕ СИСТЕМЫ
ЧАСТЬ 1. ОПЕРАЦИОННАЯ СИСТЕМА MS-DOS
Методические указания
к лабораторным работам для студентов 2 и 3 курса
Факультета АВТФ (специальность 2202)
дневного и заочного отделения
Новосибирск
1997
Составили: к.т.н., доц. В.Г. Качальский
ст.преп. Е.Н. Павенко
Рецензенты: к.т.н., доц. В.А. Астапчук
Работа подготовлена кафедрой автоматизированных систем управления
Способы обращения к ОС MS-DOS
Программы, составленные на языке С, обращаются к прерываниям MS-DOS с помощью таких функций как intdos, int86, intdosx и т.д.
Для передачи параметров используются структуры REGS, WORDREGS, BYTEREGS, SREGS, описанные в файле dos.h. Программа записывает параметры в поля структуры, соответствующие регистрам процессора, а затем вызывает одну из перечисленных выше функций, передавая ей адрес структуры. После выполнения прерывания результат записывается в эту же или другую структуру. Например:
union REGS inregs, outregs;
struct SREGS segregs;
......
inregs.h.ah. = 0x3a;
segregs.ds = FP_SEG(dir_name);
inregs.x.dx = FP_OFF(dir_name);
intdosx(&inregs, &outregs, &segregs);
.....
В этом фрагменте кода вызывается функция 3Ah прерывания INT 21h, для чего используется функция intdosx, которая входит в стандартную библиотеку системы разработки С++. Номер функции записывается в поле h.ah объединения inregs, параметры функции (передаваемые через регистры DS:DX) - соответственно поле ds структуры segregs и в поле x.dx объединения inregs. Функция intdosx записывает содержимое регистров процессора поле выполнения программного прерывания в объединение outregs.
Объединение REGS определено в файле dos.h следующим образом:
UNION REGS
{
struct WORDREGS x;
struct BYTEREGS h;
};
В нем имеется две структуры - WORDREGS и BYTEREGS.
Первая из этих структур предназначена для работы с 16-зфззядными регистрами. Она определена так:
struct WORDREGS
{
unsigned int ax, bx, cx, dx, si. di, cflag, flags;
};
В этой структуре поля ax, bx, cx, dx, si, di соответствуют одноименным регистрам центрального процессора. Значение флага переноса записывается в переменную cflag, поле flags предназначено для остальных флагов процессора.
С помощью структуры BYTEREGS можно задавать и определять содержимое 8-разрядных регистров процессора:
struct BYTEREGS
{
unsigned char al, ah, bl, bh, cl, ch, dl, dh;
};
Для работы с сегментными регистрами предназначена структура SREGS, определенная следующим образом:
struct SREGS
{
unsigned int es;
unsigned int cs;
unsigned int ss,
unsigned int ds;
};
Для использования перечисленных выше структур программа должна одержать следующую строку:
#include
Поле вызова программного прерывания программа должна проверить флаг переноса, который сохраняется в поле cflag. Проверка поля cflag может быть выполнена, например, следующим образом:
union REGS inregs, outregs;
.....
intdos(&inregs,&outregs);
if(outregs.x.cflags != 0) error();
......
Код ошибки при этом записывается в переменную outregs.x.ax.
Лабораторная работа № 1
Исследование логической структуры диска в MS-DOS
Цель работы
Изучение логической структуры диска ОС MS-DOS
Общие положения
Диски ОС MS-DOS организованы по довольно жесткой схеме. Каждый диск включает в себя помимо области файлов еще несколько управляющих областей фиксированного размера. Первый сектор логического диска (сектор 1, дорожка 0, головка 0) содержит загрузочную запись - программу начальной загрузки ОС. Кроме программы начальной загрузки в загрузочной записи находятся параметры, описывающие характеристики данного логического диска. Эти параметры располагаются в самом начале сектора.
Формат загрузочной записи
Смещение байт |
Размер байт |
Содержание |
0 |
3 |
Команда JMP xxxxx - ближний переход на программу начальной загрузки |
3 |
8 |
Название фирмы-изготовителя ОС и версия. |
11 |
25 |
Расширенный блок параметров BIOS |
36 |
1 |
Физический номер устройства (0 - НГМД, 80h - НМД) |
37 |
1 |
Зарезервировано |
38 |
1 |
Символ «(« - признак расширенной загрузочной записи |
39 |
4 |
Серийный номер диска , создается во время форматирования |
43 |
11 |
Метка диска |
54 |
8 |
Содержит запись ‘FAT12 ‘ или ‘FAT16 ‘, которая идентифицирует формат таблицы размещения файлов (FAT) |
Со смещением 11 располагается расширенный блок параметров BIOS. Этот блок содержит некоторые характеристики логического диска.
Смещение байт |
Размер байт |
Имя поля |
Описание |
0 |
2 |
set_siz |
Количество байт в одном секторе диска |
2 |
1 |
clustsiz |
Количество секторов в одном кластере |
3 |
2 |
res_sect |
Количество зарезервированных секторов |
5 |
1 |
fat_cnt |
Количество FAT |
6 |
2 |
root_siz |
Максимальное количество дескрипторов файлов в корневом каталоге диска |
8 |
2 |
tot_sect |
Общее количество секторов на носителе данных |
10 |
1 |
media |
Байт-описатель среды носителя данных |
11 |
2 |
fat_size |
Количество секторов, занимаемых одной копией FAT |
13 |
2 |
sectors |
Количество секторов на дорожке |
15 |
2 |
heads |
Количество магнитных головок |
17 |
2 |
hidden_1 |
Количество скрытых секторов, для носителя размером < 32 Мб |
19 |
2 |
hidden_2 |
Количество скрытых секторов, для носителя размером > 32 Мб |
21 |
4 |
tot_sect |
Общее количество секторов на логическом диске, превышающим по размеру 32 Мб |
Байт описания среды - media может служит для идентификации носителя данных, например, он содержит значение F8h для жесткого диска любой емкости или значение F0h для диска размером 3,5 дюйма и емкостью 1440 Кб.
Прерывания для работы с логическим диском
Для работы с логическим диском (или дискетой) на уровне логических номеров секторов MS-DOS программам два прерывания - INT 25h (чтение сектора по его логическому номеру) и INT 26h (запись сектора по его логическому номеру). Для вызова этих прерываний используется следующий формат:
INT 25h - чтение сектора по его логическому адресу
На входе:
AL - Адрес НГМД или НМД (0-A:, 1-B:, и т.д.
CX - количество секторов, которые нужно прочитать
DX - логический номер начального сектора
DS:BX - адрес буфера для чтения
На выходе:
AH - код ошибки при неуспешном завершении операции
CF 1, если произошла ошибка;
0, если ошибки нет.
INT 26h - запись сектора по его логическому номеру
На входе:
AL - Адрес НГМД или НМД (0-A:, 1-B:, и т.д.
CX - количество секторов, которые нужно записать
DX - логический номер начального сектора
DS:BX - адрес буфера, содержащего данные
На выходе:
AH - код ошибки при неуспешном завершении операции
CF 1, если произошла ошибка;
0, если ошибки нет.
В программах на языке С для работы с указанными прерываниями может быть использован следующий фрагмент программы:
...
union REGS reg;
struct SREGS segreg;
reg.x.ax. = drive;
reg.x.bx = FP_OFF (buff);
segreg.ds = FP_SEG (buff);
reg.x.x. = 1;
reg.x.dx. = 0;
int86x(0x25, ®, ®, &segreg);
...
где buff - адрес буфера, в который считывается (записывается) логический сектор.
Замечание: после вызова прерывания должна обязательно следовать команда:
asm POP AX
Порядок выполнения лабораторной работы
1. Изучить логическую структуру дика MS-DOS.
2. Составить программу, читающую загрузочный сектор диска и выводящую на экран основные характеристики диска из BPB.
Содержание отчета
1. Цель работы.
2. Описание логической структуры диска MS-DOS.
3. Характеристики логического диска, полученные в результате работы составленной в ходе выполнения лабораторной работы программы.
Контрольные вопросы
1. Принципы записи информации на дисковые накопители.
2. Методы разделения дискового пространства между пользователями («справочник файлов»).
3. Методы распределения дискового пространства для файлов.
4. Логическая структура диска MS-DOS.
Литература
1. Г. Дейтел. Введение в операционные системы. Том 1,2. М: Мир, 1987.
2. А. В. Фролов, Г.В. Фролов MS-DOS для программиста. Библиотека системного программиста, Том 19, М:ДИАЛОГ-МИФИ, 1995.
Лабораторная работа №2
Исследование таблицы размещения файлов (FAT - таблицы) ОС MS-DOS
Цель работы
Изучить структуру и назначение FAT - таблицы ОС MS-DOS
Общие положения
Сразу вслед за загрузочным сектором на логическом диске находятся секторы, содержащие таблицу размещения файлов (FAT - таблица). FAT - таблица используется для хранения информации о распределении файлам секторов диска. Сектор диска - это часть диска, в которой обычно хранится 512 байт информации, относящейся к файлу. Весь диск разбивается операционной системой на участки одинакового размера, называемые кластерами. Кластер может одержать несколько смежных секторов. Для каждого кластера в FAT - таблице есть своя индивидуальная ячейка, в которой хранится информация об использовании кластера, т.е. FAT - таблица - это массив, содержащий информацию о кластерах. Размер этого массива равен общему количеству кластеров на логическом диске.
В FAT - таблице находятся списки кластеров, распределенных файлам.. Таким образом, если файл занимает несколько кластеров на диске, то эти кластеры связаны в список. При этом элементы FAT - таблицы содержат номера следующих используемых данным файлом кластеров. Конец списка отмечен в таблице специальным значением. Номер первого кластера, распределенного файлу, хранится в элементе каталога, описывающего данный файл. Пример использования FAT - таблицы приведен на рис.1.
Корневой каталог диска C:
Имя файла |
... |
Номер первого кластера, распределенного файлу |
autoexec.bat |
... |
11 |
config.sys |
... |
12 |
... |
... |
... |
FAT - таблица
... |
17 |
13 |
FFFF |
00 |
00 |
00 |
18 |
FFFF |
00 |
..... |
кластер |
11 |
12 |
13 |
14 |
15 |
16 |
17 |
18 |
19 |
Рис 1. Пример распределения кластеров для файлов autoexec.bat b config.sys
FAT - таблица может иметь 12- или 16-битовый формат. При этом в таблице для хранения информации об одном кластере диска используется соответственно 12 или 16 бит. 12-битовый формат удобен для дискет с небольшим количеством секторов - вся FAT - таблица помещается в одном секторе.
Первый байт FAT - таблицы называется описателем среды. Он имеет такое же значение , как и байт - описатель среды, находящийся в загрузочном секторе дика.
Следующие 5 байт для 12-битового формата или 7 байт для 16-битового формата всегда содержат значение 0FFh.
Остальная часть FAT - таблицы состоит из 12- или 16-битовых ячеек. Каждая ячейка соответствует одному кластеру диска. Эти ячейки могут содержать следующие значения:
FAT12 |
FAT16 |
Тип кластера |
000h |
0000h |
Свободный кластер |
FF0h-FF6h |
FFF0h-FFF6h |
Зарезервированный кластер |
FF7h |
FFF7h |
Плохой кластер |
FF8h-FFFh |
FFF8h-FFFFh |
Последний кластер в списке |
002h - FEFh |
0002h-FFEFh |
Номер следующего кластера в списке |
Обычно FAT - таблица располагается после загрузочного сектора . Для точного определения начального сектора FAT - таблицы следует прочитать в память загрузочный сектор и проанализировать содержимое блока параметров BIOS. В поле ressect записано количество зарезервированных секторов, которые располагаются перед FAT. Поле fat_size содержит размер FAT в секторах. Кроме того, следует учитывать, что на диске может находиться несколько копий FAT. Операционная система использует только первую копию FAT, но обновляет вторую. Вторая копия нужна для утилит восстановления содержимого диска. Количество копий FAT находится в поле fat_cnt загрузочного сектора.
Общая схема использования FAT такова:
· Получаем номер первого кластера файла, для которого необходимо определить его расположение на диске.
· Используем номер первого кластера как индекс в FAT - таблице для извлечения номера следующего кластера.
· Повторяем предыдущую процедуру до тех пор, пока извлеченное из FAT - таблицы значение не будет соответствовать концу файла.
Процедура извлечения номера кластера из FAT - таблицы зависит от формата FAT - таблицы.
16-битовую FAT - таблицу можно представить как массив 16-битовых чисел. Для определения номера следующего кластера надо просто извлечь 16-битовое значение из FAT - таблицы, использовав в качестве индекса номер предыдущего кластера.
Для 12-битовой FAT - таблицы процедура значительно сложнее. Необходимо выполнить следующие действия:
· умножить номер начального кластера на 3;
· разделить результат на 2;
· прочитать 16-битовое слово из FAT - таблицы, используя в качестве смещения значение, полученное после деления на 2;
· если номер начального кластера четный, на выбранное из FAT слово нужно наложить маску 0FFFh, оставив младшие 12 бит; если же номер начального кластера нечетный, выбранное из FAT значение необходимо сдвинуть вправо на 4 бита, оставив старшие 12 бит;
· полученный результат - это номер следующего кластера в цепочке.
Используя описанную выше процедуру можно определить для каждого файла цепочку занимаемых им кластеров.
Для нахождения первого кластера, распределенного файлу необходимо прочитать информацию из каталога., в котором содержится данный файл. Для этого необходимо сначала прочитать корневой каталог, а затем все подкаталоги из пути каталогов к данному файлу.
Корневой каталог находится сразу за последней копией FAT. Перед корневым каталогом находится один загрузочный сектор и fat_cnt*fat_size секторов FAT - таблицы. Размер корневого каталога можно определить исходя из значения поля root_size. При форматировании дика в это поле записывается максимальное количество файлов и каталогов, которые могут быть в корневом каталоге. Для каждого элемента в каталоге отводится 32 байта, поэтому корневой каталог имеет длину 32*root_size байт. Корневой каталог занимает непрерывную область фиксированного размера.
Любой каталог одержит 32-байтовыу дескрипторы, описывающие файлы и другие каталоги. Дескриптор имеет следующий формат:
Смещение байт |
Размер байт |
Содержание |
0 |
8 |
Имя файла или каталога, выровненное на левую границу и дополненное пробелами |
8 |
3 |
Расширение имени файла, выровненное на левую границу и дополненное пробелами |
11 |
1 |
Байт атрибутов файла |
12 |
10 |
Зарезервировано |
22 |
2 |
Время создания файла или время его последней модификации |
24 |
2 |
Дата создания файла или дата его последней модификации |
26 |
2 |
Номер первого кластера, распределенного файлу |
28 |
4 |
Размер файла в байтах |
В любом каталоге, кроме корневого, два первых дескриптора имеют специальное назначение. Первый дескриптор содержит в поле имени строку
«. ». Этот дескриптор указывает на одержащий его каталог, т.е. каталог имеет ссылку на самого себя.
Второй специальный дескриптор содержит в поле имени строку «.. ». Это дескриптор указывает на каталог более высокого уровня
Если в поле номера первого занимаемого кластера для дескриптора с именем «.. » находится нулевое значение, это означает, что данный каталог содержится в корневом каталоге.
Порядок выполнения работы
1. Изучить структуру FAT - таблицы и структуру корневого каталога логического дика ОС MS-DOS.
2. Расширить возможности программы из лабораторной работы № 1 таким образом, чтобы она выводила на экран номера всех кластеров, распределенных файлу, указанному преподавателем.
Содержание отчета
1. Цель работы.
2. Структура FAT - таблицы и дескриптора файлов и каталогов.
3. Результаты выполнения лабораторной работы.
Контрольные вопросы
1. Распределение дискового пространства с использованием цепочки блоков.
2. Распределение дискового пространства с использованием цепочки индексных блоков.
3. Распределение дискового пространства с использование таблиц отображения файлов.
4. Организация каталогов ОС MS-DOS.
Литература
1. Г. Дейтел. Введение в операционные системы. Том 1,2. М: Мир, 1987.
2. А. В. Фролов, Г.В. Фролов MS-DOS для программиста. Библиотека системного программиста, Том 19, М:ДИАЛОГ-МИФИ, 1995.
Лабораторная работа № 3
Исследование векторной таблицы связи MS-DOS
Цель работы
Изучить назначение и структуру векторной таблицы связи основных управляющих блоков ОС MS-DOS.
Общие положения
Операционная система MS-DOS содержит векторную таблицу связи основных управляющих блоков. Зная адрес этой таблицы, можно получить доступ к внутренним структурам данных операционной системы.
Основные структуры данных ОС МS-DOS организованы в виде дерева. Корнем этого дерева является векторная таблица связи, которая содержит адреса всех остальных структур: список блоков управления памятью MCB, список блоков управления устройствами MS-DOS, таблицу файлов, дисковые буферы и т.д. Информация, содержащаяся в векторной таблице связи открывает доступ практически ко всем внутренним структурам данных операционной системы.
Поля векторной таблицы связи
Смещение байт |
Размер байт |
Имя поля |
Описание |
-2 |
2 |
mcb_seg |
Сегмент первого блока памяти |
0 |
4 |
dev_cb |
Указатель на первый блок управления устройствами |
4 |
4 |
file_tab |
Указатель на таблицу файлов MS-DOS |
8 |
4 |
clocr_dr |
Указатель на драйвер CLOCK$ |
12 |
4 |
con_dr |
Указатель на драйвер CON |
16 |
2 |
max_btbl |
Максимальный размер блока (в байтах) для устройств, выполняющих передачу данных отдельными блоками |
18 |
4 |
disk_buf |
Указатель на структуру, описывающую дисковые буферы |
22 |
4 |
drv_info |
Указатель на массив информации об устройствах |
26 |
4 |
fcb_tabl |
Указатель на таблицу FCB |
30 |
2 |
fcb_size |
Размер таблицы FCB |
32 |
1 |
num_bdev |
Число устройств, выполняющих передачу отдельными блоками |
33 |
1 |
lastdriv |
Значение LASTDRIVE в файле config.sys |
34 |
? |
null_dr |
Начало драйвера NUL. Этот драйвер всегда первый в списке драйверов MS-DOS |
Функция 52h возвращает адрес поля dev_cb. Для того чтобы получить адрес слова, содержащего сегмент первого блока памяти MCB, необходимо уменьшить значение смещения, полученного от функции на 2.
Поле mcb_seg содержит сегментную компоненту адреса первого блока MCB. Зная это значение можно проследить и изменить структуру блоков памяти.
В поле dev_cb векторной таблицы связи хранится указатель на список блоков управления дисковыми устройствами MS-DOS. Каждый такой блок содержит описание характеристик устройства, а также указатель на драйвер, обслуживающий устройство. Программа может использовать блок управления дисковыми устройствами для доступа к диску на низком уровне или для получения справочной информации об устройстве.
Поле file_tab содержит адрес таблицы файлов MS-DOS. В этой таблице для каждого открытого файла хранится разнообразная информация, такая, как количество назначенных файлу идентификаторов( т.е. сколько раз файл был открыт), режим использования файла, номер первого кластера диска, распределенного файлу и т.д. Эта информация может потребоваться для организации доступа к файлам на уровне кластеров, например в системах защиты файлов от несанкционированного доступа.
С помощью полей clock_dr и con_dr программа может получить доступ соответственно к драйверу CLOCK$ и драйверу консоли CON. Это может понадобиться для организации вызова драйвера непосредственно из программы.
Поле max_btbl содержит размер блока устройств, которые выполняют обмен данными отдельными блоками (для MS-DOS размер блока равен 512 байтам.
Поле drv_info содержит указатель на массив, в котором хранится информация о дисковых устройствах. В этом массиве можно найти текущий путь доступа для каждого диска, номер первого кластера диска, распределенного каталогу, и адрес соответствующего блока управления дискового устройства.
В поле fcb_tabl находится указатель на таблицу FCB. Размер этой таблицы записан в поле fcb_size и определяется параметром fcbs=xx, расположенном в файле cjnfig.sys.
Поле lastdriv содержит значение параметра lastdrive, расположенного в файле config.sys. Его можно использовать для определения максимального количества дисковых устройств в системе.
В поле num_bdev хранится количество действительно используемых дисковых устройств.
Поле nul_dr само по себе не содержит никакой полезной информации. Имеет значение лишь его адрес - в этом месте расположен самый первый в цепочке драйвер MS-DOS. Для получения адреса векторной таблицы связи можно воспользоваться следующей программой на языке С:
#include
#include
#include
typedef struct
{
unsigned mcb_seg;
void far *dev_cb;
void far *file_tab;
void far *clock_dr;
void far *con_dr;
unsigned max_btbl;
void far *disk_buf;
void far *drv_info;
void far *fcb_tabl;
unsigned fcb_size;
unsigntd char num_bdev;
unsigned char lastdriv;
}CVT;
typedef CVT far* LPCVT;
void main(void)
{
union REGS regs;
struct SREGS sregs;
LPCVT lpCVT;
// Получаем адрес векторной таблицы связи
resgs.h.ah = 0x52h;
indosx(®s, ®s, &sregs);
// Передвигаем указатель на поле mb_seg
lpCVT = (LPCVT)VK_FP(sregs.es, resg.x.bx - 2);
// Выводим адрес векторной таблицы связи
printf(« Адрес CVT: %Fp» (LPCVT)lpCVT);
getch();
}
Макрокоманды MR_FP, FP_SEG, FP_OFF описаны и файле dos.h. С помощью макрокоманды MK_FP можно конструировать дальний указатель из значения сегмента и смещения. Макрокоманды FP_SEG и FP_OFF можно выделить из дальнего указателя соответственно сегмент и смещение.
Формат блока MCB
Внутри блока MCB хранится длина описываемого данным МСВ фрагмента памяти. Следующий фрагмент начинается сразу за предыдущим. Все блоки управления памятью связаны в список.
Блоки MCB бывают двух типов M и Z. M - блоки - это промежуточные блоки. Блок типа Z является последним в списке блоков и может быть только один. Блок MCB имеет следующий формат:
Смещение байт |
Размер байт |
Имя поля |
Описание |
0 |
1 |
type |
Тип блока MCB (M или Z) |
1 |
2 |
owner |
Сегментная компонента адреса владельца блока |
3 |
2 |
size |
Число параграфов в этом блоке |
5 |
11 |
reserve |
Зарезервировано |
Параграф имеет размер 16 байт.
Для удобства работы с блоком MCB определим тип MCB:
typedef struct
{
unsigned char type;
unsigned owner;
unsigned size;
char reserve[11];
} MCB;
Порядок выполнения работы
1.Получить и вывести на экран адрес векторной таблицы связи и значения полей в векторной таблице связи.
2. Получить список всех MCB - блоков с указанием их типов, размеров и владельцев.
Содержание отчета
1. Цель работы.
2. Описание полей векторной таблицы связи.
3. Результаты выполнения лабораторной работы.
Контрольные вопросы
1. Распределение памяти в ОС MS-DOS.
2. Назначение и варианты использования векторной таблицы связи ОС MS-DOS.
3. Назначение и способы использования MCB - блоков
Литература
1. Г. Дейтел. Введение в операционные системы. Том 1,2. М: Мир, 1987.
2. А. В. Фролов, Г.В. Фролов MS-DOS для программиста. Библиотека системного программиста, Том 19, М:ДИАЛОГ-МИФИ, 1995.
Лабораторная работа № 4
Исследование системы обработки прерываний ОС MS-DOS
Цель работы
Изучение системы обработки прерываний ОС MS-DOS
Общие положения
Для обработки событий, происходящих асинхронно по отношению к выполнению программы, лучше всего подходит механизм прерываний. Прерывание можно рассматривать как некоторое событие в системе, требующее моментальной реакции. С прерыванием связывают число - номер прерывания.
Этот номер однозначно соответствует тому или иному событию. Система умеет распознавать прерывания и при их возникновении запускает процедуру, соответствующую номеру прерывания.
Прерывания могут быть синхронными или асинхронными. Синхронные прерывания (программные) вызываются самой программой с использованием команды INT. Программные прерывания удобно использовать для организации доступа к функциям операционной системы и другим разделяемым программам и данным. Аппаратные прерывания вызываются физическими устройствами. Эти прерывания информируют систему о событиях, связанных с работой устройств, например, завершение ввода, нажатие клавиши на клавиатуре или мыши и т.д.
Для того, чтобы связать адрес обработчика прерываний с номером прерывания, используется таблица векторов прерываний, занимающая первый килобайт оперативной памяти. Эта таблица находится в диапазоне адресов от 0000:0000 до 0000:03FFh и состоит из 256 элементов - дальних адресов обработчиков прерываний.
Элементы таблицы векторов прерываний называются векторами прерываний. В первом слове вектора прерываний записывается компонента смещения обработчика прерывания, а во втором - сегментная компонента.
Для программиста, использующего язык СИ, таблицу векторов прерываний можно описать следующим образом:
void (far* interrupt_table[256])();
Для изменения обработки некоторых прерываний программа должна установить векторы нужных прерываний на свой обработчик. Это можно сделать, изменив содержимое соответствующего элемента таблицы векторов прерываний. Перед завершением работы необходимо восстановить содержимое измененных векторов.
Если нужно добавить какие-либо действия к тем, что выполняет стандартный обработчик прерываний, то можно организовать цепочку обработчиков прерываний. В библиотеке СИ имеется функция для организации цепочки прерывания с именем _chain_intr.
Для описания функции, выполняющей обработку прерывания, следует использовать ключевое слово interrupt. Такая функция завершается командой возврата из прерывания IRET. Для нее автоматически генерируются команды сохранения регистров на входе и их восстановления при выходе из обработчика прерывания.
void interrupt far int_funct(...)
{
// Тело обработчика прерывания
}
Ключевое слово interrupt используется также для описания переменных, предназначенных для хранения векторов прерываний:
void interrupt (far *oldvect)(...);
Для установки своего обработчика прерываний используется функция _dos_setvect. Эта функция имеет два параметра - номер прерывания и указатель на новую функцию обработки прерывания:
_dos_setvect(0x16, my_key_intr);
В этом примере для прерывания номер 16h устанавливается новый обработчик прерывания my_key_intr.
Для того чтобы узнать адрес старого обработчика прерывания по его номеру используется функция _dos_getvect, которая принимает в качестве параметра номер прерывания и возвращает указатель на соответствующий номеру обработчик:
old_vector = _dos_getvector(0x16);
Следующая программа иллюстрирует применение перечисленных выше функций для создания цепочки обработчиков прерываний. Эта программа встраивает собственный обработчик прерываний от таймера, который будет вызываться 18,2 раза в секунду. Встраиваемый обработчик прерываний подсчитывает прерывания от таймера, и, если значение соответствующего счетчика кратно 20, громкоговоритель компьютера издает звуковой сигнал.
В конце работы новый обработчик прерываний вызывает старый обработчик прерываний.
После установки нового обработчика прерывания таймера основная программа ждет, когда пользователь нажмет любую клавишу, затем она восстанавливает старое содержимое вектора прерывания.
#include
#include
#include
void main(void);
void interrupt far timer(...);
void interrupt (far *oldvect)(...);
// Переменная для подсчета прерываний таймера
volatile long ticks;
void main(void);
{
// Сбрасываем счетчик
ticks = 0;
// Запоминаем адрес старого обработчика прерываний
oldvect = dos_getvect (0x1c):
// Устанавливаем новый обработчик прерываний
dos_setvect (0x1c, timer);
printf ("nТаймер установлен. Нажмите любую клавишу...n");
getch();
// Восстанавливаем старый обработчик прерываний
dos_setvect (0x1c, oldvect);
}
void interrapt far timer (...)
{
// Увеличиваем счетчик прерываний таймера
ticks++;
// Если значение счетчика кратно 20, выдаем сигнал на громкоговоритель
// компьютера
if (ticks % 20) == 0 )
{
asm mov bx,0
asm mov ax,0E07h
asm int 10h
}
// Вызываем старый обработчик прерываний
_chain_intr (oldvect);
}
Порядок выполнения работы
1. Отладить программу, приведенную выше в описании лабораторной работы.
2. Составить и отладить программу, подсчитывающую число обращений к услугам операционной системы через прерывание INT 21h. Число обращений подсчитать для программы, составленной на лабораторной работе №1, №2 или №3.
Содержание отчета
1. Цель работы.
2. Список наиболее часто используемых векторов прерываний
3. Результаты работы программы.
Контрольные вопросы
1. Принципы обработки прерываний в современных ОС.
2. Особенности обработки программных прерываний.
3. Особенности обработки аппаратных прерываний
4. Общая схема создания и подключения собственного обработчика прерываний.
Литература
1. Г. Дейтел. Введение в операционные системы. Том 1,2. М: Мир, 1987.
2. А. В. Фролов, Г.В. Фролов MS-DOS для программиста. Библиотека системного программиста, Том 19, М:ДИАЛОГ-МИФИ, 1995.
Новосибирский Государственный Технический Университет ОПЕРАЦИОННЫЕ СИСТЕМЫ ЧАСТЬ 1. ОПЕРАЦИОННАЯ СИСТЕМА MS-DOS Методические указания к лабораторным работам для студентов 2 и 3 курса Факультета АВТФ (спец
1С-бухгалтерия с рисунками
Памятка: Norton, Lexicon, DOS
Разработка САПР вакуумных систем на начальных этапах проектирования
Вспомогательные программы (утилиты)
Интернет – червь I LOVE YOU (LOVE LETTER FOR YOU). Принцип работы. Меры безопасности для защиты от заражения и предотвращения деструктивных действий
Компьютерный файлово-загрузочный полиморфный стелс-вирус ONEHALF 3544, особенности алгоритма и методы борьбы с ним
Операционные системы (шпаргалка)
Полный обзор Windows 98
Программирование на языке Турбо Паскаль
Руководство по программированию на HTML
Copyright (c) 2024 Stud-Baza.ru Рефераты, контрольные, курсовые, дипломные работы.