Логические команды.

Логические команды выполняют над операндами логические (побитовые) операции, то есть они рассматривают коды операндов не как единое число, а как набор отдельных битов. Этим они отличаются от арифметических ко­манд. Логические команды выполняют следующие основные операции:

• логическое И, логическое ИЛИ, сложение по модулю 2 (Исключаю­щее ИЛИ);

• логические, арифметические и циклические сдвиги;

• проверка битов и операндов;

• установка и очистка битов (флагов) регистра состояния процессора
(PSW).

Команды логических операций позволяют побитно вычислять основ­ные логические функции от двух входных операндов. Кроме того, операция И (AND) используется для принудительной очистки заданных битов (в качестве одного из операндов при этом используется код маски, в кото­ром разряды, требующие очистки, установлены в нуль). Операция ИЛИ (OR) применяется для принудительной установки заданных битов (в ка­честве одного из операндов при этом используется код маски, в котором разряды, требующие установки в единицу, равны единице). Операция “Ис­ключающее ИЛИ” (XOR) используется для инверсии заданных битов (в качестве одного из операндов при этом применяется код маски, в кото­ром биты, подлежащие инверсии, установлены в единицу). Команды тре­буют двух входных операндов и формируют один выходной операнд.

Команды сдвигов позволяют побитно сдвигать код операнда вправо (в сторону младших разрядов) или влево (в сторону старших разрядов). Тип сдвига (логический, арифметический или циклический) определяет, ка­ково будет новое значение старшего бита (при сдвиге вправо) или млад­шего бита (при сдвиге влево), а также определяет, будет ли где-то сохра­нено прежнее значение старшего бита (при сдвиге влево) или младшего бита (при сдвиге вправо). Например, при логическом сдвиге вправо в старшем разряде кода операнда устанавливается нуль, а младший разряд записывается в качестве флага переноса в регистр состояния процессора. А при арифметическом сдвиге вправо значение старшего разряда сохраняется прежним (нулем или единицей), младший разряд также записывается в качестве флага переноса.

Циклические сдвиги позволяют сдвигать биты кода операнда по кругу (по часовой стрелке при сдвиге вправо или против часовой стрелки при сдвиге влево). При этом в кольцо сдвига может входить или не входить флаг переноса. В бит флага переноса (если он используется) записывается значение старшего бита при циклическом сдвиге влево и младшего бита мри циклическом сдвиге вправо. Соответственно значение бита флага пе­реноса будет переписываться в младший разряд при циклическом сдвиге плево и в старший разряд при циклическом сдвиге вправо.

Для примера на рис. 3.12 показаны действия, выполняемые командами сдвигов вправо.

Команды проверки битов и операндов предназначены для установки или очистки битов регистра состояния процессора в зависимости от зна­чения выбранных битов или всего операнда в целом. Выходного операнда команды не формируют. Команда проверки операнда (TST) проверяет весь код операнда в целом на равенство нулю и на знак (на значение старшего опта), она требует только одного входного операнда. Команда проверки опта (BIT) проверяет только отдельные биты, для выбора которых в качестве второго операнда используется код маски. В коде маски проверяемым битами основного операнда должны соответствовать единичные разряды.


через перенос Ст- Операнд переноса

 

Рис. 3.12.Команды сдвигов вправо.

Наконец, команды установки и очистки битов регистра состояния про­цессора (то есть флагов) позволяют установить или очистить любой флаг, что бывает очень удобно. Каждому флагу обычно соответствуют две ко­манды, одна из которых устанавливает его в единицу, а другая сбрасывает в нуль. Например, флагу переноса С (от Carry) будут соответствовать ко­манды CLC (очистка) и SEC или STC (установка).