This document discusses macro expansion and nested macro calls in system software. It covers:
1. Macro expansion involves replacing a macro call with code from its body by substituting actual parameters for formal parameters.
2. Macro expansion can be performed by a macro assembler or preprocessor. A macro assembler performs full assembly while a preprocessor only processes macro calls.
3. Key aspects of macro expansion include the order of model statement expansion and lexical substitution of formal parameters with actual values. Nested macro calls follow a last-in, first-out expansion order.