Алгоритм работы устройства управления объектом приведен на рис.3.
Изучение предложенного алгоритма позволяет представить микропроцессорное устройство управления (МУУ) следующими функциями.
МУУ считывает из памяти параметр PAROU (блок 1), Увеличивает значение переменной PAROU на единицу (блок 2) и сравнивает его с допуском DOP, значение которого задано (блок 3). Если PAROU < DOP, то алгоритмом функционирования предусмотрен возврат к блоку 2. Если PAROU > DOP, то значение параметра PAROU уменьшается на 25 (блок 4) и результат выдается в порт PRT1 на объект управления (блок 5). После чего МУУ переходит к считыванию очередного значения параметра PAROU (блок 1).
Рисунок 3. Алгоритм работы устройства управления
Процесс управления заканчивается при достижении ситуации, когда PAROU = DOP.
При разработке структурной схемы МУУ в качестве основы используют структурную схему, показанную на рис.1.
Далее студенту следует описать назначение каждого блока структурной схемы и на основании принципов функционирования МУУ и системы команд составить машинный алгоритм работы устройства управления.
Машинный алгоритм показан на рис.4.
Блоком 1 алгоритма осуществляется загрузка пары регистров HL адресом ячейки памяти, в которой хранится параметр PAROU. Блок 2 пересылает содержимое ячейки памяти (параметр PAROU), адрес которой указан в паре регистров HL в регистр аккумулятор. Блок 3 осуществляет инкремент содержимого регистра аккумулятора. Далее в регистровую пару HL заносится адрес ячейки памяти, в которой хранится параметр DOP (блок 4).
Рисунок 4. Машинный алгоритм функционирования МУУ
Блок 5 осуществляет сравнение содержимого регистра аккумулятора A и содержимого ячейки памяти M, адресуемой парой регистров HL. В ячейке памяти хранится параметр DOP, а в регистре аккумуляторе – параметр PAROU. В результате сравнения содержимого аккумулятора с содержимым ячейки памяти устанавливаются флаги C и Z. Если (A) < (M), то флаг переноса C = 1 и осуществляется переход к блоку 3. Если (A) = (M), то разность (A) – (M) = 0 и устанавливается флаг Z =1 и осуществляется переход к блоку СТОП. Если не выполняется ни одно из рассмотренных условий, осуществляется переход к блоку 6. В результате выполнения операции сравнения содержимое регистра аккумулятора, где хранится параметр PAROU, не изменяется.
Блок 6 осуществляет операцию уменьшения содержимого регистра аккумулятора, т.е. уменьшение значения PAROU на десятичную константу 25 (десятичное число 25 в шестнадцатеричной системе счисления 19H) и результат заносится в аккумулятор. Далее блоком 7 содержимое аккумулятора передается в выходной порт PRT1, и управление передается на блок 1 алгоритма.
В соответствии с рассмотренным алгоритмом составим программу для МУУ (табл.1).
Таблица 1. Программа функционирования МУУ
Таким образом, программа функционирования МУУ размещается в 25 ячейках памяти. Ячейка памяти с адресом 0148H используется для хранения параметра PAROU, равного 59H, ячейка с адресом 0149H – для хранения допуска DOP, равного 54H. Адресное пространство памяти, занимаемое программой, определяется адресами 0131H ÷ 0149H. Порту PRT1 присвоен адрес F0H.
Наименование
| Число тактов/циклов
| Двоичный код
| Название и описание
|
Команды передачи данных
|
MOV R1, R2
| 5/1
| 01DDDSSS
| Передача между регистрами. (R1) (R2). Содержимое регистра R2 передается в регистр R1. Содержимое регистра R2 не меняется.
|
MOV R, M
| 7/1
| 01DDD110
| Передача из памяти. (R) (M). Содержимое ячейки памяти, адрес которой находится в паре регистров HL, передается в регистр R.
|
MOV M, R
| 7/1
| 01110SSS
| Передача в память. (M) (R). Содержимое регистра R передается в ячейку памяти, адрес которой находится в паре регистров HL.
|
MVI R, data
| 7/2
| 00DDD110
| Непосредственная передача в регистр. (R) (байт2). Содержимое байта 2 команды передается в регистр R.
|
MVI M, data
| 10/2
|
| Непосредственная передача в память. (M) (байт2). Содержимое байта 2 команды передается в ячейку памяти, адрес которой указан в паре регистров HL.
|
| Загрузка
|
LXI RP, data
| 10/3
| 00RP0001
| Непосредственная загрузка пары регистров. (RH) (байт3);(RL) (байт2). Байт 3 команды передается в старший регистр (RH) регистровой пары RP, а байт 2 в младший регистр (RL) этой же пары.
|
LDA addr
| 13/3
|
| Прямая загрузка аккумулятора. (A) ((байт3)(байт2)). Содержимое ячейки памяти, адрес которой определен байтами 2 и 3 команды, передается в аккумулятор.
|
LHLD addr
| 16/3
|
| Прямая загрузка пары регистров. L ((байт3)(байт2)); H ((байт3)(байт2)+1). Содержимое ячейки памяти, адрес которой определяется байтами 2 и 3 команды передается в регистр L. Содержимое следующей ячейки памяти передается в регистр H.
|
LDAX RP
| 7/1
| 00RP1010
| Косвенная загрузка аккумулятора. (A) (M). Содержимое ячейки памяти, адрес которой определяется парой регистров RP, передается в аккумулятор. Могут использоваться только пары RP=B (регистры B и C) или RP=D (регистры D и E).
|
Наименование
| Число тактов/циклов
| Двоичный код
| Название и описание
|
XCHG
| 4/1
|
| Обмен. (H) «(D); (L) «(E). Содержимое регистров H и L обмениваются с содержимым регистров D и E.
|
STA addr
| 13/3
|
| Прямое размещение содержимого аккумулятора. ((байт3)(байт2)) (A). Содержимое аккумулятора передается в ячейку памяти, адрес которой указан байтами 2 и 3 команды.
|
SHLD addr
| 16/3
|
| Прямое размещение содержимого регистров. ((байт3)(байт2)) (L); ((байт3)(байт2)+1) (H). Содержимое регистра L передается в ячейку памяти, адрес которой определяется байтами 2 и 3 команды, одержимое регистра H передается в следующую ячейку памяти.
|
STAX RP
| 7/1
| 00RP0010
| Косвенная загрузка аккумулятора. (M) (A). Содержимое аккумулятора передается в ячейку памяти, адрес которой содержится в паре регистров RP. Могут использоваться только пары RP=B (регистры B и C) или RP=D (регистры D и E).
|
Арифметические команды
|
ADD R
| 4/1
| 10000SSS
| Сложение содержимого регистра. (A) (A)+(R). Содержимое регистра R складывается с содержимым аккумулятора. Результат помещается в аккумулятор. Устанавливаются флаги – Z, S, C, P, AC.
|
ADD M
| 7/2
|
| Сложение содержимого ячейки памяти. (A) (A)+((H)(L)). Содержимое ячейки памяти, адрес которой указан в паре регистров HL, складывается с содержимым аккумулятора. Результат помещается в аккумулятор. Устанавливаются флаги – Z, S, C, P, AC.
|
ADI data
| 7/2
|
| Непосредственное сложение. (A) (A)+(байт2). Содержимое байта 2 команды складывается с содержимым аккумулятора. Результат помещается в аккумулятор. Устанавливаются флаги – Z, S, C, P, AC.
|
ADC R
| 4/1
| 10001SSS
| Сложение содержимого регистра и переноса. (A) (A)+(R)+(C). Содержимое регистра R и флага переноса C (бит переполнения) складывается с содержимым аккумулятора. Результат помещается в аккумулятор. Устанавливаются флаги – Z, S, C, P, AC.
|
Наименование
| Число тактов/циклов
| Двоичный код
| Название и описание
|
ADC M
| 7/2
|
| Сложение содержимого ячейки памяти и переноса. (A) (A)+((H)(L))+(C). Содержимое ячейки памяти, адрес которой указан в паре регистров HL, и флага переноса C складывается с содержимым аккумулятора. Результат помещается в аккумулятор. Устанавливаются флаги – Z, S, C, P, AC.
|
ACI data
| 7/2
|
| Непосредственное сложение с учетом переноса. (A) (A)+(байт2)+(C). Содержимое байта 2 команды и флага переноса C складывается с содержимым аккумулятора. Результат помещается в аккумулятор. Устанавливаются флаги – Z, S, C, P, AC.
|
DAD RP
| 10/3
| 00RP1101
| Сложение содержимого пары регистров с содержимым пары регистров HL. (H)(L) (H)(L)+(RH)(RL). Содержимое пары регистров RP складывается с содержимым пары регистров HL. Устанавливается флаг C. C=1, если есть перенос при сложении с удвоенной точностью, C=0, если нет переноса.
|
DAA
| 4/1
|
| Десятичная коррекция аккумулятора: 1. Если (A3…A0) > 9 или AC = 1, то (A)+6; 2. Если (A7…A4) > 9 или C = 1, то (A7…A4)+6
|
SUB R
| 4/1
| 10010SSS
| Вычитание содержимого регистра (A) (A)-(R). Содержимое регистра R вычитается из содержимого аккумулятора. Результат помещается в аккумулятор. Устанавливаются флаги – Z, S, C, P, AC.
|
SUB M
| 7/2
|
| Вычитание содержимого ячейки памяти. (A) (A)-(M). Содержимое ячейки памяти, адрес которой указан в паре регистров HL, вычитается из содержимого аккумулятора. Результат помещается в аккумулятор. Устанавливаются флаги – Z, S, C, P, AC.
|
SUI data
| 7/2
|
| Непосредственное вычитание. (A) (A)-(байт2). Содержимое байта 2 команды вычитается из содержимого аккумулятора. Результат помещается в аккумулятор. Устанавливаются флаги – Z, S, C, P, AC.
|
SBB R
| 4/1
| 10011SSS
| Вычитание содержимого регистра и переноса (A) (A)-(R)-(C). Содержимое регистра R и флага переноса C вычитается из содержимого аккумулятора. Результат помещается в аккумулятор. Устанавливаются флаги; Z, S, C, P, AC
.
|
Наименование
| Число тактов/циклов
| Двоичный код
| Название и описание
|
SBB M
| 7/2
|
| Вычитание содержимого ячейки памяти и переноса. (A) (A)-(M)-(C). Содержимое ячейки памяти, адрес которой указан в паре регистров HL, и флага переноса C вычитается из содержимого аккумулятора. Результат помещается в аккумулятор. Устанавливаются флаги – Z, S, C, P, AC
|
SBI data
| 7/2
|
| Непосредственное вычитание данных и переноса. (A) (A)-(байт2)-(C). Содержимое байта 2 команды и индикатора переноса C вычитается из содержимого аккумулятора. Результат помещается в аккумулятор. Устанавливаются флаги – Z, S, C, P, AC.
|
INR R
| 5/1
| 00DDD100
| Инкремент содержимого регистра. (R) (R)+1. Содержимое регистра увеличивается на 1. Устанавливаются флаги – Z, S, P, AC.
|
INR M
| 10/3
|
| Инкремент содержимого ячейки памяти. (M) ((H)(L))+1. Содержимое ячейки памяти, адрес которой указан в паре регистров HL, увеличивается на 1. Устанавливаются флаги – Z, S, P, AC
|
INX RP
| 5/1
| 00RP0011
| Инкремент содержимого пары регистров. (RH)(RL) (RH)(RL)+1. Содержимое пары регистров RP увеличивается на 1
|
DCR R
| 5/1
| 00DDD101
| Декремент содержимого регистра. (R) (R)-1. Содержимое регистра уменьшается на 1. Устанавливаются флаги – Z, S, P, AC.
|
DCR M
| 10/3
|
| Декремент содержимого ячейки памяти (M) (M)-1. Содержимое ячейки памяти, адрес которой указан в паре регистров HL, уменьшается на 1. Устанавливаются флаги – Z, S, P, AC.
|
DCX RP
| 5/1
| 00RP1011
| Декремент содержимого пары регистров (RH)(RL) (RH)(RL)-1. Содержимое пары регистров RP уменьшается на 1.
|
Логические команды
|
ANA R
| 4/1
| 10100SSS
| «И» с содержимым регистра. (A) (A)Ù(R). Содержимое регистра R и содержимое аккумулятора логически умножается. Результат помещается в аккумулятор. Устанавливаются флаги – Z, S, P, AC. C=0
|
Наименование
| Число тактов/циклов
| Двоичный код
| Название и описание
|
ANA M
| 7/2
|
| «И» с содержимым ячейки памяти. (A) (A)Ù(M). Содержимое ячейки памяти, адрес которой указан в паре регистров HL и содержимое аккумулятора логически умножается. Результат помещается в аккумулятор. Устанавливаются флаги – Z, S, P, AC. C = 0
|
ANI data
| 7/2
|
| «И» непосредственно с данными. (A) (A)Ù(байт2). Содержимое байта 2 команды и содержимое аккумулятора логически умножается. Результат помещается в аккумулятор. Устанавливаются флаги – Z, S, P, AC. C = 0.
|
XRA R
| 4/1
| 10101SSS
| «Исключающее ИЛИ» с содержимым регистра (A) (A)Å(R). Исключающее ИЛИ выполняется с содержимым регистра R и содержимым аккумулятора. Результат помещается в аккумулятор. Устанавливаются флаги – Z, S, P. AC=0, C=0.
|
XRA M
| 7/2
|
| «Исключающее ИЛИ» с содержимым ячейки памяти. (A) (A)Å(M). Исключающее ИЛИ выполняется с содержимым ячейки памяти, адрес которой указан в паре регистров HL и содержимым аккумулятора. Результат помещается в аккумулятор. Устанавливаются флаги – Z, S, P. AC=0, C=0.
|
XRI data
| 7/2
|
| «Исключающее ИЛИ» непосредственно с данными. (A) (A)Å(байт2). Исключающее ИЛИ выполняется с содержимым байта 2 команды и содержимым аккумулятора. Результат помещается в аккумулятор. Устанавливаются флаги – Z, S, P. AC=0, C=0.
|
ORA R
| 4/1
| 10110SS
| «ИЛИ» с содержимым регистра. (A) (A)Ú(R). Содержимое регистра R логически складывается с содержимым аккумулятора. Результат помещается в аккумулятор. Устанавливаются флаги – Z, S, P. AC=0, C=0.
|
ORA M
| 7/2
|
| «ИЛИ» с содержимым ячейки памяти. (A) (A)Ú(M). Содержимое ячейки памяти, адрес которой указан в паре регистров HL логически складывается с содержимым аккумулятора. Результат помещается в аккумулятор. Устанавливаются флаги – Z, S, P. AC=0, C=0.
|
Наименование
| Число тактов/циклов
| Двоичный код
| Название и описание
|
ORI data
| 7/2
|
| «ИЛИ» непосредственно с данными. (A) (A)Ú(байт2). Содержимое байта 2 команды логически складывается с содержимым аккумулятора. Результат помещается в аккумулятор. Устанавливаются флаги – Z, S, P. AC=0, C=0.
|
CMP R
| 4/1
| 10111SSS
| Сравнить содержимое регистра. (A)-(R). Содержимое регистра R вычитается из содержимого аккумулятора. Содержимое аккумулятора не изменяется. Флаги – Z=1, если (A)=(R), C=1, если (A)<(R).
|
CMP M
| 7/2
|
| Сравнить содержимое ячейки памяти. (A)-(M). Содержимое ячейки памяти, адрес которой указан парой регистров HL, вычитается из содержимого аккумулятора. Содержимое аккумулятора не изменяется. Флаги – Z=1, если (A)=(M), C=1, если (A)<(M).
|
CPI data
| 7/2
|
| Непосредственно сравнить данные. (A)-(байт2). Содержимое байта 2 команды вычитается из содержимого аккумулятора. Содержимое аккумулятора не изменяется. Флаги – Z=1, если (A)=(байт2), C=1, если (A)<(байт2).
|
RLC
| 4/1
|
| Сдвиг влево. (A) (2A). Содержимое аккумулятора сдвигается на один разряд влево (A0 A7, C A7, An+1 An). Устанавливается флаг C.
|
RRC
| 4/1
|
| Сдвиг вправо. (A) (A/2). Содержимое аккумулятора сдвигается на один разряд вправо (A7 A0, C A0, An An+1). Устанавливается флаг C.
|
RAL
| 4/1
|
| Циклический сдвиг влево. Содержимое аккумулятора сдвигается влево вместе с C (C A7, A0 C An+1 An). Устанавливается флаг C.
|
RAR
| 4/1
|
| Циклический сдвиг вправо Содержимое аккумулятора сдвигается вправо вместе с C (A7C, C A0, An An+1). Устанавливается флаг C.
|
CMA
| 4/1
|
| Инвертировать содержимое аккумулятора. .Содержимое аккумулятора инвертируется.
|
CMC
| 4/1
|
| Инвертировать флаг переноса. . Инвертируется флаг переноса.
|
STC
| 4/1
|
| Установить перенос. (C) 1. Флаг переноса устанавливается в 1.
|
Наименование
| Число тактов/циклов
| Двоичный код
| Название и описание
|
Команды ветвлений и переходов
|
JMP addr
| 10/3
|
| Ветвление. (PC) (байт3)(байт2). Управление передается команде, адрес которой указан в байтах 3 и 2 текущей команды.
|
Jcnd addr
| 10/3
| 11cnd010
| Условное ветвление. Если (cnd), то (PC) ((байт3)(байт2). Если условие выполняется, то управление передается команде, адрес которой указан в байтах 2 и 3 текущей команды, иначе – выполняется следующая команда программы.
|
CALL addr
| 17/5
|
| Вызов подпрограммы. (M0) (PCH), (адрес (M0) содержится в (SP)-1); (M1) (PCL), (адрес (M1) содержится в (SP)-2); (SP) ((SP)-2); (PC) (байт3)байт2).
|
Ccnd addr
| 17/5
| 11cnd100
| Условный вызов подпрограммы. Если условие выполняется, то действия те же, что и в команде CALL, иначе – выполняется следующая команда программы.
|
RET
| 10/3
|
| Возврат из полпрограммы. (M0) (PCL) (адрес (M0) содержится в (SP)); (M1) (PCH) (адрес (M1) содержится в (SP)+1); (SP) (SP)+2.
|
Rcnd
| 11/3
| 11cnd000
| Условный возврат из подпрограммы. Если условие выполняется, то действия те же, что и в RET, иначе – выполняется следующая команда программы
|
RST N
| 11/3
| 11NNN111
| Рестарт. (M0) (PCH), (адрес (M0) содержится в (SP)-1); (M1) (PCL), (адрес (M1) содержится в (SP)-2); (SP) ((SP)-2); (PC) (NNN´8).
|
PCHL
| 5/1
|
| Косвенный переход по адресу, указанному в паре регистров HL. (PCH) (H); (PCL) (L).
|
Команды ввода/вывода, управления и работы со стеком
|
IN port
| 10/3
|
| Ввести данные. (A) (port). Данные из порта, адрес которого указан в байте 2 команды записываются в аккумулятор.
|
OUT port
| 10/3
|
| Вывести данные. (port) (A). Данные из аккумулятора записываются в порт, адрес которого указан в байте 2 команды.
|
PUSH RP
| 11/3
| 11RP0101
| Загрузить в стек содержимое пары регистров. (M0) (RH), (адрес (M0) содержится в (SP)-1); (M1) (RL), (адрес (M1) содержится в (SP)-2)); (SP) ((SP)-2).
|
Наименование
| Число тактов/циклов
| Двоичный код
| Название и описание
|
PUSH PSW
| 11/3
|
| Загрузить в стек содержимое регистра флагов. (M0) (A); (адрес (M0) содержится в (SP)-1); (M1) PSW; (адрес (M1) содержится в (SP)-2)); (SP) ((SP)-2).
|
POP RP
| 10/3
| 11RP0001
| Считать из стека содержимое пары регистров. (RL) (M0); (адрес (M0) содержится в (SP)); (RH) (M1); (адрес (M1) содержится в (SP)+1)); (SP) ((SP)+2).
|
POP PSW
| 10/3
|
| Считать из стека содержимое регистра флагов. (PSW) (M0); (адрес (M0) содержится в (SP)); (A) (M1); (адрес (M1) содержится в (SP)+1)); (SP) ((SP)+2).
|
XTHL
| 18/5
|
| Обмен содержимым верхушки стека и пары регистров HL. (L) «(M0); (адрес (M0) содержится в (SP)); (H) «(M1); (адрес (M1) содержится в (SP)+1));
|
SPHL
| 5/1
|
| Пересылка содержимого регистров HL в указатель стека. (SP) (HL).
|
EI
| 4/1
|
| Разрешение прерываний после выполнения следующей команды.
|
DI
| 4/1
|
| Запрещение прерываний после выполнения следующей команды.
|
HLT
| 7/1
|
| Останов. Процессор останавливается.
|
NOP
| 4/1
|
| Нет операций. Не выполняется никаких операций.
|
| | | | | | | | |
КОДЫ УСЛОВИЙ (cnd), используемых в командах условного перехода, вызова подпрограмм и возврата из них