Команды сдвигов и операций с битами
Поможем в ✍️ написании учебной работы
Поможем с курсовой, контрольной, дипломной, рефератом, отчетом по практике, научно-исследовательской и любой другой работой

Команда 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.