Motorola MC68HC705C8

Информация - Радиоэлектроника

Другие материалы по предмету Радиоэлектроника

?есации.

Регистр условий не изменяется.

 

SWIПрограммное прерывание

(PC)(PC)+$0001В PC адрес возврата

(PCL); SP(SP)-$0001В стек младший байт адреса возврата

(PCH); SP(SP)-$0001В стек старший байт адреса возврата

(X); SP(SP)-$0001В стек индексный регистр

(AC); SP(SP)-$0001В стек аккумулятор

(CCR); SP(SP)-$0001В стек регистр признаков

I бит 1

PCH($xFFC)Вектор прерывания (x=1 или 3, в зависимости от версии HC05)

PCL($xFFD)

Содержимое программного счетчика увеличивается на единицу. Программный счетчик, индексный регистр, аккумулятор и регистр признаков помещаются в стек. Содержимое указателя стека уменьшается на единицу каждый раз после того, как в стек помещен байт. Бит маскирования прерываний устанавливается в единицу. В программный счетчик записывается адрес, хранящийся в векторе прерывания SWI (адрес расположен по адресу n-0002 и n-0003, где n-адрес, соответствующий единичному состоянию всех адресных выходов миропроцессора.). Команда SWI не маскируется установкой бита I регистра признаков.

IУстанавливается в 1.

 

RTIВозврат из подпрограммы обработки прерывания

SP(SP)+$0001 ССRCCR из стека

SP(SP)+$0001 ACAC из стека

SP(SP)+$0001 XX из стека

SP(SP)+$0001 PCHPCH из стека

SP(SP)+$0001 PCLPCL из стека

Регистр признаков, аккумулятор, индексный регистр и программный счетчик восстанавливаются из стека. Бит I сбрасывается, если соответствующий бит регистра признаков в стеке был нулевым.

Биты регистра признаков принимают значения в соответствии с байтом, взятым из стека.

 

RTSВозврат из подпрограммы

SP(SP)+$0001 PCHPCH из стека

SP(SP)+$0001 PCLPCL из стека

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

Регистр признаков не изменяется.

 

 

Арифметические и логические команды, битовые операции.

ADDСложить содержимое ячейки памяти с аккумулятором

AC(AC)+(M)

Сложить содержимое M и содержимое AC и разместить в AC.

HA3*M3+M3*R3\+R3\*A3

Устанавливается, если имеет место перенос из бита 3, иначе сбрасывается.

NR7

Устанавливается, если старший бит результата установлен, иначе сбрасывается.

ZR7\*R6\*R5\*R4\*R3\*R2\*R1\*R0\

Устанавливается, если все битв результата сброшены. Иначе сбрасывается.

CA7*M7+M7*R7\+R7\*A7

Устанавливается, если имеет место перенос из старшего бита результата, иначе сбрасывается.

 

ADCСложить содержимое ячейки памяти с аккумулятором
и флагом переноса.

AC(AC)+(M)+(C)

Сложить содержимое бита C и сумму содержимого M и содержимого AC и разместить в AC.

HA3*M3+M3*R3\+R3\*A3

Устанавливается, если имеет место перенос из бита 3, иначе сбрасывается.

NR7

Устанавливается, если старший бит результата установлен, иначе сбрасывается.

ZR7\*R6\*R5\*R4\*R3\*R2\*R1\*R0\

Устанавливается, если все битв результата сброшены. Иначе сбрасывается.

CA7*M7+M7*R7\+R7\*A7

Устанавливается, если имеет место перенос из старшего бита результата, иначе сбрасывается.

 

SUBВычесть.

AC(AC)-(M)

Вычесть содержимое M из AC и разместить результат в AC.

NR7

Устанавливается, если старший бит результата установлен, иначе сбрасывается.

ZR7\*R6\*R5\*R4\*R3\*R2\*R1\*R0\

Устанавливается, если все битв результата сброшены. Иначе сбрасывается.

CA7*M7+M7*R7\+R7\*A7

Устанавливается, если абсолютная величина содержимого M больше абсолютной величины аккумулятора, иначе сбрасывается.

 

SBCВычесть содержимое ячейки памяти из аккумуляторе
с флагом заема.

AC(AC)-(M)-(C)

Вычесть содержимое M из AC и разместить результат в AC.

NR7

Устанавливается, если старший бит результата установлен, иначе сбрасывается.

ZR7\*R6\*R5\*R4\*R3\*R2\*R1\*R0\

Устанавливается, если все битв результата сброшены. Иначе сбрасывается.

CA7*M7+M7*R7\+R7\*A7

Устанавливается, если абсолютная величина одержимого M, плюс предыдущее значение C, больше абсолютной величины аккумулятора, иначе сбрасывается.

 

ANDОперация И содержимого ячейки памяти и аккумулятора.

AC(AC)*(M)

Произвести логическое умножение между содержимым аккумулятора и содержимым M и разместить результата в AC. (С каждым битом аккумулятора и соответствующим битом M производится операция логического умножения).

NR7

Устанавливается, если старший бит результата установлен, иначе сбрасывается.

ZR7\*R6\*R5\*R4\*R3\*R2\*R1\*R0\

Устанавливается, если все битв результата сброшены. Иначе сбрасывается.

 

ORAОперация ИЛИ содержимого ячейки памяти и аккумулятора.

AC(AC)+(M)

Произвести логическое сложение между содержимым аккумулятора и содержимым M и разместить результата в AC. (С каждый бит аккумулятора и соответствующим битом M производится операция логического сложения).

NR7

Устанавливается, если старший бит результата установлен, иначе сбрасывается.

ZR7\*R6\*R5\*R4\*R3\*R2\*R1\*R0\

Устанавливается, если все битв результата сброшены, иначе сбрасывается.

 

CMPАрифметическое сравнение аккумулятора и ячейки памяти.

(AC)-(M)

Сравнить содержимое M и AC и установить биты в регистре признаков. Содержимое AC и M не изменяется.

NR7

Устанавливается, если старший бит результата установлен, иначе сбрасывается.

ZR7\*R6\*R5\*R4\*R3\*R2\*R1\*R0\

Устанавливается, если все битв результата сброшены. Иначе сбрас