- •Chapter 1. Introduction
- •How to Develop A Program
- •What is an Assembler?
- •Modular Programming
- •Modular Program Development Process
- •Segments, Modules, and Programs
- •Translate and Link Process
- •Filename Extensions
- •Program Template File
- •Chapter 2. Architecture Overview
- •Memory Classes and Memory Layout
- •Classic 8051
- •Extended 8051 Variants
- •Philips 80C51MX
- •Intel/Atmel WM 251
- •CPU Registers
- •CPU Registers of the 8051 Variants
- •CPU Registers of the Intel/Atmel WM 251
- •Program Status Word (PSW)
- •Instruction Sets
- •Opcode Map
- •8051 Instructions
- •Additional 251 Instructions
- •Additional 80C51MX Instructions via Prefix A5
- •Chapter 3. Writing Assembly Programs
- •Assembly Statements
- •Directives
- •Controls
- •Instructions
- •Comments
- •Symbols
- •Symbol Names
- •Labels
- •Operands
- •Special Assembler Symbols
- •Immediate Data
- •Memory Access
- •Program Addresses
- •Expressions and Operators
- •Numbers
- •Characters
- •Character Strings
- •Location Counter
- •Operators
- •Expressions
- •Chapter 4. Assembler Directives
- •Introduction
- •Segment Directives
- •Location Counter
- •Generic Segments
- •Stack Segment
- •Absolute Segments
- •Default Segment
- •SEGMENT
- •RSEG
- •BSEG, CSEG, DSEG, ISEG, XSEG
- •Symbol Definition
- •CODE, DATA, IDATA, XDATA
- •esfr, sfr, sfr16, sbit
- •LIT (AX51 & A251 only)
- •Memory Initialization
- •DD (AX51 & A251 only)
- •Reserving Memory
- •DBIT
- •DSW (AX51 & A251 only)
- •DSD (AX51 & A251 only)
- •Procedure Declaration (AX51 & A251 only)
- •PROC / ENDP (AX51 & A251 only)
- •LABEL (AX51 and A251 only)
- •Program Linkage
- •PUBLIC
- •EXTRN / EXTERN
- •NAME
- •Address Control
- •EVEN (AX51 and A251 only)
- •USING
- •Other Directives
- •_ _ERROR_ _
- •Chapter 5. Assembler Macros
- •Standard Macro Directives
- •Defining a Macro
- •Parameters
- •Labels
- •Repeating Blocks
- •REPT
- •IRPC
- •Nested Definitions
- •Nested Repeating Blocks
- •Recursive Macros
- •Operators
- •NUL Operator
- •& Operator
- •< and > Operators
- •% Operator
- •;; Operator
- •! Operator
- •Invoking a Macro
- •C Macros
- •C Macro Preprocessor Directives
- •Stringize Operator
- •Predefined C Macro Constants
- •Examples with C Macros
- •C Preprocessor Side Effects
- •Chapter 6. Macro Processing Language
- •Overview
- •Creating and Calling MPL Macros
- •Creating Parameterless Macros
- •MPL Macros with Parameters
- •Local Symbols List
- •Macro Processor Language Functions
- •Comment Function
- •Escape Function
- •Bracket Function
- •METACHAR Function
- •Numbers and Expressions
- •Numbers
- •Character Strings
- •SET Function
- •EVAL Function
- •Logical Expressions and String Comparison
- •Conditional MPL Processing
- •IF Function
- •WHILE Function
- •REPEAT Function
- •EXIT Function
- •String Manipulation Functions
- •LEN Function
- •SUBSTR Function
- •MATCH Function
- •Console I/O Functions
- •Advanced Macro Processing
- •Literal Delimiters
- •Blank Delimiters
- •Identifier Delimiters
- •Literal and Normal Mode
- •MACRO Errors
- •Chapter 7. Invocation and Controls
- •Environment Settings
- •Running Ax51
- •ERRORLEVEL
- •Output Files
- •Assembler Controls
- •Controls for Conditional Assembly
- •Conditional Assembly Controls
- •Chapter 8. Error Messages
- •Fatal Errors
- •Non–Fatal Errors
- •Chapter 9. Linker/Locator
- •Overview
- •Combining Program Modules
- •Segment Naming Conventions
- •Combining Segments
- •Locating Segments
- •Overlaying Data Memory
- •Resolving External References
- •Absolute Address Calculation
- •Generating an Absolute Object File
- •Generating a Listing File
- •Bank Switching
- •Using RTX51, RTX251, and RTX51 Tiny
- •Linking Programs
- •Command Line Examples
- •Control Linker Input with µVision2
- •ERRORLEVEL
- •Output File
- •Linker/Locater Controls
- •Locating Programs to Physical Memory
- •Classic 8051
- •Extended 8051 Variants
- •Philips 80C51MX
- •Intel/Atmel WM 251
- •Data Overlaying
- •Program and Data Segments of Functions
- •Using the Overlay Control
- •Tips and Tricks for Program Locating
- •Locate Segments with Wildcards
- •Special ROM Handling (LX51 & L251 only)
- •Bank Switching
- •Common Code Area
- •Code Bank Areas
- •Bank Switching Configuration
- •Configuration Examples
- •Control Summary
- •Listing File Controls
- •Output File Controls
- •Segment and Memory Location Controls
- •High-Level Language Controls
- •Error Messages
- •Warnings
- •Non-Fatal Errors
- •Fatal Errors
- •Exceptions
- •Chapter 10. Library Manager
- •Using LIBx51
- •Interactive Mode
- •Create Library within µVision2
- •Command Summary
- •Creating a Library
- •Adding or Replacing Object Modules
- •Removing Object Modules
- •Extracting Object Modules
- •Listing Library Contents
- •Error Messages
- •Fatal Errors
- •Errors
- •Chapter 11. Object-Hex Converter
- •Using OHx51
- •OHx51 Command Line Examples
- •Creating HEX Files for Banked Applications
- •OHx51 Error Messages
- •Using OC51
- •OC51 Error Messages
- •Intel HEX File Format
- •Record Format
- •Data Record
- •Extended 8086 Segment Record
- •Extended Linear Address Record
- •Example Intel HEX File
- •Appendix A. Application Examples
- •ASM – Assembler Example
- •Using A51 and BL51
- •Using AX51 and LX51
- •Using A251 and L251
- •CSAMPLE – C Compiler Example
- •Using C51 and BL51
- •Using C51 and LX51
- •Using C251 and L251
- •BANK_EX1 – Code Banking with C51
- •Using C51 and BL51
- •Using C51 and LX51
- •BANK_EX2 – Banking with Constants
- •Using C51 and BL51
- •Using C51 and LX51
- •Using BL51
- •Using C51 and LX51
- •Philips 80C51MX – Assembler Example
- •Philips 80C51MX – C Compiler Example
- •Appendix B. Reserved Symbols
- •Appendix C. Listing File Format
- •Assembler Listing File Format
- •Listing File Heading
- •Source Listing
- •Macro / Include File / Save Stack Format
- •Symbol Table
- •Listing File Trailer
- •Appendix D. Assembler Differences
- •Differences Between A51 and A251/AX51
- •Differences between A51 and ASM51
- •Differences between A251/AX51 & ASM51
- •Glossary
- •Index
Keil Software — A51/AX51/A251 Macro Assembler and Utilities |
99 |
|
|
Chapter 4. Assembler Directives
This chapter describes the assembler directives. It shows how to define symbols and how to control the placement of code and data in program memory.
Introduction
The Ax51 assembler has several directives that permit you to define symbol values, reserve and initialize storage, and control the placement of your code.
The directives should not be confused with instructions. They do not produce |
|
||||||
executable code, and with the exception of the DB, DW and DD directives, they |
|
||||||
have no direct effect on the contents of code memory. These directives change |
|
||||||
the state of the assembler, define user symbols, and add information to the object |
|
||||||
4 |
|||||||
file. |
|
|
|
|
|
||
The following table provides an overview of the assembler directives. Page |
|||||||
refers to the page number in this user’s guide where you can find detailed |
|
||||||
|
|||||||
information about the directive. |
|
|
|
||||
|
|
|
|
|
|||
Directive / Page |
Format |
Description |
|
|
|||
BIT |
114 |
symbol BIT bit_address |
Define a bit address in bit data space. |
|
|
||
BSEG |
111 |
BSEG |
[AT absolute address] |
Define an absolute segment within the |
|
|
|
|
|
|
|
bit address space. |
|
|
|
CODE |
114 |
symbol CODE code_address |
Assign a symbol name to a specific |
|
|
||
|
|
|
|
address in the code space. |
|
|
|
CSEG |
111 |
CSEG |
[AT absolute address] |
Define an absolute segment within the |
|
|
|
|
|
|
|
code address space. |
|
|
|
DATA |
114 |
symbol |
DATA data_address |
Assign a symbol name to a specific |
|
|
|
|
|
|
|
on-chip data address. |
|
|
|
DB |
119 |
[label:] |
DB expression [, expr ...] |
Generate a list of byte values. |
|
|
|
DBIT |
122 |
[label:] DBIT expression |
Reserve a space in bit units. |
|
|
||
DD |
121 |
[label:] |
DD expression [, expr ...] |
Generate a list of double word values. |
|
|
|
DS |
123 |
[label:] DS expression |
Reserve space in byte units. |
|
|
||
DSB |
124 |
[label:] DSB expression |
Reserve space in byte units. |
|
|
||
DSD |
126 |
[label:] DSD expression |
Reserve space in double word units. |
|
|
||
DSEG |
111 |
DSEG |
[AT absolute address] |
Define an absolute segment within the |
|
|
|
|
|
|
|
indirect internal data space. |
|
|
Shaded directives and options are available only in AX51 and A251.
|
100 |
|
|
|
|
|
|
|
|
|
|
|
Chapter 4. Assembler Directives |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
||
|
|
|
|
|
|
|
|
|
|
|
|
|
||
|
|
Directive / Page |
|
|
Format |
|
Description |
|
||||||
|
|
DSW |
125 |
|
|
[label:] |
DSW expression |
|
Reserve space in word units; |
|
||||
|
|
|
|
|
|
|
|
|
|
|
|
|
advances the location counter of the |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
current segment. |
|
|
|
DW |
120 |
|
|
[label:] |
DW expression [, expr. ...] |
|
Generate a list of word values. |
|
||||
|
|
END |
136 |
|
|
END |
|
|
|
|
|
Indicate end of program. |
|
|
|
|
EQU |
113 |
|
|
EQU expression |
|
Set symbol value permanently. |
|
|||||
|
|
_ _ERROR_ _136 |
|
_ _ERROR_ _ text |
|
Generate a standard error message. |
|
|||||||
|
|
EVEN |
134 |
|
EVEN |
|
|
|
|
|
Ensure word alignment for variables. |
|
||
|
|
EXTRN |
131 |
|
EXTRN class |
|
(symbol [, ...]) |
|
Defines symbols referenced in the |
|
||||
|
|
|
[:type] |
|
||||||||||
|
|
EXTERN |
|
|
|
|
EXTERN class [:type] (symbol [, ...]) |
|
|
current module that are defined in |
|
|||
|
|
|
|
|
|
|
|
|
|
|
|
|
other modules. |
|
|
|
IDATA |
114 |
|
symbol |
IDATA idata_address |
|
Assign a symbol name to a specific |
|
|||||
|
|
|
|
|
|
|
|
|
|
|
|
|
indirect internal address. |
|
|
|
ISEG |
111 |
|
ISEG [AT absolute address] |
|
Define an absolute segment within the |
|
||||||
|
|
|
|
|
|
|
|
|
|
|
|
|
internal data space. |
|
|
|
LABEL |
129 |
|
|
name[:] |
LABEL [type] |
|
Assign a symbol name to a address |
|
||||
4 |
|
|
|
|
|
|
|
|
|
|
|
|
location within a segment. |
|
|
LIT |
116 |
|
|
symbol |
LIT ’literal string’ |
|
Assign a symbol name to a string. |
|
|||||
|
NAME |
132 |
|
NAME modulname |
|
Specify the name of the current |
|
|||||||
|
|
|
module. |
|
||||||||||
|
|
ORG |
133 |
|
ORG expression |
|
Set the location counter of the current |
|
||||||
|
||||||||||||||
|
|
|
|
|
|
|
|
|
|
|
|
|
segment. |
|
|
|
|
|
|
|
|
|
|
||||||
|
|
PROC |
127 |
|
|
name PROC [type] |
|
Define a function start and end. |
|
|||||
|
|
ENDP |
|
|
|
name ENDP |
|
|
|
|||||
|
|
PUBLIC |
130 |
|
PUBLIC symbol [, symbol ...] |
|
Identify symbols which can be used |
|
||||||
|
|
|
|
|
|
|
|
|
|
|
|
|
outside the current module. |
|
|
|
RSEG |
110 |
|
RSEG |
seg |
|
Select a relocatable segment. |
|
|||||
|
|
SEGMENT |
106 |
|
seg SEGMENT class [reloctype] |
|
Define a relocatable segment. |
|
||||||
|
|
|
|
|
|
[alloctype] |
|
|
|
|||||
|
|
SET |
113 |
|
SET expression |
|
Set symbol value temporarily. |
|
||||||
|
|
sfr, |
116 |
|
sfr symbol = address; |
|
Define a special function register |
|
||||||
|
|
sfr16 |
|
|
sfr16 symbol = address; |
|
(SFR) symbol or a SFR bit symbol. |
|
||||||
|
|
sbit |
|
|
sbit symbol = address; |
|
|
|
||||||
|
|
USING |
134 |
|
USING |
expression |
|
Set the predefined symbolic register |
|
|||||
|
|
|
|
|
|
|
|
|
|
|
|
|
address and reserve space for the |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
specified register bank. |
|
|
|
XDATA |
114 |
|
symbol |
XDATA xdata_address |
|
Assign a symbol name to a specific |
|
|||||
|
|
|
|
|
|
|
|
|
|
|
|
|
off-chip data address. |
|
|
|
XSEG |
111 |
|
XSEG |
[AT absolute address] |
|
Define an absolute segment within the |
|
|||||
|
|
|
|
|
|
|
|
|
|
|
|
|
external data address space. |
|
Shaded directives and options are available only in AX51 and A251.
Keil Software — A51/AX51/A251 Macro Assembler and Utilities |
101 |
|
|
The directives are divided into the following categories:
|
Segment Control |
|
|
|
|
|
|
|
||||||
|
Generic Segments: SEGMENT, RSEG |
|
||||||||||||
|
Absolute Segments: CSEG, DSEG, BSEG, ISEG, XSEG |
|
||||||||||||
|
Symbol Definition |
|
|
|
|
|
|
|
||||||
|
Generic Symbols: EQU, SET |
|
||||||||||||
|
Address Symbols: BIT, CODE, DATA, IDATA, XDATA |
|
||||||||||||
|
SFR Symbols: |
sfr, sfr16, sbit |
|
|||||||||||
|
|
Text Replacement: LIT |
|
|
|
|
|
|||||||
|
Memory Initialization |
|
||||||||||||
|
DB, DW, |
DD |
|
|
|
|
|
|
|
|
||||
|
Memory Reservation |
|
||||||||||||
|
DBIT, DS, |
DSB, DSW, DSD |
|
|
|
|
||||||||
|
|
|
|
|
|
|
|
|||||||
|
Procedure Declaration |
4 |
||||||||||||
|
PROC / ENDP, LABEL |
|
||||||||||||
|
Program Linkage |
|
|
|
|
|
|
|||||||
|
PUBLIC, EXTRN / |
EXTERN |
, NAME |
|
||||||||||
|
|
|||||||||||||
|
Address Control |
|
|
|
|
|
|
|
||||||
|
ORG, |
EVEN |
, USING |
|
||||||||||
|
Others |
|
|
|
|
|
|
|
||||||
|
END, _ _ERROR_ _ |
|
The Ax51 assembler is a multi-pass assembler. In the first pass, symbol values are determined. In the subsequent passes, forward references are resolved and object code is produced. This structure imposes a restriction on the source program: expressions which define symbol values (refer to “Symbol Definition” on page 113) and expressions which control the location counter (refer to “ORG” on page 133, “DS” on page 123, and “DBIT” on page 122) may not have forward references.
Shaded directives and options are available only in AX51 and A251.