Macro definition, Concatenation, Macro definition concatenation – Zilog Z8F0130 User Manual
Page 353
UM013037-1212
Macro Definition
Zilog Developer Studio II – Z8 Encore!
User Manual
329
•
Macro Definition
A macro definition must precede the use of the macro. The macro name must be the same
for both the definition and the
ENDMACRO
line. The argument list contains the formal argu-
ments that are substituted with actual arguments when the macro is expanded. The argu-
ments can be optionally prefixed with the substitution character (\) in the macro body.
During the invocation of the macro, a token substitution is performed, replacing the formal
arguments (including the substitution character, if present) with the actual arguments.
Syntax
<macroname>[:]
MACRO
[<arg>(,<arg>)...]
<macro_body>
ENDMAC
[RO]<macroname>
Example
store: MACRO reg1,reg2,reg3
ADD reg1,reg2
LD reg3,reg1
ENDMAC store
Concatenation
To facilitate unambiguous symbol substitution during macro expansion, the concatenation
character (&) can be suffixed to symbol names. The concatenation character is a syntactic
device for delimiting symbol names that are points of substitution and is devoid of seman-
tic content. The concatenation character, therefore, is discarded by the assembler, when
the character has delimited a symbol name.
For example:
val_part1 equ 55h
val_part2 equ 33h
The assembly is:
value macro par1, par2
DB par1&_&par2
macend
value val,part1
value val,part2
The generated list file is:
- Z8F0131 Z8F0230 Z8F0231 Z8F0430 Z8F0431 Z8F043A Z8F0830 Z8F0831 Z8F083A Z8F1232 Z8F1233 Z8F0113 Z8F011A Z8F0123 Z8F012A Z8F0213 Z8F021A Z8F0223 Z8F022A Z8F0411 Z8F0412 Z8F0413 Z8F041A Z8F0421 Z8F0422 Z8F0423 Z8F042A Z8F0811 Z8F0812 Z8F0813 Z8F081A Z8F0821 Z8F0822 Z8F0823 Z8F082A Z8F0880 Z8F1621 Z8F1622 Z8F1680 Z8F1681 Z8F1682 Z8F2421 Z8F2422 Z8F2480 Z8F3221 Z8F3222 Z8F3281 Z8F3282 Z8F4821 Z8F4822 Z8F4823 Z8F6081 Z8F6082 Z8F6421 Z8F6422 Z8F6423 Z8F6481 Z8F6482 Z8FS021A ZMOT1AHH Z8FS040B ZMOT0BHH ZMOT0BSB Z8FMC04 Z8FMC08 Z8FMC16