Добавил:
Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
АВМиС - Готовые шпоры.doc
Скачиваний:
145
Добавлен:
15.09.2014
Размер:
1.75 Mб
Скачать

27. Системные регистры.

РЕГИСТР ФЛАГОВ

  • AC:

флаг проверки выравнивания. При обращении к невыровненному адресу (например, к нечетному при установленном выравнивании на границе слова) генерируется исключение. Только в 486 и выше.

  • VM:

virtual mode - флаг виртуального режима процессора. Установка флага в 1 переводит процессор в этот режим.

  • RF:

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

  • NT:

флаг вложенности задачи. Используется для вызовов вложенных задач и возврату к прерванной задаче (обычно при обработке прерываний).

  • IOPL:

содержит уровень привилегий ввода-вывода

OF:

Overflow Flag - флаг переполнения (выхода из старшего разряда в знак) результата на выходе АЛУ при выполнении арифметических операций. Соответствует переходу единицы в старший разряд из предыдущего.

DF:

Direction Flag - флаг направления цепочечных команд (stos, movs, lods и т.п.). При единице регистры DI и SI уменьшаются на единицу, иначе - увеличиваются, что дает возможность получать предыдущий или последующий байт, соответственно.

IF:

Interrupt Flag - флаг запрета прерываний. Если флаг = 1, то процессор не реагирует на поступающие аппаратные прерывания (IRQ), кроме немаскируемого (NMI), и они блокируются.

TF:

Trace Flag - флаг трассировки. В этом режиме процессор вызывает прерывание 04 после выполнения каждой инструкции.

SF:

Sign Flag - флаг отрицательного результата на выходе АЛУ при выполнении арифметических операций и операций сравнения (как признак “меньше”). Соответствует единице в старшем разряде.

ZF:

Zero Flag - флаг нулевого результата на выходе АЛУ при выполнении арифметических операций и операций сравнения (как признак равенства).

AF:

Auxiliary Flag - флаг переноса из старшей тетрады при выполнении арифметических операций с двоично-десятичными упакованными числами (BCD). Эта тема в данном справочнике не рассматривается.

PF:

Parity Flag - флаг четного числа единиц на выходе АЛУ (обычно - в AX) при выполнении арифметических операций.

CF:

Carry Flag - флаг переноса из старшего разряда (обычно - AX) при выполнении арифметических операций, а также - флаг ошибки обработчиках прерываний.

Регистры управления памятью

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

GDTR: 6-байтный регистр, в котором содержатся 32-битный линейный адрес начала таблицы глобальных дескрипторов (GDT) и ее 16-битный размер (минус 1). Каждый раз, когда происходит обращение к памяти, по селектору, находящемуся в сегментном регистре, определяется дескриптор из таблицы GDT или LDT, в котором записан адрес начала сегмента и другая информация (см. главу 6.1).

IDTR: 6-байтный регистр, в котором содержатся 32-битный линейный адрес начала таблицы глобальных дескрипторов обработчиков прерываний (IDT) и ее 16-битный размер (минус 1). Каждый раз, когда происходит прерывание или исключение, процессор передает управление на обработчик, описываемый дескриптором из IDT с соответствующим номером.

LDTR: 10-байтный регистр, в котором содержатся 16-битный селектор для GDT и весь 8-байтный дескриптор из GDT, описывающий текущую таблицу локальных дескрипторов (LDT).

TR: 10-байтный регистр, в котором содержатся 16-битный селектор для GDT и весь 8-байтный дескриптор из GDT, описывающий TSS текущей задачи.