Команда CLR (Clear Register)
Синтаксис: CLR Rd
где 16 < d < 31
Команда установки значения логического «нет» (нуля) во все биты регистра приёмника. В регистр приёмник заносится шестнадцатеричная константа 00. Устанавливает флаги Z, N, V регистра флагов.
Пример:
clr r16 ; Обнулить/очистить содержимое регистра r16
Команда SER (Set Register)
Синтаксис: SER Rd
где 16 < d < 31
Команда установки значения логического «да» (единицы) во все биты регистра приёмника. Иначе: в регистр приёмник заносится шестнадцатеричная константа FF.
Пример:
ser r16 ; Установить содержимое регистра r16 ;равным FF (11111111)
Команда COM
Синтаксис: COM Rd
где 0 < d < 31
Команда получения в регистре приёмнике единичного дополнения, хранящегося в регистре приёмнике путём вычитания шестнадцатеричного значения регистра приёмника из FF: Rd ß SFF – Rd, где S – флаг знака. Устанавливает флаги C, Z, N, V регистра флагов.
Пример:
com r16 ; Преобразовать содержимое регистра r16 в ;единичное дополнение
Команда NEG
Синтаксис: NEG Rd
где 0 < d < 31
Команда изменения знака значения регистра приёмника путём вычитания шестнадцатеричного значения регистра приёмника из нуля. Иначе: получение в регистре приёмнике двоичного дополнения, хранимого в нём ранее значения: Rd ß S00 – Rd, где S – флаг знака. Устанавливает флаги C, Z, N, V, H регистра флагов.
Пример:
neg r24 ; Преобразовать и установить содержимое ;регистра r24 отрицательным значением
Команда SBR
Синтаксис: SBR Rd, K
где 16 < d < 31, 0 < K < 255
Команда установки поименованных битов в регистре приёмнике (остальные биты команда не трогает). Обозначаются биты за счёт шестнадцатеричной константы. Так 06h (0000 0110d) соответствует установке 1-го и 2-го младших байтов (нумерация битов начинается с нуля), а 41h (0100 0001d) установке 0-го младшего и 2-го старшего байтов. Команда SBR формально записывается так: Rd ß Rd v K. Устанавливает флаги Z, N, V регистра флагов.
Пример:
sbr r19, $06 ; Установить в регистре r19 2й и 3й ;биты.
sbr r17, $41 ; Установить в регистре r17 1й и 7й
;биты
Команда CBR
Синтаксис: CBR Rd, K
где 16 < d < 31, 0 < K < 255
Команда очистки поименованных битов в регистре ( на остальные биты команда не влияет). Обозначаются биты для сброса за счёт шестнадцатеричной константы. Так 03h (0000 0011d) соответствует сбросу 0-го и 1-го бита. Формально записывается так Rd ß Rd • (SFF – K), где S – флаг знака. Устанавливает флаги Z, N, V регистра флагов.
Пример:
cbr r18, $03 ; Очистить в регистре r18 0-ой и 1ый
;биты.
Команда SEC (Set Carry flag)
Синтаксис: SEC
Команда установки флага переноса (флаг переноса принимает значение логического «да»): C=1.
Команда CLC (Clear Carry flag)
Синтаксис: CLC
Команда очистки флага переноса (флаг переноса принимает значение логического «нет»): C = 0.
Команда SEN (Set Negative flag)
Синтаксис: SEN
Команда установки флага отрицательного значения (флагу отрицательного значения присваивается логическое «да»). N =1.
Команда CLN (Clear Negative flag)
Синтаксис: CLN
Команда очистки флага отрицательного значения (флагу отрицательного значения присваивается логическое «нет»). N = 0.
Команда SEZ (Set Zero flag)
Синтаксис: SEZ
Команда установки флага нулевого значения (флагу нулевого значения присваивается логическое «да»). Z =1.
Команда CLZ (Clear Zero flag)
Синтаксис: CLZ
Команда очистки флага нулевого значения (флагу нулевого значения присваивается логическое «нет»). Z =0.
Команды SEI, CLI (Clear Interrupt flag), SES (Set Sign flag), CLS (Clear Sign flag), SEV (Set oVerflow flag), CLV (Clear oVerflow flag), SET (Set Temporary flag), CLT (Clear Temporary flag), SEH (Set Half-carry flag), CLH (Clear Half-carry flag) аналогичны вышерассмотренным командам, устанавливают флаги (=1) или сбрасывают (=0)(см таблицу…).
Команда BSET (Bit Set)
Синтаксис: BSET n
где 0 < n < 7
Команда установки того или иного флага через соответствующий бит регистра SREG (статусный регистр).
Пример:
bset 2 ; Установить второй бит регистра SREG
;(флаг отрицательного значения N)
Команда BCLR (Bit Clear)
Синтаксис: BCLR n
где 0 < n < 7
Команда очистки того или иного флага через соответствующий бит регистра SREG (статусный регистр).
Пример:
bclr 4 ; Установить четвертый бит регистра SREG (флаг
;знака S)
Команда BST
Синтаксис: BST Rd, n
где 0 < d < 31, 0 < n < 7
Команда установки в пользовательский флаг значения, равного указанному биту значения, хранящегося в регистре приёмнике.
Пример:
bst r3, 3 ; Записать во флаг T то же значение, что
;и в третьем бите (0000x000) регистра r3
Команда BLD
Синтаксис: BLD Rd, n
где 0 < d < 31, 0 < n < 7
Команда установки значения пользовательского флага в указанный бит значения, хранящегося в регистре приёмнике.
Пример:
bld r5, 6 ; Записать в шестой бит регистра r5 ;(0x000000) то же значение, что хранится во флаге T
Команда SBI
Синтаксис: SBI IO, n
где 0 < n < 7
Команда установки указанного бита в регистре I/O (ввода/вывода).
Пример:
sbi pinc, 4 ;
Команда CBI
Синтаксис: CBI IO, n
где 0 < n < 7
Команда очистки указанного бита в регистре I/O (ввода/вывода).
Пример:
cbi pina, 7 ;
Команда LSL (Logical Shift Left)
Синтаксис: LSL Rd
где 0 < d < 31
Команда осуществляет логический сдвиг влево содержимого казанного регистра Rd. При этом старший бит старшего байта записывается во флаг переноса, последовательность сдвигается побитово влево и в младший бит младшего байта записывается ноль (см. рисунок 2). Устанавливает флаги Z, C, N, V, H регистра флагов.
Рисунок 2
Команда LSR (Logical Shift Right)
Синтаксис: LSR Rd
где 0 < d < 31
Команда осуществляет логический сдвиг вправо содержимого регистра Rd. При этом младший бит младшего байта записывается во флаг переноса, последовательность сдвигается побитово вправо и в старший бит старшего байта записывается ноль (см. рисунок 3). Устанавливает флаги Z, C, N, V, H регистра флагов.
Рисунок 3
Команда ROL (Rotate Left)
Синтаксис: ROL Rd
где 0 < d < 31
Команда осуществляет циклический (логического через флаг переноса) сдвиг влево содержимого регистра Rd. При этом старший бит старшего байта записывается во флаг переноса, последовательность сдвигается побитово влево, и во младший бит младшего байта заносится значение, записанное во флаге переноса (см. рисунок 4). Устанавливает флаги Z, C, N, V, H регистра флагов.
Рисунок 4
Команда ROR (Rotate Right)
Синтаксис: ROL Rd
где 0 < d < 31
Команда осуществляет циклический (логического через флаг переноса) сдвиг вправо содержимого регистра Rd. При этом младший бит младшего байта записывается во флаг переноса, последовательность сдвигается побитово вправо, и в старший бит старшего байта заносится значение, записанное во флаге переноса (см. рисунок 5). Устанавливает флаги Z, C, N, V регистра флагов.
Рисунок 5
Команда ASR (Arithmetical Shift Right)
Синтаксис: ASR Rd
где 0 < d < 31
Команда выполняет арифметический сдвиг вправо содержимого регистра Rd (см. рисунок 6). Устанавливает флаги Z, C, N, V регистра флагов.
Рисунок 6
Команда SWAP
Синтаксис: SWAP Rd
где 0 < d < 31
Команда обмена нибблов (старших и младших разрядов) значения, хранящегося в регистре приёмнике (см. рисунок 7).
Рисунок 7
Дата: 2018-12-28, просмотров: 326.