How the Translator Works With Macros
11-9
Mnemonic-to-Algebraic Translator Description
11.5.2 Macro Local Variables
When macro local variables are encountered, they are changed so that
repeated calls to the macro do not generate identical labels. The following
source code preprocesses to the intermediate code as shown:
Example 11–4. Macro Local Variables
(a) Source code
mymac
.macro parm1
lab?
.word parm1
.endm
mymac 4
mymac 40
mymac 400
(b) Intermediate code
mymac
.macro parm1
lab?
.word parm1
.endm
;
mymac 4
lab$1$
.word 4
;
mymac 40
lab$2$
.word 40
;
mymac 400
lab$3$
.word 400
The local label name is appended with $
n$, where n is the number of the macro
invocation. Insure that there are no other labels that could be identical to a
generated macro local label.
Summary of Contents for TMS320C54x
Page 38: ......
Page 39: ......
Page 40: ......
Page 41: ......
Page 42: ......
Page 43: ......
Page 44: ......
Page 45: ......
Page 46: ......
Page 47: ......
Page 48: ......
Page 49: ......
Page 50: ......
Page 51: ......
Page 52: ......
Page 53: ......
Page 54: ......
Page 55: ......
Page 56: ......
Page 57: ......
Page 58: ......
Page 59: ......
Page 60: ......
Page 61: ......
Page 62: ......
Page 276: ......
Page 277: ......
Page 278: ......
Page 279: ......
Page 280: ......
Page 281: ......
Page 282: ......
Page 283: ......
Page 284: ......
Page 285: ......
Page 286: ......
Page 287: ......
Page 288: ......
Page 289: ......
Page 290: ......
Page 291: ......
Page 292: ......
Page 293: ......
Page 294: ......
Page 295: ......
Page 296: ......
Page 297: ......
Page 298: ......
Page 299: ......
Page 300: ......
Page 301: ......
Page 302: ......