Описание:
Выполнение сдвига всех битов Rd на одно место влево. Бит 0 стирается. Бит 7 загружается во флаг переноса (С) регистра состояния (SREG). Эта команда эффективно умножает на два значение величины без знака.
Операция:
(i) | |||
Синтаксис | Операнды: | Счетчик программ: | |
(i) | LSL Rd | 0 < d < 31 | PC <-- PC + 1 |
16-разрядный код операции:
0000 | 11dd | dddd | dddd |
Булевы выражения регистра статуса (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