- •Оглавление
- •Общие сведения
- •Среда выполнения программ
- •Представление информации
- •Двоичные числа без знака
- •Двоичные числа со знаком
- •Символьная информация
- •Двоично-десятичные числа
- •Адресация памяти
- •Физическая память
- •Сегментация
- •Регистры микропроцессора
- •Регистры общего назначения
- •Сегментные регистры
- •Регистр флагов
- •15 0
- •Указатель инструкции
- •Выполнение инструкций
- •Адресация операндов
- •Регистровые операнды
- •Операнды в памяти
- •Непосредственные операнды
- •Адреса переходов
- •Формат кода команды
- •Префиксы
- •Код операции
- •Байт ModRegR/m
- •7 6 5 4 3 2 1 0
- •Отклонение
- •Непосредственный операнд
- •Инициализация процессора
- •Прерывания
- •Источники и причины прерываний
- •Внешние прерывания
- •Немаскируемые прерывания
- •Маскируемые прерывания
- •Исключения
- •Прерывание по ошибке деления
- •Прерывание по точке останова
- •Прерывание по переполнению
- •Прерывание по трассировке
- •Программные прерывания
- •Обработка прерываний
- •Действия микропроцессора по обработке прерывания
- •Приоритет прерываний
- •Идентификация источников прерываний
- •Система команд
- •Машинные инструкции
- •Aaa– коррекция сложения двоично-десятичных распакованных чисел
- •Замечания по программированию
- •Aad– коррекция деления двоично-десятичных распакованных чисел
- •Замечания по программированию
- •Aam– коррекция умножения двоично-десятичных распакованных чисел
- •Замечания по программированию
- •Aas– коррекция вычитания двоично-десятичных распакованных чисел
- •Add– двоичное сложение без переноса
- •Замечания по программированию
- •Adc– двоичное сложение с переносом
- •Замечания по программированию
- •And– логическое и
- •Call– вызов процедуры
- •Cbw– преобразование байта в слово
- •Cmps– сравнение строк
- •Замечания по программированию
- •Cwd– преобразование слово в двойное слово
- •Daa– коррекция сложения двоично-десятичных упакованных чисел
- •Das– коррекция вычитания двоично-десятичных упакованных чисел
- •Dec– декремент
- •Замечания по программированию
- •Div– деление беззнаковое
- •Esc– команда сопроцессора
- •Замечания по программированию
- •Hlt– останов процессора
- •Idiv– деление знаковое
- •Imul– умножение знаковое
- •In– ввод информации из порта ввода-вывода
- •Inc– инкремент
- •Замечания по программированию
- •Jmp– безусловный переход
- •Lahf– загрузка флагов состояния в регистрAh
- •Lds– загрузка дальнего указателя для сегмента данных
- •Lea– загрузка эффективного адреса
- •Замечания по программированию
- •Les– загрузка дальнего указателя для дополнительного сегмента данных
- •Lods– загрузка строки
- •Замечания по программированию
- •Loop/looPcc– цикл по счётчику в регистреCx
- •Mov– пересылка
- •Movs– пересылка строк
- •Замечания по программированию
- •Mul– умножение беззнаковое
- •Neg– смена знака
- •Out– вывод информации из порта ввода-вывода
- •Pop– извлечение информации из стека
- •Замечания по программированию
- •Popf– загрузка регистра флагов из стека
- •Push– занесение информации в стек
- •Замечания по программированию
- •Pushf– запись регистра флагов в стек
- •Rcl– циклический сдвиг влево через флажок переноса
- •Замечания по программированию
- •Rcr– циклический сдвиг вправо через флажок переноса
- •Замечания по программированию
- •Ret– возврат из процедуры
- •Замечания по программированию
- •Rol– циклический сдвиг влево
- •Замечания по программированию
- •Ror– циклический сдвиг вправо
- •Замечания по программированию
- •Sahf– загрузкаAHв регистр флагов
- •Sal – арифметический сдвиг влево
- •Замечания по программированию
- •Sar– арифметический сдвиг вправо
- •Замечания по программированию
- •Sbb– двоичное вычитание с заёмом
- •Замечания по программированию
- •Scas– сканирование строки
- •Замечания по программированию
- •Shl – логический сдвиг влево
- •Замечания по программированию
- •Shr– логический сдвиг вправо
- •0 ─►│ Операнд ├──►│cf│
- •Замечания по программированию
- •Замечания по программированию
- •Sub– двоичное вычитание
- •Замечания по программированию
- •Test– логическое сравнение
- •Wait– ожидание сопроцессора
- •Замечания по программированию
- •Xchg– обмен информацией
- •Xlatb– табличная перекодировка
- •Xor– исключающее или
- •Префиксы машинных инструкций
- •Ds:/es:/ss:/cs:– префиксы замены сегмента
- •Lock– блокировка шины
- •Rep/rePcc– повторение строковой операции
- •Приложение 1. Коды операций
- •Приложение 2. Время выполнения команд
Das– коррекция вычитания двоично-десятичных упакованных чисел
2F |
DAS |
двоично-десятичная коррекция вычитания AL |
Описание.Эта команда выполняет коррекцию результата вычитания двух двоично-кодированных десятичных чисел инструкциейSUBилиSBB.
Если при выполнении предшествовавшей операции вычитания в младшем полубайте регистра ALполучено значение, превышающее 9, или произошёл заём в 3-ий разряд (был установлен флажокAF), то значение младшего полубайта регистраALуменьшается на 6, флажокAFостаётся равным 1, а флажокCFустанавливается, если при вычитании 6 возник заём в 3-ий разряд (если заёма не было, значение флажкаCFне изменяется, т.е. остаётся таким же, каким оно было до выполнения инструкцииDAA). Если же содержимое младшего полубайта регистраALне превышает 9, а флажокAFсброшен, никаких действий с младшим полубайтом не выполняется.
Затем проверяется содержимое старшего полубайта регистра AL. Если его значение больше 9 либо если установлен флажокCF(независимо от того, был ли он установлен при выполнении команды сложения или при уменьшении младшего полубайта на 6 в процессе выполнения инструкцииDAS), то это значение уменьшается на 6 и устанавливается флажокCF. Если же значение старшего полубайта не превышает 9, а флажокCFсброшен, никаких действий со старшим полубайтом не выполняется.
ФлажкиAFиCFустанавливаются в соответствии с результатом операции (см. выше).
Флажки SF,ZFиPFустанавливаются по обычным правилам в соответствии с полученным результатом.
Значение флажка OFне определено.
Dec– декремент
48+rw |
DEC r16 |
декремент r16 |
FE /1 |
DEC r/m8 |
декремент r/m8 |
FF /1 |
DEC r/m16 |
декремент r/m16 |
Описание.Эта инструкция уменьшает значение своего операнда на единицу. Операндом может являться любой регистр общего назначения или одно- или двухбайтовое поле памяти.
ФлажкиOF,SF,ZF,AFиPFустанавливаются в соответствии с результатом по обычным правилам. Значение флажкаCFне изменяется.
Замечания по программированию
Декремент 16-разрядных регистров общего назначения может быть выполнен двумя видами инструкций – однобайтовой (код операции 48 плюс номер регистра) и двухбайтовой (код операции FF, номер регистра определяется байтомModRegR/M). Транслятор языка ассемблера автоматически генерирует однобайтовый код операции как более компактный; второй вариант при необходимости может быть запрограммирован вручную.
Div– деление беззнаковое
F6 /6 |
DIV r/m8 |
AL:= AX DIV r/m8 AH:= AX MOD r/m8 |
F7 /6 |
DIV r/m16 |
AX:= DX, AX DIV r/m16 DX:= DX, AX MOD r/m16 |
Описание.Эта команда производит целочисленное деление двух беззнаковых двоичных чисел.
Делимое имеет размер 16 или 32 разряда. В первом случае оно располагается в регистре AX, во втором занимает регистровую паруDX:AX(старшая часть – в регистреDX, младшая – в регистреAX). Делитель размещается в регистре или ячейке памяти, определяемой байтомModRegR/M. При 16-разрядном делимом делитель имеет размер байт, а при 32-разрядном делимом – слово.
Частное и остаток имеют разрядность, совпадающую с разрядностью делителя, т.е. в два раза меньше, чем у делимого. В операции деления 16-разрядного числа на 8-разрядное частное располагается в регистре AL, остаток – в регистреAH. При делении 32-разрядного числа на 16-разрядное частное будет находиться в регистреAX, а остаток – в регистреDX.
Если производится попытка деления на 0 или частное не помещается в отведённую разрядность, вырабатывается прерывание по ошибке деления (вектор 0).
Флажкине изменяются.