Добавил:
Upload Опубликованный материал нарушает ваши авторские права? Сообщите нам.
Вуз: Предмет: Файл:
0_МПиИСТС_Все главы.doc
Скачиваний:
518
Добавлен:
27.03.2016
Размер:
10.5 Mб
Скачать

4.7.5 Логические операции с непосредственной адресацией

  1. Логическая операция "И" со вторым байтом

ANI Данные

A(A) <B2> <B1>

E6

<B2>

Данные

б) Логическая операция "исключающее ИЛИ" со вторым байтом.

XRI Данные

A(A) <B2> <B1>

EE

<B2>

Данные

в) Логическая операция "ИЛИ" со вторым байтом

ORI Данные

A(A) <B2> < B1>

F6

<B2>

Данные

Все сказанное для логических операций над А и ri (п. 4) справедливо и для команд данной группы. Отличие состоит лишь в том, что второй операнд приводится непосредственно в команде во втором ее байте. Каждая операция выполняется за 2 машинных цикла (7 тактов).

Примеры:

0900) XRI 2B

Адрес/ регистр

Код до выполнения операции

Код после выполнения операции

0900

EE

EE

0901

00101011 =2B

2B

A

10101010 =AA

10000001=81

FL

02

86

PC

0900

0902

0800) ANI 98

Адрес/ регистр

Код до выполнения операции

Код после выполнения операции

0800

E6

E6

0801

98

98

A

AE

88

FL

03

96

PC

0800

0802

0802) ORI FE

Адрес/ регистр

Код до выполнения операции

Код после выполнения операции

0802

F6

F6

0803

FE

FE

A

A3

FF

FL

03

86

PC

0802

0804

4.7.6 Операции сравнения

а) Сравнение (А) с (ri)

CMP ri

(A) - (ri) <B1>

10111

ri

Пример:

0100) CMP D

Адрес

Код до выполнения операции

Код после выполнения операции

0100

BA

BA

A

B6

B6

D

CB

CB

FL

02

87

PC

0100

0101

б) Сравнение (А) со вторым байтом

CPI Данные

(A) - <B2> <B1>

FE

<B2>

Данные

Пример:

0125) CPI 25

Адрес/ регистр

Код до выполнения операции

Код после выполнения операции

0125

FE

FE

0126

25

25

A

96

96

FL

02

17

PC

0125

0127

Выполнение команд этой группы аналогично выполнению команды "вычитание", но ее результат не загружается в аккумулятор. Хотя по окончании операции исходные данные в аккумуляторе не изменяются, разрядам Z, S и С регистра признаков присваиваются значения в соответствии с полученным результатом.

В качестве регистров ri в команде а) могут быть выбраны A, B, C, D, E, H, L, M. С помощью этой команды можно производить сравнение двух слов на "больше", "меньше", "равно".

На выполнение команды а) затрачивается 1 машинный цикл (4такта) при работе с регистрами или 2 цикла (7 тактов), если данные нахо­дятся в памяти (М) по адресу HL . команда б) выполняется за 2 цикла (7 тактов).