EQU - Установить постоянное выражение

Директива EQU присваивает метке значение. Эта метка может позднее использоваться в выражениях. Метка которой присвоено значение данной директивой не может быть переназначена и её значение не может быть изменено.

Синтаксис:

.EQU метка = выражение

Пример:

.EQU io_offset = 0x23

.EQU porta = io_offset + 2

.CSEG ; Начало сегмента данных

clr r2 ; Очистить регистр r2

out porta,r2 ; Записать в порт A

ESEG - Сегмент EEPROM

Директива ESEG определяет начало сегмента EEPROM. Исходный файл может состоять из нескольких сегментов EEPROM, которые объединяются в один сегмент при компиляции. Сегмент EEPROM обычно состоит только из директив DB, DW и меток. Сегменты EEPROM имеют свои собственные побайтные счётчики положения. Директива ORG может быть использована для размещения переменных в необходимом месте EEPROM. Директива не имеет параметров.

Синтаксис:

.ESEG

Пример:

.DSEG ; Начало сегмента данных

var1: .BYTE 1 ; зарезервировать 1 байт для var1

table: .BYTE tab_size ; зарезервировать tab_size байт.

.ESEG

eevar1: .DW 0xffff ; проинициализировать 1 слово в EEPROM

EXIT - Выйти из файла

Встретив директиву EXIT компилятор прекращает компиляцию данного файла. Если директива использована во вложенном файле (см. директиву INCLUDE), то компиляция продолжается со строки следующей после директивы INCLUDE. Если же файл не является вложенным, то компиляция прекращается.

Синтаксис:

.EXIT

Пример:

.EXIT ; Выйти из данного файла

INCLUDE - Вложить другой файл

Встретив директиву INCLUDE компилятор открывает указанный в ней файл, компилирует его пока файл не закончится или не встретится директива EXIT, после этого продолжает компиляцию начального файла со строки следующей за директивой INCLUDE. Вложенный файл может также содержать директивы INCLUDE.

Синтаксис:

.INCLUDE "имя_файла"

Пример:

; файл iodefs.asm:

.EQU sreg = 0x3f ; Регистр статуса

.EQU sphigh = 0x3e ; Старший байт указателя стека

.EQU splow = 0x3d ; Младший байт указателя стека

; файл incdemo.asm

.INCLUDE iodefs.asm ; Вложить определения портов

in r0,sreg ; Прочитать регистр статуса

LIST - Включить генерацию листинга

Директива LIST указывает компилятору на необходимость создания листинга. Листинг представляет из себя комбинацию ассемблерного кода, адресов и кодов операций. По умолчанию генерация листинга включена, однако данная директива используется совместно с директивой NOLIST для получения листингов отдельных частей исходных файлов.

Синтаксис:

.LIST

Пример:

.NOLIST ; Отключить генерацию листинга

.INCLUDE "macro.inc" ; Вложенные файлы не будут

.INCLUDE "const.def" ; отображены в листинге

.LIST ; Включить генерацию листинга

LISTMAC - Включить разворачивание макросов в листинге

После директивы LISTMAC компилятор будет показывать в листинге содержимое макроса. По умолчанию в листинге показывается только вызов макроса и передаваемые параметры.

Синтаксис:

.LISTMAC

Пример:

.MACRO MACX ; Определение макроса

add r0,@0 ; Тело макроса

eor r1,@1

.ENDMACRO ; Конец макроопределения

.LISTMAC ; Включить разворачивание макросов

MACX r2,r1 ; Вызов макроса (в листинге будет показано теломакроса)

MACRO - Начало макроса

С директивы MACRO начинается определение макроса. В качестве параметра директиве передаётся имя макроса. При встрече имени макроса позднее в тексте программы, компилятор заменяет это имя на тело макроса. Макрос может иметь до 10 параметров, к которым в его теле обращаются через @0-

@9. При вызове параметры перечисляются через запятые. Определение макроса заканчивается директивой ENDMACRO.

По умолчанию в листинг включается только вызов макроса, для разворачивания макроса необходимо использовать директиву LISTMAC. Макрос в листинге показывается знаком +.

Синтаксис:

.MACRO макроимя

Пример:

.MACRO SUBI16 ; Начало макроопределения

subi@1,low(@0) ; Вычесть младший байт параметра 0 из параметра 1

sbci @2,high(@0) ; Вычесть старший байт параметра 0 из параметра 2

.ENDMACRO ; Конец макроопределения

.CSEG     ; Начало программного сегмента
  SUBI16 0x1234,r16,r17 ; Вычесть 0x1234 из r17:r16

NOLIST - Выключить генерацию листинга

Директива NOLIST указывает компилятору на необходимость прекращения генерации листинга. Листинг представляет из себя комбинацию ассемблерного кода, адресов и кодов операций. По умолчанию генерация листинга включена, однако может быть отключена данной директивой. Кроме того данная директива может быть использована совместно с директивой LIST для получения листингов отдельных частей исходных файлов

Синтаксис:

.NOLIST

Пример:

.NOLIST ; Отключить генерацию листинга

.INCLUDE "macro.inc" ; Вложенные файлы не будут

.INCLUDE "const.def" ; отображены в листинге

.LIST ; Включить генерацию листинга

Наши рекомендации