- •Введение
- •Устройства ввода/вывода aTmega8535
- •1.3. Система команд микроконтроллера
- •1.3.1 Команды пересылки данных
- •1.3.2 Арифметические команды
- •1.3.3. Команды умножения
- •1.3.4 Команды сравнения
- •1.3.5 Логические команды
- •1.3.6 Команды сдвигов и операций с битами
- •1.3.7 Команды безусловного перехода
- •1.3.8 Команды обращения к процедурам
- •1.3.9 Команды условного перехода
- •Порядок выполнения лабораторных работ
- •Регистры, данные и команды пересылки данных Цель работы
- •Постановка задачи
- •Лабораторная работа №2. Арифметические команды Цель работы
- •Постановка задачи
- •Лабораторная работа №3. Логические команды и команды манипулирования битами Цель работы
- •Постановка задачи
1.3.7 Команды безусловного перехода
Команда RJMP
Синтаксис: RJMP n
где -2048 < n < 2048 (-2K < n < 2K)
Команда относительного перехода через n+1 команду. Переход можно осуществить не более чем на 2048 команд в обе стороны.
Пример:
rjmp Init ; Перейти к адресу с меткой Init, ;находящемуся в пределах двух килобайт от ;текущей позиции.
Команда IJMP
Синтаксис: IJMP
Команда косвенного перехода к адресу, записанному в регистровой паре Z. Под регистровой парой Z тут нужно понимать 30-й и 31-й регистры.
Команда JMP
Синтаксис: JMP addr
где 0 < addr < 4 000 000 (0 < addr < 4M)
Команда прямого перехода к указанному адресу.
Пример:
jmp Init ; Перейти к адресу с меткой Init
1.3.8 Команды обращения к процедурам
Команда RCALL
Синтаксис: RCALL n
где -2048 < n < 2048 (-2K < n < 2K)
Команда относительного вызова подпрограммы, расположенной через n+1 команду от текущей позиции. Переход можно осуществить не более чем на 2048 команд в обе стороны.
Пример:
rcall Init ; Вызвать процедуру Init, находящуюся по ;адресу, расположенному в пределах двух ;килобайт от текущей позиции.
Команда ICALL
Синтаксис: ICALL
Команда косвенного вызова процедуры через регистровую пару Z. Под регистровой парой Z понимается 30-й и 31-й регистры.
Команда CALL
Синтаксис: CALL addr
где 0 < addr < 4 000 000 (0 < addr < 4M)
Команда непосредственного вызова процедуры по её стартовому адресу. Позиция вызова заносится в стек. Важно:
1. Процедура обязательно должна быть завершена командой RET.
2. Стек имеет конечный объем, потому в случае рекуррентных процедур нужно тщательно планировать вычислительный процесс, избегая переполнения стека.
Пример:
call my_proc ; Вызов процедуры, находящейся по
; адресу с меткой «my_proc».
Команда RET
Синтаксис: RET
Команда возврата из процедуры к позиции, записанной в стек при вызове.
Команда RETI
Синтаксис: RET
Команда возврата из глобального прерывания к позиции, записанной в стек при возникновении прерывания. Устанавливает или сбрасывает флаг I регистра флагов.
1.3.9 Команды условного перехода
Команда CPSE
Синтаксис: CPSE Rd, Rr
где 0 < d < 31, 0 < r < 31
Команда межрегистрового сравнения и перехода через последующую команду, в случае равенства содержимого регистра источнике и регистра приёмнике.
Пример:
cpse r28, r30 ; Перешагнуть следующую команду, ;если содержимое r28 = r30
Команда SBRC
Синтаксис: SBRC Rd, n
где 0 < d < 31, 0 < n < 7
Команда перехода через последующую команду, в случае, когда указанный бит в регистре приёмнике сброшен (равен нулю).
Пример:
sbrc r0, 2 ;Перешагнуть следующую команду в ;случае, когда содержимое r0 вида xxxxx0xx
Команда SBRS
Синтаксис: SBRS Rd, n
где 0 < d < 31, 0 < n < 7
Команда перехода через последующую команду, в случае, когда указанный бит в регистре приёмнике установлен (равен единице).
Пример:
sbrs r30, 5 ;Перешагнуть следующую команду в случае,
;когда в регистре r30 установлен 5й бит.
Команда SBIC
Синтаксис: SBIC Rd, n
где 0 < d < 31, 0 < n < 7
Команда перехода через последующую команду, в случае, когда указанный бит в регистре I/O сброшен (равен нулю).
Пример:
sbic pina, 5 ; Перешагнуть следующую команду в ;случае, когда порт А содержит ;последовательность вида xx0xxxxx
Команда SBIS
Синтаксис: SBIS Rd, n
где 0 < d < 31, 0 < n < 7
Команда перехода через последующую команду, в случае, когда указанный бит в регистре I/O установлен (равен единице).
Пример:
sbis pinb, 3 ; Перешагнуть следующую команду в ;случае, когда порт B содержит ;последовательность вида xxxx1xxx
Команда BRBS
Синтаксис: BRBS s, k
где 0 < s < 7, -64 < k < 63
Команда относительного перехода через k+1 команду, в случае, если указанный флаг статусного регистра установлен (равен единице). Переходить можно не более чем на 63 команды вперёд или на 64 команды назад, относительно текущей позиции курсора.
Пример:
brbs 3, Exit ; Переход на метку Exit, находящуюся в ;пределах 64 команд в случае, когда ;установлен флаг переполнения
Команда BRBC
Синтаксис: BRBC s, k
где 0 < s < 7, -64 < k < 63
Команда относительного перехода через k+1 команду, в случае, если указанный флаг статусного регистра сброшен (равен нулю). Переходить можно не более чем на 63 команды вперёд или на 64 команды назад, относительно текущей позиции курсора.
Пример:
brbc 1, Exit ; Переход на метку Exit, находящуюся в ;пределах 64 команд в случае, когда ;сброшен флаг нулевого значения
Команда BREQ
Синтаксис: BREQ n
где -64 < n < 63
Команда относительного перехода через n+1 команду, если в результате выполнения предыдущей команды флаг нулевого значения установлен в единицу. Переходить можно не более чем на 63 команды вперёд или на 64 команды назад, относительно текущей позиции курсора.
Команда BRNE
Синтаксис: BRNE n
где -64 < n < 63
Команда относительного перехода через n+1 команду, в случае, если после выполнения предыдущей команды флаг нулевого значения сброшен, т.е. равен нулю. Переходить можно не более чем на 63 команды вперёд или на 64 команды назад, относительно текущей позиции курсора.
Команда BRCS
Синтаксис: BRCS n
где -64 < n < 63
Команда относительного перехода через n+1 команду, в случае, если установлен (равен единице) флаг переноса. Переходить можно не более чем на 63 команды вперёд или на 64 команды назад, относительно текущей позиции курсора.
Команда BRCC
Синтаксис: BRCC n
где -64 < n < 63
Команда относительного перехода через n+1 команду, в случае, если сброшен (равен нулю) флаг переноса. Переходить можно не более чем на 63 команды вперёд или на 64 команды назад, относительно текущей позиции курсора.
Команда BRSH
Синтаксис: BRSH n
где -64 < n < 63
Команда относительного перехода через n+1 команду, в случае, если после выполнения предыдущей команды сброшен флаг переноса (равный нулю). Переходить можно не более чем на 63 команды вперёд или на 64 команды назад, относительно текущей позиции курсора.
Команда BRLO
Синтаксис: BRLO n
где -64 < n < 63
Команда относительного перехода через n+1 команду, в случае, если после выполнения предыдущей команды установлен (равен единице) флаг переноса. Переходить можно не более чем на 63 команды вперёд или на 64 команды назад, относительно текущей позиции курсора.
Команда BRMI
Синтаксис: BRMI n
где -64 < n < 63
Команда относительного перехода через n+1 команду, в случае, если установлен (равен единице) флаг отрицательного значения. Переходить можно не более чем на 63 команды вперёд или на 64 команды назад, относительно текущей позиции курсора.
Команда BRPL
Синтаксис: BRPL n
где -64 < n < 63
Команда относительного перехода через n+1 команду, в случае, если сброшен (равен нулю) флаг переноса. Переходить можно не более чем на 63 команды вперёд или на 64 команды назад, относительно текущей позиции курсора.
Команда BRGE
Синтаксис: BRGE n
где -64 < n < 63
Команда относительного перехода через n+1 команду, в случае, если после выполнения предыдущей команды по предыдущей команде. Определяющую роль играет равенство нулю суммы по модулю 2 флагов отрицательного значения и переполнения. Переходить можно не более чем на 63 команды вперёд или на 64 команды назад, относительно текущей позиции курсора.
Команда BRLT
Синтаксис: BRLT n
где -64 < n < 63
Команда относительного перехода через n+1 команду, в случае, если после выполнения предыдущей команды установлен флаг знака (S) регистра статуса. Переходить можно не более чем на 63 команды вперёд или на 64 команды назад, относительно текущей позиции курсора.
Команда BRHS
Синтаксис: BRHS n
где -64 < n < 63
Команда относительного перехода через n+1 команду, в случае, если установлен (равен единице) флаг половинного переноса. Переходить можно не более чем на 63 команды вперёд или на 64 команды назад, относительно текущей позиции курсора.
Команда BRHC
Синтаксис: BRHC n
где -64 < n < 63
Команда относительного перехода через n+1 команду, в случае, если сброшен (равен нулю) флаг половинного переноса. Переходить можно не более чем на 63 команды вперёд или на 64 команды назад, относительно текущей позиции курсора.
Команда BRTS
Синтаксис: BRTS n
где -64 < n < 63
Команда относительного перехода через n+1 команду, в случае, если установлен (равен единице) пользовательский флаг. Переходить можно не более чем на 63 команды вперёд или на 64 команды назад, относительно текущей позиции курсора.
Команда BRTC
Синтаксис: BRTC n
где -64 < n < 63
Команда относительного перехода через n+1 команду, в случае, если сброшен (равен нулю) пользовательский флаг. Переходить можно не более чем на 63 команды вперёд или на 64 команды назад, относительно текущей позиции курсора.
Команда BRVS
Синтаксис: BRVS n
где -64 < n < 63
Команда относительного перехода через n+1 команду, в случае, если установлен (равен единице) флаг переполнения. Переходить можно не более чем на 63 команды вперёд или на 64 команды назад, относительно текущей позиции курсора.
Команда BRVC
Синтаксис: BRVC n
где -64 < n < 63
Команда относительного перехода через n+1 команду, в случае, если сброшен (равен нулю) флаг переполнения. Переходить можно не более чем на 63 команды вперёд или на 64 команды назад, относительно текущей позиции курсора.
Команда BRIE
Синтаксис: BRIE n
где -64 < n < 63
Команда относительного перехода через n+1 команду, в случае, если установлен (равен единице) флаг глобального прерывания, то есть прерывание разрешено. Переходить можно не более чем на 63 команды вперёд или на 64 команды назад, относительно текущей позиции курсора.
Команда BRID
Синтаксис: BRID n
где -64 < n < 63
Команда относительного перехода через n+1 команду, в случае, если сброшен (равен нулю) флаг глобального прерывания, то есть прерывание запрещено. Переходить можно не более чем на 63 команды вперёд или на 64 команды назад, относительно текущей позиции курсора.
Создание программ на языке Ассемблера
Исходный файл, написанный на языке ассемблера, содержит мнемоники, директивы и метки.
Перед каждой строкой программы ставится метка, которая является алфавитно-цифровой строкой, заканчивающейся двоеточием. Метки используются как указания для безусловного перехода и команд условного перехода.
Строкой программы может быть директива, команда, комментарий. Допускается пустая строка в программе.
Комментарий имеет следующую форму:
; [Текст]
Любой текст после символа “ ; ” игнорируется ассемблером и имеет значение только для пользователя.
Операнды можно задавать в различных форматах:
- десятичный (по умолчанию): 10, 255
- шестнадцатеричный (два способа): 00а, $0а
- двоичный: 0b00001010, 0b11111111
- восьмеричный (впереди ноль): 010, 077
Директивы:
Директивой называются управляющими указаниями для программы ассемблера. Она не транслируется в код, как это делает команда. Они инициализируют участки памяти, определяют константы в памяти, устанавливают счетчик команд на определенный адрес и т.д.
Все директивы ассемблера приведены в табл. 6.
Таблица 6. Директивы ассемблера
Директива |
Описание |
BYTE |
Зарезервировать байт под переменную |
CSEG |
Сегмент кодов |
DB |
Задать постоянным(и) байт(ы) в памяти |
DEF |
Задать символическое имя регистру |
DEVICE |
Задать для какого типа микроконтроллера компилировать |
DSEG |
Сегмент данных |
DW |
Задать постоянное(ые) слово(а) в памяти |
EQU |
Установите символ равный выражению |
ESEG |
Сегмент EEPROM |
EXIT |
Выход из файла |
INCLUDE |
Включить исходный код из другого файла |
LIST |
Включить генерацию .lst - файла |
NOLIST |
Выключить генерацию .lst - файла |
ORG |
Начальный адрес программы |
SET |
Установите символ равный выражению |
Синтаксис всех директив следующий:
.[директива]
То есть перед директивой должна стоять точка. Иначе ассемблер воспринимает это как метку.
Директива CSEG (Code segment) указывает на начало сегмента кодов. Ассемблируемый файл может иметь несколько кодовых сегментов, которые будут объединены в один при ассемблировании.
Синтаксис:
.CSEG
Пример:
.DSEG ; Начало сегмента данных vartab: .BYTE 4 ; Резервируется 4 байта в СОЗУ
.CSEG ; Начало сегмента кодов const: .DW 2 ; Записать 0x0002 в программной памяти mov r1,r0 ; Что-то делать
Директива DSEG (Data Segment) указывает на начало сегмента данных. Ассемблируемый файл может содержать несколько сегментов данных, которые потом будут собраны в один при ассемблировании. Обычно сегмент данных состоит лишь из директив BYTE и меток.
Синтаксис:
.DSEG
Пример:
.DSEG ; Начало сегмента данных
var1: .BYTE 1 ;Резервировать 1 байт под переменную table: .BYTE tab_size ; Резервировать tab_size байтов.
.CSEG
ldi r30,low(var1)
ldi r31,high(var1)
ld r1,Z
Директива ESEG (EEPROM Segment) указывает на начало сегмента EEPROM памяти. Ассемблируемый файл может содержать несколько EEPROM сегментов, которые будут собраны в один сегмент при ассемблировании. Обычно сегмент EEPROM состоит из DB и DW директив (и меток). Сегмент EEPROM памяти имеет свой собственный счетчик. Директива ORG может использоваться для размещения переменных в нужной области EEPROM.
Синтаксис:
.ESEG
Пример:
.DSEG ;Начало сегмента данных var1:.BYTE 1 ; Резервировать 1 байт под переменную
table: .BYTE tab_size ; Зарезервировать tab_size байт.
.ESEG
eevar1: .DW 0xffff ; Записать 1 слово в EEPROM
Директива ORG присваивает значения локальным счетчикам. Используется только совместно с директивами .CSEG, .DSEG, .ESEG.
Синтаксис:
.ORG адрес
Пример:
.DSEG ; Начало сегмента данных
.ORG 0x37 ; Установить адрес СОЗУ на 37h
variable: .BYTE 1 ;Зарезервировать байт СОЗУ по адресу 37h
.CSEG
.ORG 0x10 ;Установить счетчик команд на адрес 10h
mov r0,r1 ; Чего-нибудь делать
Директива DB резервирует ресурсы памяти в программной памяти или в EEPROM. Директиве должна предшествовать метка. DB задает список выражений, и должна содержать по крайней мере одно выражение. Размещать директиву следует в сегменте кодов или в EEPROM сегменте.
Список выражений представляет собой последовательность выражений, разделенных запятыми. Каждое выражение должно быть величиной между –128 и 255.
Если директива указывается в сегменте кодов и список выражений содержит более двух величин, то выражения будут записаны так, что 2 байта будут размещаться в каждом слове Flash-памяти.
Синтаксис:
LABEL: .DB список выражений
Пример:
.CSEG
consts: .DB 0, 255, 0b01010101, -128, 0xaa
.ESEG
const2: .DB 1,2,3
Директива DW резервирует ресурсы памяти в программной памяти или в EEPROM. Директиве должна предшествовать метка. DW задает список выражений, и должна содержать по крайней мере одно выражение. Размещать директиву следует в сегменте кодов или в EEPROM сегменте.
Список выражений представляет собой последовательность выражений, разделенных запятыми. Каждое выражение должно быть величиной между –32768 и 65535.
Синтаксис:
LABEL: .DW список выражений
Пример:
.CSEG
varlist: .DW 0, 0xffff, 0b1001110001010101, -32768, 65535
.ESEG
eevarlst: .DW 0,0xffff,10
Директива DEF позволяет присвоить символическое имя регистру. Регистр может иметь несколько символических имен.
Синтаксис:
.DEF Имя=Регистр
Пример:
.DEF temp=R16
.DEF ior=R0
.CSEG
ldi temp,0xf0 ; Загрузить 0xf0 в регистр temp
in ior,0x3f ; Прочитать SREG в регистр ior
eor temp,
Директива EQU присваивает значение метке. Эта метка может быть использована в других выражениях. Значение этой метки нельзя изменить или переопределить.
Синтаксис:
.EQU метка=выражение
Пример:
.EQU io_offset = 0x23
.EQU porta = io_offset + 2
.CSEG ; Начало сегмента кодов
clr r2 ; Очистить регистр r2
out porta,r2 ; Записать в порт А
Директива INCLUDE говорит Ассемблеру начать читать из другого файла. Ассемблер будет ассемблировать этот файл до конца файла или до директивы EXIT. Включаемый файл может сам включать директивы INCLUDE.
Синтаксис:
.INCLUDE "имя файла"
Пример:
.EQU sreg = 0x3f ; Регистр статуса
.EQU sphigh = 0x3e ; Старший байт указателя стека.
.EQU splow = 0x3d ; Младший байт указателя стека.
.INCLUDE iodefs.asm ; Включить файл «iodefs.asm»
in r0,sreg ; Прочитать регистр статуса
Директива EXIT позволяет ассемблеру остановить ассемблирование текущего файла. Обычно ассемблер работает до конца файла. Если он встретит директиву EXIT, то продолжит ассемблировать со строки, следующей за директивой INCLUDE.
Синтаксис:
.EXIT
Пример:
.EXIT ; выйти из этого файла
Директива DEVICE позволяет пользователю сообщить ассемблеру, для какого типа устройства пишется программа. Если ассемблер встретит команду, которая не поддерживается указанным типом микроконтроллера, то будет выдано сообщение. Также сообщение появится в случае, если размер программы превысит объем имеющейся в этом устройстве памяти.
Синтаксис:
.DEVICE AT90S1200 | AT90S2313 | AT90S2323 | AT90S2333 | AT90S2343 | AT90S4414 | AT90S4433 | AT90S4434 | AT90S8515 | AT90S8534 | AT90S8535 | ATtiny11 | ATtiny12 | ATtiny22 | ATmega603 | ATmega103 | Atmega8535
Пример:
.DEVICE ATmega8535 ;использовать ATmega8535
.CSEG
.ORG 0000
jmp label1 ;При ассемблировании появиться сообщение, что
;ATmega8535 не поддерживает команду jmp