ESC Расширение процессора
Арифметический сопроцессор предоставляет расширение
системы команд МП 80386. Сопроцессор поддерживает высокоточные
вычисления как целочисленные, так и с плавающей точкой и, кроме того, содержит набор полезных констант, ускоряющих вычисления. Сопроцессор работает параллельно с центральным процессором, обеспечивая таким образом высокую производительность.
Команды сопроцессора включаются в общий поток команд, составляющих программу для МП 80386. Система выполняет команды сопроцессора в том порядке, в котором они появляются в потоке.
HLT Останов
Команда прекращает выполнение любых команд и переводит МП в состояние останова. Немаскируемые прерывания, операция запуска и разрешенные прерывания возобновляют работу процессора. Команда HLT обычно является последней командой в последовательности команд останова системы, например для сохранения состояния процесса после обнаружения сбоя питания.
IDIV Знаковое деление
Команда выполняет знаковое деление. Делимому, частному и остатку неявно назначаются определенные регистры, в то время как местонахождение делителя указывается явным образом. По форме делителя определяется, какие регистры должны использоваться. Если делитель равен нулю или частное слишком велико для регистра-приемника, возбуждается прерывание 0.
IMUL Знаковое целочисленное умножение
Команда выполняет операцию знакового целочисленного умножения. Команда имеет три варианта.
1. Однооперандная форма. Операнд может быть байтом, словом или двойным словом в памяти или регистре общего назначения. Команда использует содержимое регистров EAX и EDX в качестве операндов.
2. Двухоперандная форма. Один из операндов-источников может находиться в любом регистре общего назначения, в то время как другой может быть в регистре общего назначения или в памяти. Произведение размещается на месте операнда в регистре общего назначения.
3. Трехоперандная форма. Два операнда представляют собой источники и один приемник. Один из операндов-источников является непосредственным значением, записанным в команде. Второй может находиться в памяти или в любом регистре общего назначения. Произведение может быть записано в любой регистр общего назначения. Непосредственный операнд считается знаковым. Если он является байтом, процессор перед выполнением умножения автоматически расширяет его знак до размера второго операнда.
IN Ввод из порта
Команда вводит байт или слово из порта и записывает его в регистре (AL, AH, EAX). Порт указывается вторым операндом. Для доступа к порту его номер следует поместить в регистр DX и использовать команду IN с обозначением DX в качестве второго параметра.
INC Инкремент на 1.
Команда прибавляет 1 к операнду-приемнику, но в отличие от ADD не влияет на флаг CF.
INT Вызов процедуры обработки прерывания
Команда передает управление от одной ячейки программного сегмента на другую. Эти ячейки могут принадлежать одному программному сегменту или разным программным сегментам. Команда возбуждает программное прерывание, позволяющее пользователю передть управление из своей программы программе обработки прерываний.
Команда INTn активизирует программу обработки прерывания, соответствующую номеру, указанному в команде. Команда может определять прерывание любого типа. Заметьте, что прерывания
0..31 зарезервированы фирмой Intel. Возврат управления из программы обработки прерывания осуществляется командой IRET.
INTO Прерывание по переполнению
Команда при установленном флаге OF возбуждает прерывание 4, которое специально зарезервировано для этой цели. Флаг OF устанавливается рядом арифметических, логических и строковых команд.
IRET Возврат из прерывания
Команда возвращает управление прерванной процедуре. В отличие от команды RET IRET извлекает из стека значения флагов и помещает их в регистр флагов. Флаги записываются в стек в процессе реализации прерывания.
IRETD Возврат из прерывания в 32-разрядном режиме
JMP Переход
Команда передает управление из одной точки сегмента в другую. Точка перехода может быть в том же сегменте (ближний переход) или в другом сегменте (дальний переход). Команда безусловно передает управление в точку перехода и является, таким образом, однонаправленной.
Команды условных переходов:
JA/JNBE Выше, не ниже и не равно
JAE/JNB Выше или равно, не ниже
JB/JNAE Ниже, не выше и не равно
JBE/JNA Ниже или равно, не выше
JC Перенос
JE/JZ Равно, нуль
JNC Отсутствие переноса
JNE/JNZ Не равно, не нуль
JNP/JPO Отсутствие четности, нечетность
JP/JPE Четность
JG/JNLE Больше, не меньше и не равно
JGE/JNL Больше или равно, не меньше
JL/JNGE Меньше, не больше и не равно
JLE/JNG Меньше или равно, не больше
JNO Отсутствие переполнения
JNS Отсутствие знака
(положительно, включая нуль)
JO Переполнение
JS Знак (отрицательно)
LAHF Загрузка флагов в регистр AH
Хотя для изменения флагов CF и DF предусмотрены специальные команды, остальные флаги, используемые в прикладных программах, нельзя изменять непосредственно. Эта команда дает возможность программного изменения остальных битов флагов с помощью команд побитовых операций после пересылки флагов в стек или в регистр AH.
Команда копирует биты SF,ZF,AF,PF,CF соответственно в разряды 7,6,4,2,0 регистра AH.
LAR Загрузка байта прав доступа
Команда читает дескриптор сегмента и заносит биты дробности(23), свободный (20), присутствия (15), DPL (14), типа (9-11) и доступа (8) в 32-разрядный регистр, бит дробности и свободный бит не пересылаются.
LEA Загрузка исполнительного адреса
Команда пересылает по адресу приемника относительный адрес операнда-источника. Операнд-источник должен находиться в памяти. Операнд-приемник должен быть регистром общего назначения. Команда особенно полезна для инициализации регистров перед выполнением действий над начальными данными или команды XLAT.
LEAVE Выход из процедуры высокого уровня
Команда выполняет действия противоположные действию команды ENTER.
LGDT Загрузка регистра таблицы глобальных дескрипторов
LIDT Загрузка регистра таблицы
Команда оповещает аппратные средства о точке перехода в случае прерываний.
LGS Загрузка полного указателя
LSS Загрузка указателя с использованием регистра SS
LDS Загрузка указателя с использованием регистра DS
LES Загрузка указателя с использованием регистра ES
LFS Загрузка указателя с использованием регистра FS
Команды указателей данных загружают указатель, состоящий из селектора сегмента и относительного адреса, в регистр сегмента и регистр общего назначения.
LLDT Загрузка регистра локальных дескрипторов
Таблица локальных дескрипторов загружается, когда задача или главная подсистема получает или восстанавливает контроль над системой.
LWSW Загрузка слова состояния машины
Команда загружает в регистр CR0 слово сотояния машины. Команду можно использовать для переключения в защищенный режим.
LOCK Префикс установки сигнала LOCK#
Сигнал LOCK# захватывает общую память, так что МП получает ее в свое исключительное пользование на время выполнения следующей за LOCK команды.
LODS Загрузка строкового операнда
LODSB Загрузка байта
LODSW Загрузка слова
LODSD Загрузка двойного слова
Эти команды обрабатывают не логические или арифметические переменные, а строки. Они воздействуют на один элемент строки, который может быть байтом, словом или двойным словом.
LOOP Циклическое выполнение, пока счетчик ECX не нуль
LOOPE Цикл, пока равно
LOOPZ Цикл, пока нуль
LOOPNE Цикл, пока не равно
LOOPNZ Цикл, пока не нуль
Команды обеспечивают условный переход для циклического выполнения участка программы. Число шагов определяется значением, занесенным в регистр ECX. Все разновидности команды автоматически выполняют декремент ECX и останавливают цикл, если ECX=0.
LTR Загрузка регистра задачи
Первый операнд команды LTR определяет регистр-источник или ячейку памяти, содержащие информацию для регистра задачи. Команда загружает эту информацию в регистр задачи.
MOV Пересылка в/из специальных регистров
Команда используется для загрузки и выгрузки специальных регистров и регистров общего назначения.
MOVS Пересылка данных из строки в строку
MOVSB Пересылка байта строки
MOVSW Пересылка слова строки
MOVSD Пересылка двойного слова строки
Эти команды используются для работы со строками, а не логическими или арифметическими величинами.
MOVZX Пересылка с расширением нуля
Команда расширяет 8-разрядную величину до 16-разрядной и 8- или 16-разрядную величину до 32-разрядной заполнением старших разрядов нулями.
MUL Целочисленное беззнаковое умножение содержимого регистров AL или AX
Команда перемножает операнд-источник и содержимое аккумулятора и возвращает результат удвоенной длины.
NEG Изменение знака, дополнение до 2
Команда выполняет вычитание знакового целочисленного операнда из нуля.
NOP Холостая команда
Команда занимает в памяти только 1 байт. Она действует только на указатель команд EIP. Команда NOP полезна при "выравнивании" адресов переходов.
OR Логическое ВКЛЮЧАЮЩЕЕ ИЛИ
Команда сравнивает два операнда и вычисляет следующее: если соответствующие биты в операндах равны 0, результат 0; в противном случае результат 1.
OUT Вывод в порт
Команда пересылает данные из регистра в порт вывода. Операнд-источник находится в регистре AL,AX,EAX. Номер порта определяется первым операндом. Для вывода данных в любой порт от 0 до 65535 номер порта помещается в регистр DX.
OUTS Вывод строки в порт
OUTSB Вывод байта
OUTSW Вывод слова
OUTSD Вывод двойного слова