Команда LSL - логически сдвинуть влево
Описание:
Выполнение сдвига всех битов Rd на одно место влево. Бит 0 стирается. Бит 7 загружается во флаг переноса (С) регистра состояния (SREG). Эта команда эффективно умножает на два значение величины без знака.
Операция:
(i) |
|
|
|
Синтаксис |
Операнды: |
Счетчик программ: |
(i) |
LSL Rd |
0 < d < 31 |
PC <-- PC + 1 |
16-разрядный код операции:
Булевы выражения регистра статуса (SREG)
H: |
Rd3 |
S: |
NЕV, Для проверок со знаком |
V: |
NЕC (Для N и C после сдвига)
Устанавливается если (N устанавливается и C очищается) или (N очищается
а C устанавливается). В ином случае очищается (при наличии значений N и
C после сдвига) |
N: |
R7 Устанавливается если в результате установлен MSB, в ином случае очищается |
Z: |
R7*R6*R5*R4*R3*R2*R1*R0
Устанавливается если результат $00, в ином случае очищается |
C: |
Rd7
Устанавливается если перед сдвигом был установлен MSB регистра Rd в
ином случае очищается |
R: |
(Результат)соответствует Rd после выполнения команды |
Пример:
add r0, r4 ; Сложить r4 с r0
lsl r0 ; Умножить r0 на 2
Слов: 1 (2 байта)
Циклов: 1
|