Задание

Найти наименьший отчёт, зарегистрированный в «электронном журнале» во время предпоследнего сеанса снятия показаний датчиков.

Исходный данные:

Количество датчиков N – 5

Количество сеансов n – 2

Начальный адрес для файла G Аж.нач. – 2225(10) = 08B1(16)

Начальный адрес программы Апр.нач. – FA25(16)

Микропроцессорная система обработки журнальных данных

1. Каждому включению МСОЖД должен предшествовать рабочий цикл некоторого автомата для сбора данных (АСД), который в течении своего суточного цикла (когда сигнал X1 = 1) организует n сеансов связи и во время каждого «сеанса» поочерёдно (в порядке возрастания номеров) подключает датчики Д1…Дn ко входу данных Д ОЗУ, формирует адрес (номер) Aij ячейкидля записи показаний Дij i-го датчика в j-ом «сеансе» связи и вырабатывает саму команду w запись. В результате в конце суточного цикла сбора данных, когда сигнал ![](data:image/x-wmf;base64,183GmgAAAAAAAIADIAL/CAAAAABOXgEACQAAA/UAAAACABwAAAAAAAUAAAAJAgAAAAAFAAAAAgEBAAAABQAAAAEC////AAUAAAAuARgAAAAFAAAACwIAAAAABQAAAAwCIAKAAxIAAAAmBg8AGgD/////AAAQAAAAwP///6b///9AAwAAxgEAAAsAAAAmBg8ADABNYXRoVHlwZQAAUAAcAAAA+wKA/gAAAAAAAJABAAAAAgQCABBTeW1ib2wAdbIbChAoBTIAFPESAHlIVXVAkVh1/RZmFQQAAAAtAQAACAAAADIKgAFqAgEAAAA9eRwAAAD7AiD/AAAAAAAAkAEAAAAABAIAEFRpbWVzIE5ldyBSb21hbgAU8RIAeUhVdUCRWHX9FmYVBAAAAC0BAQAEAAAA8AEAAAgAAAAyCuABbwEBAAAAMXkcAAAA+wKA/gAAAAAAAJABAQAAAAQCABBUaW1lcyBOZXcgUm9tYW4AFPESAHlIVXVAkVh1/RZmFQQAAAAtAQAABAAAAPABAQAIAAAAMgqAAVgAAQAAAFh5CgAAACYGDwAKAP////8BAAAAAAAcAAAA+wIQAAcAAAAAALwCAAAAzAECAiJTeXN0ZW0AFf0WZhUAAAoAOACKAQAAAAABAAAAMPMSAAQAAAAtAQEABAAAAPABAAADAAAAAAA=)1|0 сменит свой уровень с 1 на 0, в ОЗУ окажется сформированным готовым к обработке файл G данных (т.е. электронный журнал), структура которого полностью известна.

На рисунке 1 изображена упрощённая структура такого автомата для сбора данных (АСД): в его состав входят программируемый электронный таймер, 8-разрядный N-канальный мультиплексор и два детектора, которые, анализируя показания таймера, формируют сигналы «сеанс» (=1 во время сеанса) и «цикл» (=1 во время цикла). Последний из них X1 хранится в регистре параллельного действия RG, т. е. в «порте» устройства ввода УВ №1 МСОЖД.

Мультиплексор каналов

+

счётчик – формирователь адреса

Детектор «нач/конец сеанса»

Детектор «нач/конец сеанса»

D ОЗУ

(файл G)

A

W/R

RG

D0 (порт УВв1)

Д1

Д1

ДN

(8)

(8)

Канал 1

Канал 2

Канал N-1

(8)

(16)

X2 («сеанс»)

X1 («цикл»)

(8)

W

gt

Рис. 1. Автомат для сбора данных.

2. Описание МСОЖД. Один из возможных вариантов построения МСОЖД показан на рисунке 2, где приведена микропроцессорная система с трёхшинной организацией, а в качестве центрального процессора (CPU) использована БИС КР580ВМ80. Если в ОЗУ в область свободную от обрабатываемого файла G, разместить программу, реализующую заданный пользователем алгоритм обработки, то становится возможной автоматизация процедуры обработки. Программ запускается по окончании суточного цикла сбора данных, а обработка начинается по сигналу X = 0, считываемому с «детектора цикла» АСД и вводимому через устройство ввода УВв №1 по команде INPUT программы. В ходе обработки программа должна обеспечивать неоднократное извлечение из ОЗУ любого элемента файла G, выполнение над ним необходимых арифметических и логических действий, приводящих к формированию конечного результата F, и выдачу F через устройство вывода УВыв №1 пользователю (по команде UOTPUT). Нужно учесть, что структура файла G такова (поочередная запись показаний датчиков в порядке возрастания их номеров во время каждого сеанса), что информация gij, принятая по i-ому каналу (i=1,2,…,n-1) во время j-ого сеанса (j=0,1,2,…,n-1), будет храниться в ячейке ОЗУ с номером = адресом Aij = Aнач + j\*N+i.

А область памяти, которую занимает журнал, находится в диапазоне адресов от Анач до (Анач + n\*N+1).

CPU

![](data:image/x-emf;base64,AQAAAGwAAAAAAAAAAAAAAA8AAABUAAAAAAAAAAAAAAA1AgAAuAsAACBFTUYAAAEAjBYAAAYAAAABAAAAAAAAAAAAAAAAAAAAAAQAAAADAABpAQAADwEAAAAAAAAAAAAAAAAAAByDBQBVIgQAEQAAAAwAAAAIAAAACwAAABAAAAAQAAAAVQAAAAkAAAAQAAAANQIAALgLAABNAAAA4BUAAAAAAAAAAAAADwAAAFQAAAAAAAAAAAAAADUCAAC4CwAAIADMAAAAAAAAAAAAAACAPwAAAAAAAAAAAACAPwAAAAAAAAAA////AAAAAABsAAAANAAAAKAAAABAFQAAEAAAAFUAAAAoAAAAEAAAAFUAAAABACAAAwAAAEAVAAAAAAAAAAAAAAAAAAAAAAAAAAD/AAD/AAD/AAAA+/7///X6/f/0////9//////9/////P//+f3///j+///9/v////z+///+///8+/3/+P////P9/f/6////+v7///3////6////8////+76/v/2+P//+vv///H9///r+f//8/z///T8///y9v//+P3//+/6/v/0////9vv8//v////+/v7/+////+37//84S1j/5vr//+P4///g+P//3fn//9n3///c+P//4vf//+j6//84SFT/8/////j9/////v////39//3////y/P//AAEN/46bq/+tvM//p7vN/6rC1v+lwNX/qsHX/7PB1P+Pl6j/AAAI//P9///7/v////7////+///+/f///f7//wUAAP8gDQD/TDgm/z82KP8HBAD/Ojkk/z83IP9KMiD/JA4D/wIAAP/4/v////7////+/////v////z+///+/v8OAQD//+/a///54P//+OH/FgcA///01///+Nv///zk///p2f8KAgD///38//75+v///v////7//////v///vX/s6qh//D8/P/y/v7/1cnD/xUDAP8qHhz/wsDA//j////7//7/raWY////9f////7///7////+/////f7////7///8+f/s+/7/kZ2h/xILCP/Zysf/iH1//wEABP+UnqX/7vf6////+f////n///3+//z9/////v//+vr///j8//+/vsf/XU9J/7ionP/27eT////4////8/+7q5v/HAwA/1VMSf/x8/7/9fv///39/////f////7///n8///1/P//AAAD///48P///O7////2////+P////T////y///p2v9ENC7/HBsk//b8///09/v///////7/+/////v////1/wsCAP///fr///78/////P///Pv///3////9/v////z//fHr/w8DAP////L////7//v//v/+//v////6////9P+Eg3n//f7///b5///4/v//9f7///b8///1+///9Pz///v///9YVEn////1////+v/7//7///3///3+///y/v//X3R8/+P9///h/v//3Pn//+P+///m/v//4/v//+H+///e+///Wm55//P+///7/P////3////9///6/f//7fv//wAADP/D2eT/xNrl/8be6v/I3ur/x9ri/83g6P/I3ur/wdjn/wACEf/q+v//+/7////+///7////+/////r///8AAAD/IRUV/x8PEP8eEBH/Fw0N/xgTEv8XDQ3/IQ8Q/xwOD/8DBQX/+P////v////5+/z/+v/+//3////9//7/AgAA/6yho/+zpqj/rqSk/7Onpf8MAAD/uaah/8Cjn//CqKL/DAIA////+P/6/vn/+//+///+/////v//+f/+/wABBP/m/f//4P3//+H////s////AQEB///++/////z////5/2JSRf///vD////4//j/+P///v////////3//v8AAQH/ip2l/9/2///f+v//jZ2j/wQBAP////n////+///8+P////X////0////+P/9//v//f/8////+/////X/uaec/xsAAP87Hhn/MBkX/xUAAP9pVD/////v////+v/////////5////+P//+/z///3///3//P////v///30////9P/DpZr/c1FL/0ssK/+Yfnj////u////8P////v/+/////b+/v/6//////v////7///9/P7///z9///+/P///v7/+P////L9///q7/7/+fn////9/P////n////+//j7///r+P//7/v///b0////+f///f7///79/////f//+vv//+37//+swMv/X2+A/9Dd7f/2////9fr5///9/f/8/P//Dxkq/+/7///6+/////v///j+///0/P//8/z//8HEzP+Ce3j/q6Oj/wACDf/z+f//+f7///3///////////7//wAABv/0+P3/+//+//3/+//3/f//8/v///P9//8AAAT///Pw////+P8SCQb/n5ye//v+///5/P//+v3///v8//8CAAD////7//v/9v/7//f//fz///39///6+///BQIE///9/v///vj//enX/xUFAP/b2Of/9Pj///D1//+anKb/g351////9P/9//b/+//7//z6/////f/////7/wYDAP/////////7////7f+Nf23/Hhki/3V2iv9ud4X/eX+E////+P////X////5//z/+////f///Pr5////9f/Nzr7/9f/6//T//P/+//b////0//Pu3//Ly7//x9DG//f/+//8/fn////8///9/P////7///7///////////n//v/4//P99//s+ff/8v7///j//v////X////w//r97v/5/ff/+v7///r9/////v////79///9/f/9/f//8/f///P1//9VS1H/Jh4l/2Rvg//o+P//8/z//21tc/8vIyP/WE1Q/+vy///v/P//9vz///v///////z/+fn///P5//8WGjL/f3aA/6qiqf8ABBf/Xm+J/2N0jv+eqLr/0MjP/1JITv8VHCv/7vv///j+///7///////8///////2/v//AAAJ//P+///0////5Onn/wACBP9qg5f/4fz//+z8///4////AAAB//r+/////v////7/////+/////z/+/33/wABAP/R3uD/8v37/+Pj0/81NSf/AAEH/63BzP/v////8fr3/wgGAP////f////+///+//////////75////8/+Mf3H/HhMP/1lPSP9zZVP///nk/5CCcP8MAgD/eHBw/ygfG/+TgXD////w////+//+/f///f/////++/////T////y/7Gln/+tpKD////4////9P////T/sqie/1pTUP+If3v////x////8v/9+PX//f////39/////v///vr5/////P/3/Pr/8Pz//+b+///j/f//5Pz//+r9///w////+v/8///9+v///v7///7///v+///7/v//+/7///j+///4/v//9/////T////E19//r8TT/63B0/+vv8z/7fr4//b//P/4/v//+Pv///b5/v/9/v///vz///r9///v/f//8f3//6Odov80IyD/NR4P/0sxIP9NMiT/Iw0C/zcnIP+hnZz/8f3//+77///4/P////7////+///3+///8f3//2Zvef9UUFX/2MXA///p1v//+uH///vj///o1//cycL/VlBR/2Nudv/x/f//+/7////////9/f3////////+//8AAAH/9f7///v//////vz///73////9v////j///7///n8//8AAAD////+/////v///f3//f/+/////v////v/DQYD/9vj4//y+/7///3////9//////7//f/+//r+///b3OD/DgoF////9v////v////+//3//////v3////5/9HFv/8mIh3/dnJx/6KYnv/Iwcb/xsTE/5qYl/9/dHb/IxcX/9XMwv////f////8///+///9/////f39///+/////Pz/7efi/4eBfP86MjL/NzMy/zEyLv9aWVX/in58//jr6f///fj////8//v8+v////////////v8///x9///9vz///3///////v/+vru//b56v/1+e3////4///99f////7/8vv///D5///9//////76///////7/v//8/z//2JugP/x/f//8v7///D//v/x//7/7/////H////y////8////19ufv/x/P//9/v8/////P/+/f//+/z///v+//8AAAr/wdr0/7bY9v+w2PT/r9r1/7HY+P+23Pz/s9jy/8Db7/8AAAv/+/7///3////+//3//f////3////4+vr/AAMI/wANH/8ADSX/AA8o/wANJ/8ACSf/AAwn/wAPJP8AEB3/AAAD///////8/v7//f/////+///7/f7/+////wQBAP+7q5r/vamY/7Snn/8MAAD/vayp/7Oimf+5qZj/taiY/wUCAP////7//P7+//3//////////P7+//v///8FAgD////t////6v////H/FgMA///97/////D////r////7v8HAgD////+//3////9//////7////+//////7/AAEA//X////z////9P///wACAf/9/////f////X9/f/4////AAAB///+///+/v7///////7+/v////7///75/wECAP+1wcf/7f3//9Pg3v8AAgD/1tzn/+/3///s/P//z9vn/wIAAf///v7///////z+/v/9//z//vz0////9f+QgXj/DAAA/1lMRP8kFQL/uKic/xMJFf+bmK7/u7zW/woHF/8gDwz////3///7+P/9///////7////+////vn///33/5WEe/9IMyT/m4Fw////8v9EMTT/CgAH/wYACP8SBw//++zq///89v////z//P/9///7/v///P//8fb///b9//////f///rt///++v///Pn///bn/76pk/+4qY//8+rc//v9///4+/////7////++v///P////v///P6//+xvc//9P////n//f//+/////v/////9P///+v////q////9P+1vcr/8fv///n6/v////z//f////n5///7+///AAAO/+b4///o9///8u////30///++f////7///nu8f//+f//AAAK//X4/////f////3///n//f/9//7///7+/wQAA/8RGiT/ZXKC/2xwiP9tcYn/ZnOD/212g/93c3//VUtX/wUABP/////////////////7//7////5////8f9LNiH/HA4A/0VDOf+otcP/z+j8/9X0/f/i+fv/7PHw//317v8VCwD////w////9//5//j/+v/////9+P////D///nh/+POsv9gVUH/AQcG/xIiKf+MoKH/5/j1//j//v////n/08y9////8/////f/+//4//j+///9///////7////9////vH////0/93Nvf+TgHP/IgsD/yseHP9kbnX/y9rj//j9///++/////3////+///z+f7/+/7///z3+P////7////8////+///++/////0///q5P+TfHr/LTEy/wUTGf9sdX7/9/n////9////+///+v/8//r9+/////7///z9///8/v/6/v//7f3///P8////9///8Nzb/311ZP9XWET/x86///v/+f/6+vr///3///3/+//6/fv/+/7///n7///0/P//7Pz//9n0//+mv9P/anKD/4yPlP/p6uD////y//j97v/9//n//f////r7//////7/+f7///H8///m+v//u9f5/3yZuP9XaHv/k6a1/9Hx///W+///2/z//+b9//8VGST//Pv///r9///6/v///f78//v+///x/P//Xm+E/wANI/9QX2//n56g/5mcmv+KoaP/f5+l/4Odqf+Lmqr/AAAL///6///6/f//+P///////P////7//v3//w0DA/9FMSD/VDke/1M3GP9UOxn/Tzwb/0Y3F/9OPB3/RDMe/wwAAP///f////7+/////v/+//3////8/////P8SBgD///nn///53////uD///bW///52f///d////nd///44/8XDQP////6/////P////7///3///////////b/w8rF/+38///i8P//8/3///b////2////8vv//+fv///u9f//xs3G//7/9v/7/f3//f7////7///++v///f/8/+35+f86S17/BBcy/1lsgf/o/P//6vz//2BuhP8UHzv/RE1h/+319f/7//z/+/z///v6////+/////n///r6//8fHCX/jXxz/7qsoP8MDg7/Z292/3V7gv+rqan/08a4/2BRSP8iHSb/+fn////7/////P////7////9///69///BwAJ////9/////H/7efg/wMCAP+LiIT///32////8f///vH/BAAE///6/////P////z+//b/+v////v///z2/wcBAv/I2Oj/6Pj//+Tf4P9AMiz/CQEA/73Cwf/o/v//4fT//wYEA////fb////7////+//6//v////4////8/+HgXr/ABAb/ztMWf9pYWH///Tr/4yCeP8CAwH/W296/wkcJP+Fgnr////y////+P////v////+///9+v////v////3/7Knk/+9sJr////z///+9v////j/vKue/2JUPv+PhG7////0////+P////z///79///9/////P/////////79v////H////v////+f///v7///3+///69f////D////w////+f/8+vr////////+/////f///fv////9///6/P//7/v//+Ps///g2u3/xrrM/8i8zv/CvM//7/P///L5///6/f///f7///z9///9/v///f7///v+///4/f//7/j//46crv8WIDL/HRgn/zUrN/81LTj/CAgW/xggMf+Nmqr/8Pz///T+///7/v////7///7+/v/4////6v7//2N0d/9bVEP/4dG6//Pp1///+uz///rr//Xv3P/X07f/UFI+/2N2ef/q/v//+fz//////v////v/+////+7+//8AAQH////y////6/////T/+//1//r/9P////L////s////8f8AAgH/8f////z8/P///fr////+/////P///vz/DQYJ/9bZ6P/s+v//3Pj//9z+///d/v//4/3//+34///X2Ob/DgUI///7+f////z////8///8/f////z////4/9jJx/8UFij/X22D/4Sbqv+ows7/rcXR/4eaqf9lbYT/GBUl/9vJyP///fb///77/////v/9/v/////////89f////X/+Ovd/5SGdP9GOBz/SToa/0g5Gf9qXED/j39u//zs3/////X////5//37+//7/v//9/r+///+//////v////z////8P///+b///vZ///71v///Nf////k////5P////D///7x////+////v//+Pv////+///9/f3///7+/////v////r////5////+P////f////3////9/////n////7/////v/////////////+/////////vv9//38/v///v///f////z+///7////+/////v////4/P3//f////r8/f///v///v3////9/////////v3////+/////v////7////+///////////////9/f///f3////////////+/f///v3////+/////v////7//w4AAAAUAAAAAAAAABAAAAAUAAAA)

A

64К х8

ОЗУ

R/W D R/W

УВв №1

Регистр=порт

УВыв №1

Регитр=порт

ША 16 - разрядная

ШД 8 – разрядная двунаправленная

ШУ 10 - разрядная

Х1

F

MEMW

MEMR

IOR

IOW

Рис. 2. МП – система автоматической ОЖД.

Если в программе выполняется команда, требующая обращение к памяти, то на 16-разрядную шину адреса ША выставляется номер требуемой ячейки Aij, а на 10-разрядной шине управления ШУ формируются сигналы «читай память» MEMR или «пиши в память» MEMW, которые задают режим работы ОЗУ и направление передачи по двунаправленной 8-разрядной шине данных ШД. Если же программа выполнит программу INPUT (или OUTPUT), то на ША выдаётся номер устройства ввода (или вывода), а на ШУ формируются сигналы «ввод/вывод читай» IOR (или «ввод/вывод пиши» IOW).

«Портом» УВв №1 является 8-разрядный регистр-защёлка, у которого младший разряд хранящегося в нем числа определяется сигналом Х1, а сигнал IOR поступает на вход «разрешение выдачи» ОЕ. «Порт» УВыв №1 также является параллельным 8-рязрядным регистром, на тактовый вход которого поступает сигнал IOW. Само Увыв представляет собой 3-разрядный 7-сегментный индикатор (для отображения результата F) и соответствующий кодопреобразователь, включенный между портом и индикатором.

3. Процессор КР580ВМ80.

В состав данного 8-разрядного процессора (рис. 3) входит АЛУ и программно-доступные регистры: аккумулятор РОН А, 6 регистров общего назначения РОН (с «именем» B, C, D, E, H и L) и счётчик команд РС. АЛУ, получив от УУиС указания о типе выполняемой операции f над доставленными на его входе операндами х1 их2, формирует результат F=f(x1 x2) и «флаги» Ф (признаки нулевого – Z, отрицательного – S и чётного результат Р или наличие переноса С7). Существенно, что результат F всегда (по умолчанию) размещается в РОН А. Это означает, что, если содержимое РОН А не является операндом следующей команды, то при программировании её должна предшествовать дополнительная команда (которой нет в алгоритме обработки пользователя) перезаписи содержимого РОН А в свободный РОН или в ячейку М памяти ОЗУ (=Ме-точку). Для программировании операций с РОН каждому из них присвоен порядковый номер i и соответствующий индивидуальный двоичный код ri (табл. 1). Для хранения 16-разрядный чисел d16=adr РОНя могут объединяться в регистровые пары rp: BC=rpB, DE=rpD, HL=rpH.

8-разр. ШД

B……...(8)

C……...(8)D……...(8)E……...(8)H……...(8)

L……...(8)

SP (16)

PC (16)

Pr Agp(16)

РГК

ДШК

УУиС

(УА)

Буф Рг

Буф Рг

Буф. Pr

двунвправ.

f

X2

X1

АЛУ

Рез-т F

z

c

s

p

Блок регистров

Внутренняя 8-разрядная двунаправленная ШД

16 разр. ША

системная

системная

ГТИ

10-разрядная ШУ

системная

**КР 580ВМ80**

Рис. 3. Упрощёшшая модель микропроцессора КР580ВМ80

Нумерация РОН. Табл. 1

|  |  |  |
| --- | --- | --- |
| i | Имя РОН | Код ri |
| 0  1  2  3  4  5  6  7 | B  rp  C  D  rp  E  rp  H  L  M  A | 000  001  010  011  100  101  110  111 |

Указатель стека SP хранит текущий адрес ячейки ОЗУ, являющейся на данный момент вершиной стека.

Счётчик команд PC хранит адрес выполняемой (текущей) команды: после её завершения содержимое PC инкрементируется, т. е.PC![](data:image/x-wmf;base64,183GmgAAAAAAAOABYAEBCQAAAACQXgEACQAAA50AAAACABwAAAAAAAUAAAAJAgAAAAAFAAAAAgEBAAAABQAAAAEC////AAUAAAAuARgAAAAFAAAACwIAAAAABQAAAAwCYAHgARIAAAAmBg8AGgD/////AAAQAAAAwP///yYAAACgAQAAhgEAAAsAAAAmBg8ADABNYXRoVHlwZQAAMAAcAAAA+wKA/gAAAAAAAJABAAAAAgACABBTeW1ib2wAAI4PCvWg8RIA2J/zd+Gf83cgIPV3Zw5mrAQAAAAtAQAACAAAADIKAAE0AAEAAACseQoAAAAmBg8ACgD/////AQAAAAAAHAAAAPsCEAAHAAAAAAC8AgAAAMwBAgIiU3lzdGVtAABnDmasAAAKACEAigEAAAAA/////7zzEgAEAAAALQEBAAQAAADwAQAAAwAAAAAA)(PC) + 1, и через буферный PrАдр выдается на системную ША, а из ОЗУ (по сигналу MEM R) извлекается первый байт <B1> кода следующей команды из ячейки ОЗУ с номером (PC) + 1) и по системной шине ШД передается в регистр команд PrK.

Это означает, что в обычной ситуации процессор может выполнять команды программы только в том порядке, в котором они записаны в ОЗУ.

Чтобы изменить порядок выполнения команд (сделать скачок на несколько ячеек ОЗУ вперёд или назад, организовать ветвление или цикл, выполнить программу), необходимо в программу вставить команду безусловного или условного перехода, которая позволяет скачком менять содержимое (РС) счётчика команд РС.

Все регистры и АЛУ обмениваются между собой 8-разрядными данными d8 через внутреннюю двунаправленную ШД, однако на каждом такте обмен осуществляется только между одной парой «абонентов» (один - отправитель, другой – получатель).

Обмен между внутренней и внешней = системной ШД происходит через двунаправленный буферный регистр.

Каждая (текущая) команда программы (её код находится в PrK, а адрес в РС) выполняется процессором в течении определённого времени, называемого командным циклом продолжительностью от 1 до 4 тактов (при тактовой частоте 2 Mгц). В течении командного цикла устройство управления и синхронизации УуиС, будучи обычным управляющим автоматом (УА), декодирует с помощью дешифратора ДшК первый байт <B1> кода команды и в соответствии с этим кодом на каждом такте вырабатывает сигналы для внутреннего выполнения управлением микроопераций на «избранных» (на данном такте) функциональных узлах (регистрах, АЛУ, селекторе и др.), а также внешние управляющие сигналы (типа MEMR, MEMW, IOW и др.), выдаваемые на системную ШУ.

4. Система команд.

Каждый процессор умеет выполнять ограниченный набор «приказов», входящих в его систему команд. Каждая команда представляет собой многоразрядный двоичный код (от 8 до 24 бит) определённого формата. Для процессора КР580ВМ80 предусмотрены команды трёх форматов: «короткие» однобайтные <B1>, двухбайтные <B1><B2> и трёхбайтные <B1><B2><B3>. Первый байт <B1> команды любого формата содержит код операций Коп, второй <B2> - в двухбайтных командах содержит числовое значение непосредственно задаваемого операнда d8 или порядковый номер n устройства ввода/вывода = port n. Третий и второй байты «длинных» команд содержат либо численное значение 16-разрядного операнда d16, либо 16-разрядный адрес (“adr”): причем старший байт адреса/операнда размещается в <B3>, а младший в <B2>.

Ниже в таблице 2 приведены данные о наиболее ходовых командах процессора.

В таблице 2 поле 1 характеризует формат команды (в байтах), поле 2 – продолжительность командного цикла в количестве тактов; в поле 3 описывается (на языке микрокоманд) выполняемая операция: запись (ri) означает «содержимое» регистра ri, запись <Bi> - «содержимое байта Bi? (HL) – регистровой пары HL, а в поле 5 побитовая структура 1 – го байта <B1> кода команды.

В командах пересылке и загрузки (NN1 и 2) нужно учесть, что при ri = 110 в обмене участвует ячейка М ОЗУ, адрес которой (по умолчанию) хранится в регистровой паре HL. Это означает, что команда MOV и MVI обязательно должна предшествовать команда загрузки регистровой пары (HL![](data:image/x-wmf;base64,183GmgAAAAAAAOABYAEBCQAAAACQXgEACQAAA50AAAACABwAAAAAAAUAAAAJAgAAAAAFAAAAAgEBAAAABQAAAAEC////AAUAAAAuARgAAAAFAAAACwIAAAAABQAAAAwCYAHgARIAAAAmBg8AGgD/////AAAQAAAAwP///yYAAACgAQAAhgEAAAsAAAAmBg8ADABNYXRoVHlwZQAAMAAcAAAA+wKA/gAAAAAAAJABAAAAAgACABBTeW1ib2wAAA0PCglA8RIA2J/zd+Gf83cgIPV3JgJmYgQAAAAtAQAACAAAADIKAAE0AAEAAACseQoAAAAmBg8ACgD/////AQAAAAAAHAAAAPsCEAAHAAAAAAC8AgAAAMwBAgIiU3lzdGVtAAAmAmZiAAAKACEAigEAAAAA/////1zzEgAEAAAALQEBAAQAAADwAQAAAwAAAAAA)adr), т. е. команда LXI.

В ассемблерной записи команд NN3 и 21 фигурирует старший регистр ri (=B, D или H) регистровой пары rp. При выполнении двухоперандных команд (NN7 – 18) первые операнд x1 всегда берётся из РОН А, а второй x2 из другого РОНа или задается непосредственно во втором байте <B2> команды. Логические операции, в отличии от арифметических, выполняются поразрядно.

Для всех команд условного перехода (NN25 – 30) при невыполнении проверяемого условия в PC загружается адрес adr = (PC) + 3.

Система команд процессора КР580ВМ80. Табл.2

|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- | --- |
| NN  n/n | Ассемблерная запись команды | Формат  (байты) | | Такты | Выполняемая операция | | Форми-  руемые  флаги | Структура <B1>  (номера разрядов) | | | | | | | |
| Команды пересылке и загрузке | | | | | | | | | | | | | | | |
| 1.  2.  3.  4.  5.  6. | MOV\_ri,rj  MVI\_ri,d8  LXI\_ri,d16  XCHD  PCHL  SPHL | 1  2  3  1  1  1 | 5  7  10  4  5  5 | | | ri← (rj)  ri←B2>  ri←<B2>,ri+1←<B2>  (HL)↔(DE)  PC←(HL)  SP←(HL | нет  нет  нет  нет  нет  нет | 0  0  0  1  1  1 | 1  0  0  1  1  1 | ←  ←  ←  1  1  1 | ri  ri  ri  0  0  0 | →  →  →  1  1  1 | ←  1  0  0  0  0 | ri  1  0  1  0  0 | →  0  1  1  1  1 |
| Арифметические и логические операции | | | | | | | | | | | | | | | |
| 7.  8.  9.  10.  11.  12.  13.  14.  15.  16.  17.  18.  19. | ADD\_ ri  SUB\_ ri  ANA\_ ri  XRA\_ ri  ORA\_ ri  CMP\_ ri  ADI\_ d8  SUI\_ d8  ANI\_ d8  XRI\_ d8  ORI\_ d8  CPI\_ d8  SMA | 1  1  1  1  1  1  2  2  2  2  2  2  1 | 4  4  4  4  4  4  7  7  7  7  7  7  4 | | | A← (A) + (ri)  A← (A) - (ri)  A← (A) /\ (ri)  A← (A) + (ri)  A← (A) \/ (ri)  Сравн. A - (ri)  A← (A) + <B2>  A← (A) - <B2>  A← (A) /\ <B2>  A← (A) + <B2>  A← (A) \/ <B2>  Сравн. A - <B2>  A← (A) | все  все  z, s, p  z, s, p  z, s, p  все  все  все  z, s, p  z, s, p  z, s, p  все  нет | 1  1  1  1  1  1  1  1  1  1  1  1  0 | 0  0  0  0  0  0  1  1  1  1  1  1  0 | 0  0  1  1  1  1  0  0  1  1  1  1  1 | 0  1  0  0  1  1  0  1  0  0  1  1  0 | 0  0  0  1  0  1  0  0  0  1  0  1  1 | ←  ←  ←  ←  ←  ←  1  1  1  1  1  1  1 | ri  ri  ri  ri  ri  ri  1  1  1  1  1  1  1 | →  →  →  →  →  →  0  0  0  0  0  0  1 |
| Операции циклического сдвига и инкремента | | | | | | | | | | | | | | | |
| 20.  21.  22.  23 | INR\_ri  INX\_ri  RLC  RRC | 1  1  1  1 | 5  5  4  4 | | | ri ← (ri) + 1  rp← (rp) + 1  Ai+1←(Ai);A0←(A7);  C7←(A7)  Ai←(Ai+1);A7←(A0);  C7←(A0) | z, s, p  нет  С7  С7 | 0  0  0  0 | 0  0  0  0 | ←  ←  0  0 | ri  ri  0  0 | →  →  0  1 | 1  0  1  1 | 0  1  1  1 | 0  1  1  1 |
| Безусловный переход | | | | | | | | | | | | | | | |
| 24 | JMP\_adr | 3 | 10 | | | PC←<B3><B2> | нет | 1 | 1 | 0 | 0 | 0 | 0 | 1 | 1 |
| Условные переходы | | | | | | | | | | | | | | | |
| 25.  26.  27  28  29  30 | JNZ\_adr  JZ\_adr  JNC\_adr  JC\_adr  JP\_adr  JM\_adr | 3  3  3  3  3  3 | 10  10  10  10  10  10 | | | при z=0  PC←<B3><B2>  при z=1 …..|…..  при С7=0 …..|…..  при С7=1 …..|…..  при S=0 …..|…..  при S=1 …..|….. | нет  нет  нет  нет  нет  нет | 1  1  1  1  1  1 | 1  1  1  1  1  1 | 0  0  0  0  1  1 | 0  0  1  1  1  1 | 0  1  0  1  0  1 | 0  0  0  0  0  0 | 1  1  1  1  1  1 | 0  0  0  0  0  0 |
| Вспомогательные функции | | | | | | | | | | | | | | | |
| 31.  32.  33.  34. | IN\_port n  OUT\_port m  NOP  HLT | 2  2  1  1 | 10  10  4  7 | | | Ввод: А←(port n)  Вывод: А←(port m)  Нет операции  Остановка, стоп | нет  нет  нет  нет | 1  1  0  0 | 1  1  0  1 | 0  0  0  1 | 1  1  0  1 | 1  0  0  0 | 0  0  0  1 | 1  1  0  1 | 1  1  0  0 |

5. Разработка алгоритма

начало

A ← Увв№1

к1

A← (А) ^ maska

к2

Z=0

к3

да

M1:

HL ← Aпред

к4

E ← M[HL]

к5

C ← 0

к6

HL ← (HL)+1

к7

C ← C+1

к8

A ← (C)

к9

Срав.(А) - Кrp

к10

Krp = O5(16) = <B2>

S=0

к11

A ← (E)

к17

УВыв№1 ← (А)

к18

stop

к19

A ← M[HL]

Срав.(А) - E

к13

к12

M2:

S=0

к14

E ← (A)

к15

да (Kt > Krp)

нет (Kt > Krp)

да (gt<gmin)

нет (gt>gmin)

Рис.4. Блок – схема алгоритма обработки журнальных записей.

Алгоритм обработки предписывает поочередное чтение из ОЗУ показаний gt из ячеек с адресами At, попарное сравнение их по величине и запоминание меньшего из них. Блок – схема алгоритма приведена на рис. 4 и содержит 19 команд к1…к19: здесь формируемая величина gmin размещена в РОН Е, текущий адрес Аt = Aпред + ∆At – в регистровой паре HL, а приращение адреса ∆At = kt является параметром цикла обработки и размещается в РОН С; максимальное (=граничное) приращение krp = N = 5 является индикатором окончания цикла анализа данных gt из журнального файла G.

На блок-схеме рис.4:

* команды к1…к3 обеспечивают анализ вводимого с ПЭК сигнала х1 и принятие решения о конце суточного цикла сбора данных и начла обработки файла G; численное значении маски 01(16) гарантирует анализ младшего бита содержимого РОН А;
* команда к4 загружает адрес предпоследнего сеанса Апред в регистровую пару HL;
* команда к5 считывает первый «отсчёт» предпоследнего сеанса g0 из файла G и, записав его в РОН Е, объявляет его равным gmin;
* команда к6 заносит начальное значение Kt = 0 в РОН С; вместе к4…к6 обеспечивают подготовку цикла к7…к15 анализа G;
* команды к7, к8 обеспечивают инкремент текущего адреса At и приращение адреса Kt;
* команды к9 – к11 на основе сравнения kt c krp = 05 обеспечивают выход из цикла обработки и выдачу на индикацию через УВыв№1 рассчитанного значения gmin из РОН Е (к17, к18);
* команда к12 загружает в РОН А текущий отсчёт gt из ячейки M ОЗУ с адресом At (сформированным в регистровой паре HL);
* команды к13 и к14 обеспечивают сравнение текущего отсчёта gt с gmin и при появлении gt<gmin перезапись его в РОН Е (к15);
* команда к16 обеспечивает безусловный переход (БП) на метку М3.

В таблице 3 (в полях 2-6) приведена ассемблерная запись программы, реализующий этот алгоритм. Из неё видно, что для размещения загрузочного модуля (в двоичных кодах) этой программы необходимо 34 байта (ячейки ОЗУ).

Сам загрузочный модуль представлен полями 0 и 1таблицы 3, но для простоты и кратности записан в 16-ричных кодах (h-кодах): коды первых байтов взяты из таблицы 2, а числовые значения <B3> и <B2>, а также начального адреса предпоследнего сеанса FA25(16) для размещения программы в ОЗУ устанавливаются по исходным данным задачи.

Текст программы на ассемблере и её загрузочные модуль (в h-кодах). Табл.3

|  |  |  |  |  |  |  |  |
| --- | --- | --- | --- | --- | --- | --- | --- |
| Мет-  ки | Адрес ОЗУ | h-коды | NN  коман-  ды | Ассемблер | Комментарий | Бай-  ты | Так-  ты |
| 0 | 1 | 2 | 3 | 4 | 5 | 6 |
| М1 | FA25  FA26 | <B1>DB  <B2>01 | K1 | IN\_00 | A←(port 0) | 2 | 10 |
| FA27  FA28 | <B1>E6  <B2>01 | K2 | ANI\_01 | A←(A)^maska  maska = 01h | 2 | 7 |
| FA29  FA2A  FA2B | <B1>C2  <B2>89  <B3>FE | K3 | JNZ\_M1: | Усл. Переход (УП) по условию Х1 = 0  («обработку начать») | 3 | 10 |
| FA2C  FA2D  FA2E | <B1>21  <B2>86  <B3>26 | K4 | LXI\_H,08B1 | HL←Апред  (Апред = adr = 08B1 | 3 | 10 |
| FA2F | <B1>5E | K5 | MOV\_E,M | E←gt (из ОЗУ) | 1 | 5 |
| FA30  FA31 | <B1>0E  <B2>00 | K6 | MVI\_C,00 | С←0 (At:=0) | 2 | 7 |
| M2 | FA32 | <B1>23 | K7 | INX\_H | HL←(HL)+1  инкремент At | 1 | 5 |
| FA33 | <B1>0C | K8 | INR\_C | C←(C)+1(инкр. Kt) | 1 | 5 |
| FA34 | <B1>79 | K9 | MOV\_A,C | А←С | 1 | 5 |
| FA35  FA36 | <B1>FE  <B2>0D | K10 | CPI\_0C | Сравнение(А) с Krp=05 | 2 | 7 |
| FA37  FA38  FA39 | <B1>F2  <B2>A7  <B3>FE | K11 | JP\_M2: | УП на метку М2  («конец файла G») | 3 | 10 |
| FA3A | <B1>7E | K12 | MOV\_A,M | А←gt (из ОЗУ) | 1 | 5 |
| FA3B | <B1>BB | K13 | CMP\_E | Сравнение (А) и gmin | 1 | 4 |
| FA3C  FA3D  FA3E | <B1>F2  <B2>96  <B3>FE | K14 | JP\_M3: | УП на метку М3  («новый отсчёт gt меньше, чем gmin?») | 3 | 10 |
| FA3F | <B1>5F | K15 | MOV\_E,A | Сохранить gt в РОН E | 1 | 5 |
| FA40  FA41  FA42 | <B1>C3  <B2>98  <B3>FE | K16 | JMP\_M3: | Безусл. Переход (БП)  на метку М3  (PC) ←<B3><B2> | 3 | 10 |
| M2 | FA43 | <B1>7B | K17 | MOV\_A,E | A←(E) | 1 | 5 |
| FA44  FA45 | <B1>D3  <B2>01 | K18 | OUT\_01 | Выдать gmin на индикацию через Увыв №1 | 2 | 10 |
| FA46 | <B1>76 | K19 | HLT | Стоп | 1 | 7 |