Команда xadd выполняет в одной операции сложение и обмен операндов. Команда требует двух операндов, причем первый операнд должен быть ячейкой памяти, а второй - регистром. После сложения операндов исходное содержимое памяти переносится во второй операнд (регистр), а полученная сумма записывается в память (на место первого слагаемого) (рис. П13). Команда воздействует на флаги OF, SF, ZF, AF, PF и CF.
Рис. П13. Действие команды xadd.
Пример
; В полях данных
mem dw 99
;В программном сегменте
mov AX,48
xadd mem,AX ;mem=147, AX=99
XCHG Обмен данными между операндами
Команда xchg пересылает значение первого операнда во второй, а второго - в первый.
В качестве любого операнда можно указывать регистр (кроме сегментного) или ячейку
памяти, однако не допускается определять оба операнда одновременно как ячейки
памяти. Операнды могут быть байтами или словами и представлять числа со знаком
или без знака. Команда не воздействует на флаги процессора.
Пример 1
mov AX,OFF01h
Пример 2
;В полях данных:
Пример 3
mov AX,6031h
Допустимо использование 32-битовых операндов и дополнительных режимов адресации 32-разрядных процессоров.
Пример
xchg ESI,EDI ;ESI и EDI обмениваются содержимым
XLAT Табличная трансляция
Команда xlat осуществляет выборку байта из массива байтов, который в этом случае
называют таблицей трансляции. В регистре ВХ должен находиться относительный
адрес таблицы, а в регистре AL - смещение в таблице к выбираемому байту (его
индекс). Выбранный байт загружается в регистр AL, замещая находившееся в нем
смещение. Длина таблицы может достигать 256 байт. Таблица должна находиться
в сегменте данных, адресуемом через сегментный регистр DS. Замена сегмента не
допускается. Команда xlat не имеет параметров, но требует предварительной настройки
регистров ВХ и AL. Команда не воздействует на флаги процессора.
Пример
;Пример демонстрирует преобразование первых 14 скен-кодов
386+ XLAT
386+ XLATB
Команда xlatb эквивалентна команде xlat МП 86 за исключением того, что для 32-разрядных
приложений относительный адрес таблицы размещается в расширенном регистре ЕВХ.
Команда xlat может иметь в качестве операнда относительный адрес таблицы трансляции;
в этом случае помещение адреса таблицы в регистр ЕВХ не требуется. Действие
команды от этого не изменяется, однако возможна замена сегмента.
Пример
;В сегменте, адресуемом через сегментный регистр ES:
XOR Логическое ИСКЛЮЧАЮЩЕЕ ИЛИ
Команда хог выполняет операцию логического (побитового) ИСКЛЮЧАЮЩЕГО ИЛИ над
своими двумя операндами. Результат операции замещает первый операнд; второй
операнд не изменяется. Каждый бит результата устанавливается в 1, если соответствующие
биты операндов различны, и сбрасывается в 0, если соответствующие биты операндов
совпадают.
В качестве первого операнда команды хог можно указывать регистр (кроме сегментного)
или ячейку памяти, в качестве второго - регистр (кроме сегментного), ячейку
памяти или непосредственное значение, однако не допускается определять оба операнда
одновременно как ячейки памяти. Операнды могут быть байтами или словами. Команда
воздействует на флаги OF, SF, ZF, PF и CF, причем флаги OF и CF всегда сбрасываются,
а остальные флаги устанавливаются в зависимости от результата.
Правила побитового ИСКЛЮЧАЮЩЕГО ИЛИ:
Первый операнд-бит 0101
Второй операнд-бит 0011
Бит результата 0110
Пример 1
mov AX,0Fh
Пример 2
хог ВХ,ВХ ;Обнуление ВХ
Пример 3
mov SI,0AAAAh
Допустимо использование 32-битовьгх операндов и дополнительных режимов адресации 32-разрядных процессоров.
Пример
mov EAX,4444AAAAh