MC6809-MC6809E
8-BIT MICROPROCESSOR
PROGRAMMING MANUAL

Original Issue: March 1, 1981

©MOTOROLA INC., 1981
# TABLE OF CONTENTS

<table>
<thead>
<tr>
<th>Paragraph No.</th>
<th>Title</th>
<th>Page No.</th>
</tr>
</thead>
<tbody>
<tr>
<td>1.1</td>
<td>Introduction</td>
<td>1-1</td>
</tr>
<tr>
<td>1.2</td>
<td>Features</td>
<td>1-1</td>
</tr>
<tr>
<td>1.3</td>
<td>Software Features</td>
<td>1-2</td>
</tr>
<tr>
<td>1.4</td>
<td>Programming Model</td>
<td>1-3</td>
</tr>
<tr>
<td>1.5</td>
<td>Index Registers (X, Y)</td>
<td>1-3</td>
</tr>
<tr>
<td>1.6</td>
<td>Stack Pointer Registers (U, S)</td>
<td>1-3</td>
</tr>
<tr>
<td>1.7</td>
<td>Program Counter (PC)</td>
<td>1-4</td>
</tr>
<tr>
<td>1.8</td>
<td>Accumulator Registers (A, B, D)</td>
<td>1-4</td>
</tr>
<tr>
<td>1.9</td>
<td>Direct Page Register (DP)</td>
<td>1-4</td>
</tr>
<tr>
<td>1.10</td>
<td>Condition Code Register (CC)</td>
<td>1-4</td>
</tr>
<tr>
<td>1.10.1</td>
<td>Condition Code Bits</td>
<td>1-5</td>
</tr>
<tr>
<td>1.10.1.1</td>
<td>Half Carry (H), Bit 5</td>
<td>1-5</td>
</tr>
<tr>
<td>1.10.1.2</td>
<td>Negative (N), Bit 3</td>
<td>1-5</td>
</tr>
<tr>
<td>1.10.1.3</td>
<td>Zero (Z), Bit 2</td>
<td>1-5</td>
</tr>
<tr>
<td>1.10.1.4</td>
<td>Overflow (V), Bit 1</td>
<td>1-5</td>
</tr>
<tr>
<td>1.10.1.5</td>
<td>Carry (C), Bit 0</td>
<td>1-5</td>
</tr>
<tr>
<td>1.10.2</td>
<td>Interrupt Mask Bits and Stacking Indicator</td>
<td>1-5</td>
</tr>
<tr>
<td>1.10.2.1</td>
<td>Fast Interrupt Request Mask (F), Bit 6</td>
<td>1-5</td>
</tr>
<tr>
<td>1.10.2.2</td>
<td>Interrupt Request Mask (I), Bit 4</td>
<td>1-5</td>
</tr>
<tr>
<td>1.10.2.3</td>
<td>Entire Flag (E), Bit 7</td>
<td>1-6</td>
</tr>
<tr>
<td>1.11</td>
<td>Pin Assignments and Signal Description</td>
<td>1-6</td>
</tr>
<tr>
<td>1.11.1</td>
<td>MC6809 Clocks</td>
<td>1-6</td>
</tr>
<tr>
<td>1.11.1.1</td>
<td>Oscillator (EXTAL, XTAL)</td>
<td>1-6</td>
</tr>
<tr>
<td>1.11.1.2</td>
<td>Enable (E)</td>
<td>1-7</td>
</tr>
<tr>
<td>1.11.1.3</td>
<td>Quadrature (Q)</td>
<td>1-7</td>
</tr>
<tr>
<td>1.11.2</td>
<td>MC6809E Clocks (E and Q)</td>
<td>1-7</td>
</tr>
<tr>
<td>1.11.3</td>
<td>Three State Control (TSC) (MC6809E)</td>
<td>1-7</td>
</tr>
<tr>
<td>1.11.4</td>
<td>Last Instruction Cycle (LIC) (MC6809E)</td>
<td>1-7</td>
</tr>
<tr>
<td>1.11.5</td>
<td>Address Bus (A0-A15)</td>
<td>1-7</td>
</tr>
<tr>
<td>1.11.6</td>
<td>Data Bus (D0-D7)</td>
<td>1-7</td>
</tr>
<tr>
<td>1.11.7</td>
<td>Read/Write (R/W)</td>
<td>1-8</td>
</tr>
<tr>
<td>1.11.8</td>
<td>Processor State Indicators (BA, BS)</td>
<td>1-8</td>
</tr>
<tr>
<td>1.11.8.1</td>
<td>Normal</td>
<td>1-8</td>
</tr>
<tr>
<td>1.11.8.2</td>
<td>Interrupt or Reset Acknowledge</td>
<td>1-8</td>
</tr>
<tr>
<td>1.11.8.3</td>
<td>Sync Acknowledge</td>
<td>1-8</td>
</tr>
</tbody>
</table>
# TABLE OF CONTENTS
(CONTINUED)

<table>
<thead>
<tr>
<th>Paragraph No.</th>
<th>Title</th>
<th>Page No.</th>
</tr>
</thead>
<tbody>
<tr>
<td>1.11.8.4</td>
<td>Halt/Bus Grant</td>
<td>1-8</td>
</tr>
<tr>
<td>1.11.9</td>
<td>Reset (RESET)</td>
<td>1-9</td>
</tr>
<tr>
<td>1.11.10</td>
<td>Interrupts</td>
<td>1-9</td>
</tr>
<tr>
<td>1.11.10.1</td>
<td>Non-Maskable Interrupt (NMI)</td>
<td>1-9</td>
</tr>
<tr>
<td>1.11.10.2</td>
<td>Fast Interrupt Request (FIRQ)</td>
<td>1-9</td>
</tr>
<tr>
<td>1.11.10.3</td>
<td>Interrupt Request (IRQ)</td>
<td>1-9</td>
</tr>
<tr>
<td>1.11.11</td>
<td>Memory Ready (MRDY) (MC6809)</td>
<td>1-9</td>
</tr>
<tr>
<td>1.11.12</td>
<td>Advanced Valid Memory Address (AVMA) (MC6809E)</td>
<td>1-10</td>
</tr>
<tr>
<td>1.11.13</td>
<td>Halt (HALT)</td>
<td>1-10</td>
</tr>
<tr>
<td>1.11.14</td>
<td>Direct Memory Access/Bus Request (DMA/BREQ) (MC6809)</td>
<td>1-10</td>
</tr>
<tr>
<td>1.11.15</td>
<td>Busy (MC6809E)</td>
<td>1-10</td>
</tr>
<tr>
<td>1.11.16</td>
<td>Power</td>
<td>1-11</td>
</tr>
</tbody>
</table>

## SECTION 2
ADDRESSING MODES

<table>
<thead>
<tr>
<th>Section</th>
<th>Title</th>
<th>Page No.</th>
</tr>
</thead>
<tbody>
<tr>
<td>2.1</td>
<td>Introduction</td>
<td>2-1</td>
</tr>
<tr>
<td>2.2</td>
<td>Addressing Modes</td>
<td>2-1</td>
</tr>
<tr>
<td>2.2.1</td>
<td>Inherent</td>
<td>2-1</td>
</tr>
<tr>
<td>2.2.2</td>
<td>Immediate</td>
<td>2-1</td>
</tr>
<tr>
<td>2.2.3</td>
<td>Extended</td>
<td>2-2</td>
</tr>
<tr>
<td>2.2.4</td>
<td>Direct</td>
<td>2-2</td>
</tr>
<tr>
<td>2.2.5</td>
<td>Indexed</td>
<td>2-2</td>
</tr>
<tr>
<td>2.2.5.1</td>
<td>Constant Offset from Register</td>
<td>2-2</td>
</tr>
<tr>
<td>2.2.5.2</td>
<td>Accumulator Offset from Register</td>
<td>2-3</td>
</tr>
<tr>
<td>2.2.5.3</td>
<td>Autoincrement/Decrement from Register</td>
<td>2-3</td>
</tr>
<tr>
<td>2.2.5.4</td>
<td>Indirection</td>
<td>2-4</td>
</tr>
<tr>
<td>2.2.5.5</td>
<td>Extended Indirect</td>
<td>2-4</td>
</tr>
<tr>
<td>2.2.5.6</td>
<td>Program Counter Relative</td>
<td>2-4</td>
</tr>
<tr>
<td>2.2.6</td>
<td>Branch Relative</td>
<td>2-4</td>
</tr>
</tbody>
</table>

## SECTION 3
INTERRUPT CAPABILITIES

<table>
<thead>
<tr>
<th>Section</th>
<th>Title</th>
<th>Page No.</th>
</tr>
</thead>
<tbody>
<tr>
<td>3.1</td>
<td>Introduction</td>
<td>3-1</td>
</tr>
<tr>
<td>3.2</td>
<td>Non-Maskable Interrupt (NMI)</td>
<td>3-1</td>
</tr>
<tr>
<td>3.3</td>
<td>Fast Maskable Interrupt Request (FIRQ)</td>
<td>3-2</td>
</tr>
<tr>
<td>3.4</td>
<td>Normal Maskable Interrupt Request (IRQ)</td>
<td>3-2</td>
</tr>
<tr>
<td>3.5</td>
<td>Software Interrupts (SWI, SWI2, SWI3)</td>
<td>3-2</td>
</tr>
</tbody>
</table>
# TABLE OF CONTENTS
(CONCLUDED)

<table>
<thead>
<tr>
<th>Paragraph No.</th>
<th>Title</th>
<th>Page No.</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td><strong>SECTION 4</strong></td>
<td></td>
</tr>
<tr>
<td></td>
<td><strong>PROGRAMMING</strong></td>
<td></td>
</tr>
<tr>
<td>4.1</td>
<td>Introduction</td>
<td>4-1</td>
</tr>
<tr>
<td>4.1.1</td>
<td>Position-Independence</td>
<td>4-1</td>
</tr>
<tr>
<td>4.1.2</td>
<td>Modular Programming</td>
<td>4-1</td>
</tr>
<tr>
<td>4.1.2.1</td>
<td>Local Storage</td>
<td>4-1</td>
</tr>
<tr>
<td>4.1.2.2</td>
<td>Global Storage</td>
<td>4-2</td>
</tr>
<tr>
<td>4.1.3</td>
<td>Reentrancy/Recursion</td>
<td>4-2</td>
</tr>
<tr>
<td>4.2</td>
<td>M6809 Capabilities</td>
<td>4-2</td>
</tr>
<tr>
<td>4.2.1</td>
<td>Module Construction</td>
<td>4-2</td>
</tr>
<tr>
<td>4.2.1.1</td>
<td>Parameters</td>
<td>4-3</td>
</tr>
<tr>
<td>4.2.1.2</td>
<td>Local Storage</td>
<td>4-3</td>
</tr>
<tr>
<td>4.2.1.3</td>
<td>Global Storage</td>
<td>4-3</td>
</tr>
<tr>
<td>4.2.2</td>
<td>Position-Independent Code</td>
<td>4-4</td>
</tr>
<tr>
<td>4.2.3</td>
<td>Reentrant Programs</td>
<td>4-5</td>
</tr>
<tr>
<td>4.2.4</td>
<td>Recursive Programs</td>
<td>4-5</td>
</tr>
<tr>
<td>4.2.5</td>
<td>Loops</td>
<td>4-5</td>
</tr>
<tr>
<td>4.2.6</td>
<td>Stack Programming</td>
<td>4-6</td>
</tr>
<tr>
<td>4.2.6.1</td>
<td>M6809 Stacking Operations</td>
<td>4-6</td>
</tr>
<tr>
<td>4.2.6.2</td>
<td>Subroutine Linkage</td>
<td>4-7</td>
</tr>
<tr>
<td>4.2.6.3</td>
<td>Software Stacks</td>
<td>4-8</td>
</tr>
<tr>
<td>4.2.7</td>
<td>Real Time Programming</td>
<td>4-8</td>
</tr>
<tr>
<td>4.3</td>
<td>Program Documentation</td>
<td>4-8</td>
</tr>
<tr>
<td>4.4</td>
<td>Instruction Set</td>
<td>4-9</td>
</tr>
</tbody>
</table>

# APPENDIX A
**INSTRUCTION SET DETAILS**

<table>
<thead>
<tr>
<th>A.1</th>
<th>Introduction</th>
<th>A-1</th>
</tr>
</thead>
<tbody>
<tr>
<td>A.2</td>
<td>Notation</td>
<td>A-1</td>
</tr>
<tr>
<td></td>
<td>Instructions (listed in alphabetical order)</td>
<td>A-3</td>
</tr>
</tbody>
</table>

# APPENDIX B
**ASSIST09 MONITOR PROGRAM**

<table>
<thead>
<tr>
<th>B.1</th>
<th>General Description</th>
<th>B-1</th>
</tr>
</thead>
<tbody>
<tr>
<td>B.2</td>
<td>Implementation Requirements</td>
<td>B-1</td>
</tr>
<tr>
<td>B.3</td>
<td>Interrupt Control</td>
<td>B-2</td>
</tr>
<tr>
<td>B.4</td>
<td>Initialization</td>
<td>B-3</td>
</tr>
<tr>
<td>Paragraph No.</td>
<td>Title</td>
<td>Page No.</td>
</tr>
<tr>
<td>--------------</td>
<td>-----------------------------</td>
<td>----------</td>
</tr>
<tr>
<td>B.5</td>
<td>Input/Output Control</td>
<td>B-4</td>
</tr>
<tr>
<td>B.6</td>
<td>Command Format</td>
<td>B-4</td>
</tr>
<tr>
<td>B.7</td>
<td>Command List</td>
<td>B-5</td>
</tr>
<tr>
<td>B.8</td>
<td>Commands</td>
<td>B-5</td>
</tr>
<tr>
<td></td>
<td>Breakpoint</td>
<td>B-6</td>
</tr>
<tr>
<td></td>
<td>Call</td>
<td>B-6</td>
</tr>
<tr>
<td></td>
<td>Display</td>
<td>B-7</td>
</tr>
<tr>
<td></td>
<td>Encode</td>
<td>B-7</td>
</tr>
<tr>
<td></td>
<td>Go</td>
<td>B-8</td>
</tr>
<tr>
<td></td>
<td>Load</td>
<td>B-8</td>
</tr>
<tr>
<td></td>
<td>Memory</td>
<td>B-9</td>
</tr>
<tr>
<td></td>
<td>Null</td>
<td>B-10</td>
</tr>
<tr>
<td></td>
<td>Offset</td>
<td>B-10</td>
</tr>
<tr>
<td></td>
<td>Punch</td>
<td>B-11</td>
</tr>
<tr>
<td></td>
<td>Register</td>
<td>B-11</td>
</tr>
<tr>
<td></td>
<td>Stevel</td>
<td>B-12</td>
</tr>
<tr>
<td></td>
<td>Trace</td>
<td>B-12</td>
</tr>
<tr>
<td></td>
<td>Verify</td>
<td>B-13</td>
</tr>
<tr>
<td></td>
<td>Window</td>
<td>B-13</td>
</tr>
<tr>
<td>B.9</td>
<td>Services</td>
<td>B-14</td>
</tr>
<tr>
<td></td>
<td>BKPT</td>
<td>B-15</td>
</tr>
<tr>
<td></td>
<td>INCHP</td>
<td>B-15</td>
</tr>
<tr>
<td></td>
<td>MONITR</td>
<td>B-16</td>
</tr>
<tr>
<td></td>
<td>OUTCH</td>
<td>B-17</td>
</tr>
<tr>
<td></td>
<td>OUT2HS</td>
<td>B-17</td>
</tr>
<tr>
<td></td>
<td>OUT4HS</td>
<td>B-18</td>
</tr>
<tr>
<td></td>
<td>PAUSE</td>
<td>B-18</td>
</tr>
<tr>
<td></td>
<td>PCRLF</td>
<td>B-19</td>
</tr>
<tr>
<td></td>
<td>PDATA</td>
<td>B-19</td>
</tr>
<tr>
<td></td>
<td>PDATA1</td>
<td>B-20</td>
</tr>
<tr>
<td></td>
<td>SPACE</td>
<td>B-21</td>
</tr>
<tr>
<td></td>
<td>VTRSW</td>
<td>B-21</td>
</tr>
<tr>
<td>B.10</td>
<td>Vector Swap Service</td>
<td>B-22</td>
</tr>
<tr>
<td></td>
<td>.ACIA</td>
<td>B-23</td>
</tr>
<tr>
<td></td>
<td>.AVTBL</td>
<td>B-23</td>
</tr>
<tr>
<td></td>
<td>.BSDTA</td>
<td>B-24</td>
</tr>
<tr>
<td></td>
<td>.BSOFF</td>
<td>B-24</td>
</tr>
<tr>
<td></td>
<td>.BSON</td>
<td>B-25</td>
</tr>
<tr>
<td></td>
<td>.CIDTA</td>
<td>B-25</td>
</tr>
<tr>
<td></td>
<td>.CIOFF</td>
<td>B-26</td>
</tr>
<tr>
<td></td>
<td>.CION</td>
<td>B-26</td>
</tr>
<tr>
<td></td>
<td>.CMDL1</td>
<td>B-27</td>
</tr>
<tr>
<td></td>
<td>.CMDL2</td>
<td>B-28</td>
</tr>
</tbody>
</table>
TABLE OF CONTENTS
(CONTINUED)

<table>
<thead>
<tr>
<th>Paragraph No.</th>
<th>Title</th>
<th>Page No.</th>
</tr>
</thead>
<tbody>
<tr>
<td>.CODTA</td>
<td></td>
<td>B-28</td>
</tr>
<tr>
<td>.COOFF</td>
<td></td>
<td>B-29</td>
</tr>
<tr>
<td>.COON</td>
<td></td>
<td>B-29</td>
</tr>
<tr>
<td>.ECHO</td>
<td></td>
<td>B-30</td>
</tr>
<tr>
<td>.FIRQ</td>
<td></td>
<td>B-30</td>
</tr>
<tr>
<td>.HSDATA</td>
<td></td>
<td>B-31</td>
</tr>
<tr>
<td>.IRQ</td>
<td></td>
<td>B-31</td>
</tr>
<tr>
<td>.NMI</td>
<td></td>
<td>B-32</td>
</tr>
<tr>
<td>.PAD</td>
<td></td>
<td>B-32</td>
</tr>
<tr>
<td>.PAUSE</td>
<td></td>
<td>B-33</td>
</tr>
<tr>
<td>.PTM</td>
<td></td>
<td>B-33</td>
</tr>
<tr>
<td>.RESET</td>
<td></td>
<td>B-34</td>
</tr>
<tr>
<td>.RSVD</td>
<td></td>
<td>B-34</td>
</tr>
<tr>
<td>.SWI</td>
<td></td>
<td>B-35</td>
</tr>
<tr>
<td>.SWI2</td>
<td></td>
<td>B-35</td>
</tr>
<tr>
<td>.SWI3</td>
<td></td>
<td>B-36</td>
</tr>
<tr>
<td>B.11</td>
<td>Monitor Listing</td>
<td>B-37</td>
</tr>
</tbody>
</table>

APPENDIX C
MACHINE CODE TO INSTRUCTION CROSS REFERENCE

C.1 Introduction ........................................................................C-1

APPENDIX D
PROGRAMMING AID

D.1 Introduction ........................................................................D-1

APPENDIX E
ASCII CHARACTER SET

E.1 Introduction ........................................................................E-1
E.2 Character Representation and Code Identification ..............E-1
E.3 Control Characters ..............................................................E-2
E.4 Graphic Characters ..............................................................E-2
TABLE OF CONTENTS (CONTINUED)

<table>
<thead>
<tr>
<th>Paragraph No.</th>
<th>Title</th>
<th>Page No.</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td><strong>APPENDIX F</strong></td>
<td></td>
</tr>
<tr>
<td>F.1</td>
<td>Introduction</td>
<td>F-1</td>
</tr>
<tr>
<td>F.2</td>
<td>Opcode Map</td>
<td>F-1</td>
</tr>
<tr>
<td></td>
<td><strong>APPENDIX G</strong></td>
<td></td>
</tr>
<tr>
<td>G.1</td>
<td>Introduction</td>
<td>G-1</td>
</tr>
<tr>
<td></td>
<td><strong>APPENDIX H</strong></td>
<td></td>
</tr>
<tr>
<td>H.1</td>
<td>Introduction</td>
<td>H-1</td>
</tr>
<tr>
<td>H.2</td>
<td>Powers of 2; Powers of 16</td>
<td>H-1</td>
</tr>
<tr>
<td>H.3</td>
<td>Hexadecimal and Decimal Conversion</td>
<td>H-2</td>
</tr>
<tr>
<td>H.3.1</td>
<td>Converting Hexadecimal to Decimal</td>
<td>H-2</td>
</tr>
<tr>
<td>H.3.2</td>
<td>Converting Decimal to Hexadecimal</td>
<td>H-2</td>
</tr>
<tr>
<td></td>
<td><strong>LIST OF ILLUSTRATIONS</strong></td>
<td></td>
</tr>
<tr>
<td></td>
<td><strong>Figure No.</strong></td>
<td></td>
</tr>
<tr>
<td></td>
<td>Title</td>
<td>Page No.</td>
</tr>
<tr>
<td>1-1</td>
<td>Programming Model</td>
<td>1-3</td>
</tr>
<tr>
<td>1-2</td>
<td>Condition Code Register</td>
<td>1-4</td>
</tr>
<tr>
<td>1-3</td>
<td>Processor Pin Assignments</td>
<td>1-6</td>
</tr>
<tr>
<td>2-1</td>
<td>Postbyte Usage for EXG/TFR, PSH/PUL Instructions</td>
<td>2-2</td>
</tr>
<tr>
<td>3-1</td>
<td>Interrupt Processing Flowchart</td>
<td>3-5</td>
</tr>
<tr>
<td>4-1</td>
<td>Stacking Order</td>
<td>4-7</td>
</tr>
<tr>
<td>B-1</td>
<td>Memory Map</td>
<td>B-2</td>
</tr>
<tr>
<td>E-1</td>
<td>ASCII Character Set</td>
<td>E-1</td>
</tr>
<tr>
<td>G-1</td>
<td>Pin Assignments</td>
<td>G-1</td>
</tr>
</tbody>
</table>

viii
## LIST OF TABLES

<table>
<thead>
<tr>
<th>Table No.</th>
<th>Title</th>
<th>Page No.</th>
</tr>
</thead>
<tbody>
<tr>
<td>1-1</td>
<td>BA/BS Signal Encoding</td>
<td>1-8</td>
</tr>
<tr>
<td>2-1</td>
<td>Postbyte Usage for Indexed Addressing Modes</td>
<td>2-3</td>
</tr>
<tr>
<td>3-1</td>
<td>Interrupt Vector Locations</td>
<td>3-1</td>
</tr>
<tr>
<td>4-1</td>
<td>Instruction Set</td>
<td>4-9</td>
</tr>
<tr>
<td>4-2</td>
<td>8-Bit Accumulator and Memory Instructions</td>
<td>4-11</td>
</tr>
<tr>
<td>4-3</td>
<td>16-Bit Accumulator and Memory Instructions</td>
<td>4-12</td>
</tr>
<tr>
<td>4-4</td>
<td>Index/Stack Pointer Instructions</td>
<td>4-12</td>
</tr>
<tr>
<td>4-5</td>
<td>Branch Instructions</td>
<td>4-13</td>
</tr>
<tr>
<td>4-6</td>
<td>Miscellaneous Instructions</td>
<td>4-13</td>
</tr>
<tr>
<td>A-1</td>
<td>Operation Notation</td>
<td>A-1</td>
</tr>
<tr>
<td>A-2</td>
<td>Register Notation</td>
<td>A-2</td>
</tr>
<tr>
<td>B-1</td>
<td>Command List</td>
<td>B-5</td>
</tr>
<tr>
<td>B-2</td>
<td>Services</td>
<td>B-14</td>
</tr>
<tr>
<td>B-3</td>
<td>Vector Table Entries</td>
<td>B-22</td>
</tr>
<tr>
<td>C-1</td>
<td>Machine Code to Instruction Cross Reference</td>
<td>C-2</td>
</tr>
<tr>
<td>D-1</td>
<td>Programming Aid</td>
<td>D-1</td>
</tr>
<tr>
<td>E-1</td>
<td>Control Characters</td>
<td>E-2</td>
</tr>
<tr>
<td>E-2</td>
<td>Graphic Characters</td>
<td>E-3</td>
</tr>
<tr>
<td>F-1</td>
<td>Opcode Map</td>
<td>F-2</td>
</tr>
<tr>
<td>F-2</td>
<td>Indexed Addressing Mode Data</td>
<td>F-3</td>
</tr>
<tr>
<td>H-1</td>
<td>Powers of 2; Powers of 16</td>
<td>H-1</td>
</tr>
<tr>
<td>H-2</td>
<td>Hexadecimal and Decimal Conversion Chart</td>
<td>H-2</td>
</tr>
</tbody>
</table>
SECTION 1
GENERAL DESCRIPTION

1.1 INTRODUCTION

This section contains a general description of the Motorola MC6809 and MC6809E Microprocessor Units (MPU). Pin assignments and a brief description of each input/output signal are also given. The term MPU, processor, or M6809 will be used throughout this manual to refer to both the MC6809 and MC6809E processors. When a topic relates to only one of the processors, that specific designator (MC6809 or MC6809E) will be used.

1.2 FEATURES

The MC6809 and MC6809E microprocessors are greatly enhanced, upward compatible, computationally faster extensions of the MC6800 microprocessor.

Enhancements such as additional registers (a Y index register, a U stack pointer, and a direct page register) and instructions (such as MUL) simplify software design. Improved addressing modes have also been implemented.

Upward compatibility is guaranteed as MC6800 assembly language programs may be assembled using the Motorola MC6809 Macro Assembler. This code, while not as compact as native M6800 code, is, in most cases, 100% functional.

Both address and data are available from the processor earlier in an instruction cycle than from the MC6800 which simplifies hardware design. Two clock signals, E (the MC6800 $\phi 2$) and a new quadrature clock Q (which leads E by one-quarter cycle) also simplify hardware design.

A memory ready (MRDY) input is provided on the MC6809 for working with slow memories. This input stretches both the processor internal cycle and direct memory access bus cycle times but allows internal operations to continue at full speed. A direct memory access request (DMA/BREQ) input is provided for immediate memory access or dynamic memory refresh operations; this input halts the internal MC6809 clocks. Because the processor's registers are dynamic, an internal counter periodically recovers the bus from direct memory access operations and performs a true processor refresh cycle to allow unlimited length direct memory access operation. An interrupt acknowledge signal is available to allow development of vectoring by interrupt device hardware or detection of operating system calls.
Three prioritized, vectored, hardware interrupt levels are available: non-maskable, fast, and normal. The highest and lowest priority interrupts, non-maskable and interrupt request respectively, are the normal interrupts used in the M6800 family. A new interrupt on this processor is the fast interrupt request which provides faster service to its interrupt input by only stacking the program counter and condition code register and then servicing the interrupt.

Modern programming techniques such as position-independent, system independent, and reentrant programming are readily supported by these processors.

A Memory Management Unit (MMU), the MC6829, allows a M6809 based system to address a two megabyte memory space. Note: An arbitrary number of tasks may be supported — slower — with software.

This advanced family of processors is compatible with all M6800 peripheral parts.

1.3 SOFTWARE FEATURES

Some of the software features of these processors are itemized in the following paragraphs. Programs developed for the MC6800 can be easily converted for use with the MC6809 or MC6809E by running the source code through a M6809 Macro Assembler or any one of the many cross assemblers that are available.

The addressing modes of any microprocessor provide it with the capability to efficiently address memory to obtain data and instructions. The MC6809 and MC6809E have a versatile set of addressing modes which allow them to function using modern programming techniques.

The addressing modes and instructions of the MC6809 and MC6809E are upward compatible with the MC6800. The old addressing modes have been retained and many new ones have been added.

A direct page register has been added which allows a 256 byte “direct” page anywhere in the 64K logical address space. The direct page register is used to hold the most-significant byte of the address used in direct addressing and decrease the time required for address calculation.

Branch relative addressing to anywhere in the memory map (-32768 to +32767) is available.

Program counter relative addressing is also available for data access as well as branch instructions.

The indexed addressing modes have been expanded to include:

- 0-, 5-, 8-, 16-bit constant offsets,
- 8- or 16-bit accumulator offsets,
- autoncrement/decrement (stack operation).
In addition, most indexed addressing modes may have an additional level of indirection added.

Any or all registers may be pushed on to or pulled from either stack with a single instruction.

A multiply instruction is included which multiplies unsigned binary numbers in accumulators A and B and places the unsigned result in the 16-bit accumulator D. This unsigned multiply instruction also allows signed or unsigned multiple precision multiplication.

1.4 PROGRAMMING MODEL

The programming model (Figure 1-1) for these processors contains five 16-bit and four 8-bit registers that are available to the programmer.

![Programming Model Diagram]

**Figure 1-1. Programming Model**

1.5 INDEX REGISTERS \((X, Y)\)

The index registers are used during the indexed addressing modes. The address information in an index register is used in the calculation of an effective address. This address may be used to point directly to data or may be modified by an optional constant or register offset to produce the effective address.

1.6 STACK POINTER REGISTERS \((U, S)\)

Two stack pointer registers are available in these processors. They are: a user stack pointer register \((U)\) controlled exclusively by the programmer, and a hardware stack pointer register \((S)\) which is used automatically by the processor during subroutine calls.
and interrupts, but may also be used by the programmer. Both stack pointers always point to the top of the stack.

These registers have the same indexed addressing mode capabilities as the index registers, and also support push and pull instructions. All four indexable registers (X, Y, U, S) are referred to as pointer registers.

1.7 PROGRAM COUNTER (PC)

The program counter register is used by these processors to store the address of the next instruction to be executed. It may also be used as an index register in certain addressing modes.

1.8 ACCUMULATOR REGISTERS (A, B, D)

The accumulator registers (A, B) are general-purpose 8-bit registers used for arithmetic calculations and data manipulation.

Certain instructions concatenate these registers into one 16-bit accumulator with register A positioned as the most-significant byte. When concatenated, this register is referred to as accumulator D.

1.9 DIRECT PAGE REGISTER (DP)

This 8-bit register contains the most-significant byte of the address to be used in the direct addressing mode. The contents of this register are concatenated with the byte following the direct addressing mode operation code to form the 16-bit effective address. The direct page register contents appear as bits A15 through A8 of the address. This register is automatically cleared by a hardware reset to ensure M6800 compatibility.

1.10 CONDITION CODE REGISTER (CC)

The condition code register contains the condition codes and the interrupt masks as shown in Figure 1-2.

![Figure 1-2. Condition Code Register](image)

1-4
1.10.1 CONDITION CODE BITS. Five bits in the condition code register are used to indicate the results of instructions that manipulate data. They are: half carry (H), negative (N), zero (Z), overflow (V), and carry (C). The effect each instruction has on these bits is given in the detail information for each instruction (see Appendix A).

1.10.1.1 Half Carry (H), Bit 5. This bit is used to indicate that a carry was generated from bit three in the arithmetic logic unit as a result of an 8-bit addition. This bit is undefined in all subtract-like instructions. The decimal addition adjust (DAA) instruction uses the state of this bit to perform the adjust operation.

1.10.1.2 Negative (N), Bit 3. This bit contains the value of the most-significant bit of the result of the previous data operation.

1.10.1.3 Zero (Z), Bit 2. This bit is used to indicate that the result of the previous operation was zero.

1.10.1.4 Overflow (V), Bit 1. This bit is used to indicate that the previous operation caused a signed arithmetic overflow.

1.10.1.5 Carry (C), Bit 0. This bit is used to indicate that a carry or a borrow was generated from bit seven in the arithmetic logic unit as a result of an 8-bit mathematical operation.

1.10.2 INTERRUPT MASK BITS AND STACKING INDICATOR. Two bits (I and F) are used as mask bits for the interrupt request and the fast interrupt request inputs. When either or both of these bits are set, their associated input will not be recognized.

One bit (E) is used to indicate how many registers (all, or only the program counter and condition code) were stacked during the last interrupt.

1.10.2.1 Fast Interrupt Request Mask (F), Bit 6. This bit is used to mask (disable) any fast interrupt request line (FIRQ). This bit is set automatically by a hardware reset or after recognition of another interrupt. Execution of certain instructions such as SWI will also inhibit recognition of a FIRQ input.

1.10.2.2 Interrupt Request Mask (I), Bit 4. This bit is used to mask (disable) any interrupt request input (IRQ). This bit is set automatically by a hardware reset or after recognition of another interrupt. Execution of certain instructions such as SWI will also inhibit recognition of an IRQ input.
1.10.2.3 Entire Flag (E), Bit 7. This bit is used to indicate how many registers were stacked. When set, all the registers were stacked during the last interrupt stacking operation. When clear, only the program counter and condition code registers were stacked during the last interrupt.

The state of the E bit in the stacked condition code register is used by the return from interrupt (RTI) instruction to determine the number of registers to be unstacked.

1.11 PIN ASSIGNMENTS AND SIGNAL DESCRIPTION

Figure 1-3 shows the pin assignments for the processors. The following paragraphs provide a short description of each of the input and output signals.

![Processor Pin Assignments Diagram]

**Figure 1-3. Processor Pin Assignments**

1.11.1 MC6809 CLOCKS. The MC6809 has five pins committed to developing the clock signals needed for internal and system operation. They are: the oscillator pins EXTL and XTAL; the standard M6800 enable (E) clock; and a new, quadrature (Q) clock.

1.11.1.1 Oscillator (EXTL, XTAL). These pins are used to connect the processor's internal oscillator to an external, parallel-resonant crystal. These pins can also be used for input of an external TTL timing signal by grounding the XTAL pin and applying the input to the EXTL pin. The crystal or the external timing source is four times the resulting bus frequency.
1.11.2 Enable (E). The E clock is similar to the phase 2 (φ2) MC6800 bus timing clock. The leading edge indicates to memory and peripherals that the data is stable and to begin write operations. Data movement occurs after the Q clock is high and is latched on the trailing edge of E. Data is valid from the processor (during a write operation) by the rising edge of E.

1.11.3 Quadrature (Q). The Q clock leads the E clock by approximately one half of the E clock time. Address information from the processor is valid with the leading edge of the Q clock. The Q clock is a new signal in these processors and does not have an equivalent clock within the MC6800 bus timing.

1.11.2 MC6809E CLOCKS (E and Q). The MC6809E has two pins provided for the TTL clock signal inputs required for internal operation. They are the standard M6800 enable (E) clock and the quadrature (Q) clock. The Q input must lead the E input.

Addresses will be valid from the processor (on address delay time after the falling edge of E) and data will be latched from the bus by the falling edge of E. The Q input is fully TTL compatible. The E input is used to drive the internal MOS circuitry directly and therefore requires input levels above the normal TTL levels.

1.11.3 THREE STATE CONTROLS (TSC) (MC6809E). This input is used to place the address and data lines and the R/W line in the high-impedance state and allows the address bus to be shared with other bus masters.

1.11.4 LAST INSTRUCTION CYCLE (LIC) (MC6809E). This output goes high during the last cycle of every instruction and its high-to-low transition indicates that the first byte of an opcode will be latched at the end of the present bus cycle.

1.11.5 ADDRESS BUS (A0-A15). This 16-bit, unidirectional, three-state bus is used by the processor to provide address information to the address bus. Address information is valid on the rising edge of the Q clock. All 16 outputs are in the high-impedance state when the bus available (BA) signal is high, and for one bus cycle thereafter.

When the processor does not require the address bus for a data transfer, it outputs address FFFF₁₆, and read/write (R/W) high. This is a “dummy access” of the least-significant byte of the reset vector which replaces the valid memory address (VMA) functions of the MC6800. For the MC6809, the memory read signal internal circuitry inhibits stretching of the clocks during non-access cycles.

1.11.6 DATA BUS (D0-D7). This 8-bit, bidirectional, three-state bus is the general purpose data path. All eight outputs are in the high-impedance state when the bus available (BA) output is high.
1.11.7 READ/WRITE (R/W). This output indicates the direction of data transfer on the data bus. A low indicates that the processor is writing onto the data bus; a high indicates that the processor is reading data from the data bus. The signal at the R/W output is valid at the leading edge of the Q clock. The R/W output is in the high-impedance state when the bus available (BA) output is high.

1.11.8 PROCESSOR STATE INDICATORS (BA, BS). The processor uses these two output lines to indicate the present processor state. These pins are valid with the leading edge of the Q clock.

The bus available (BA) output is used to indicate that the buses (address and data) and the read/write output are in the high-impedance state. This signal can be used to indicate to bus-sharing or direct memory access systems that the buses are available. When BA goes low, an additional dead cycle will elapse before the processor regains control of the buses.

The bus status (BS) output is used in conjunction with the BA output to indicate the present state of the processor. Table 1-1 is a listing of the BA and BS outputs and the processor states that they indicate. The following paragraphs briefly explain each processor state.

<table>
<thead>
<tr>
<th>BA</th>
<th>BS</th>
<th>Processor State</th>
</tr>
</thead>
<tbody>
<tr>
<td>0</td>
<td>0</td>
<td>Normal (Running)</td>
</tr>
<tr>
<td>0</td>
<td>1</td>
<td>Interrupt or Reset Acknowledge</td>
</tr>
<tr>
<td>1</td>
<td>0</td>
<td>Sync Acknowledge</td>
</tr>
<tr>
<td>1</td>
<td>1</td>
<td>Halt/Bus Grant Acknowledged</td>
</tr>
</tbody>
</table>

1.11.8.1 Normal. The processor is running and executing instructions.

1.11.8.2 Interrupt or Reset Acknowledge. This processor state is indicated during both cycles of a hardware vector fetch which occurs when any of the following interrupts have occurred: RESET, NMI, FIRQ, IRQ, SWI, SWI2, and SWI3.

This output, plus decoding of address lines A3 through A1 provides the user with an indication of which interrupt is being serviced.

1.11.8.3 Sync Acknowledge. The processor is waiting for an external synchronization input on an interrupt line. See SYNC instruction in Appendix A.

1.11.8.4 Halt/Bus Grant. The processor is halted or bus control has been granted to some other device.
1.11.9 **RESET (RESET)**. This input is used to reset the processor. A low input lasting longer than one bus cycle will reset the processor.

The reset vector is fetched from locations $\text{FFFE}$ and $\text{FFFF}$ when the processor enters the reset acknowledge state as indicated by the BA output being low and the BS output being high.

During initial power-on, the reset input should be held low until the clock oscillator is fully operational.

1.11.10 **INTERRUPTS.** The processor has three separate interrupt input pins: non-maskable interrupt (NMI), fast interrupt request (FIRQ), and interrupt request (IRQ). These interrupt inputs are latched by the falling edge of every Q clock except during cycle stealing operations where only the NMI input is latched. Using this point as a reference, a delay of at least one bus cycle will occur before the interrupt is recognized by the processor.

1.11.10.1 **Non-Maskable Interrupt (NMI).** A negative edge on this input requests that a non-maskable interrupt sequence be generated. This input, as the name indicates, cannot be masked by software and has the highest priority of the three interrupt inputs. After a reset has occurred, a NMI input will not be recognized by the processor until the first program load of the hardware stack pointer. The entire machine state is saved on the hardware stack during the processing of a non-maskable interrupt. This interrupt is internally blocked after a hardware reset until the stack pointer is initialized.

1.11.10.2 **Fast Interrupt Request (FIRQ).** This input is used to initiate a fast interrupt request sequence. Initiation depends on the F (fast interrupt request mask) bit in the condition code register being clear. This bit is set during reset. During the interrupt, only the contents of the condition code register and the program counter are stacked resulting in a short amount of time required to service this interrupt. This interrupt has a higher priority than the normal interrupt request (IRQ).

1.11.10.3 **Interrupt Request (IRQ).** This input is used to initiate what might be considered the "normal" interrupt request sequence. Initiation depends on the I (interrupt mask) bit in the condition code register being clear. This bit is set during reset. The entire machine state is saved on the hardware stack during processing of an IRQ input. This input has the lowest priority of the three hardware interrupts.

1.11.11 **MEMORY READ (MRDY) (MC6909).** This input allows extension of the E and Q clocks to allow a longer data access time. A low on this input allows extension of the E and Q clocks (E high and Q low) in integral multiples of quarter bus cycles (up to 10 cycles) to allow interface with slow memory devices.
Memory ready does not extend the E and Q clocks during non-valid memory access cycles and therefore the processor does not slow down for "don’t care" bus accesses. Memory ready may also be used to extend the E and Q clocks when an external device is using the halt and direct memory access/bus request inputs.

1.11.12 ADVANCED VALID MEMORY ADDRESS (AVMA) (MC6809E). This output signal indicates that the MC6809E will use the bus in the following bus cycle. This output is low when the MC6809E is in either a halt or sync state.

1.11.13 HALT. This input is used to halt the processor. A low input halts the processor at the end of the present instruction execution cycle and the processor remains halted indefinitely without loss of data.

When the processor is halted, the BA output is high to indicate that the buses are in the high-impedance state and the BS output is also high to indicate that the processor is in the halt/bus grant state.

During the halt/bus grant state, the processor will not respond to external real-time requests such as FIQ or IRQ. However, a direct memory access/bus request input will be accepted. A non-maskable interrupt or a reset input will be latched for processing later. The E and Q clocks continue to run during the halt/bus grant state.

1.11.14 DIRECT MEMORY ACCESS/BUS REQUEST (DMA/BREQ) (MC6809). This input is used to suspend program execution and make the buses available for another use such as a direct memory access or a dynamic memory refresh.

A low level on this input occurring during the Q clock high time suspends instruction execution at the end of the current cycle. The processor acknowledges acceptance of this input by setting the BA and BS outputs high to signify the bus grant state. The requesting device now has up to 15 bus cycles before the processor retrieves the bus for self-refresh.

Typically, a direct memory access controller will request to use the bus by setting the DMA/BREQ input low when E goes high. When the processor acknowledges this input by setting the BA and BS outputs high, that cycle will be a dead cycle used to transfer bus mastership to the direct memory access controller. False memory access during any dead cycle should be prevented by externally developing a system DMA/VMA signal which is low in any cycle when the BA output changes.

When the BA output goes low, either as a result of a direct memory access/bus request or a processor self-refresh, the direct memory access device should be removed from the bus. Another dead cycle will elapse before the processor accesses memory, to allow transfer of bus mastership without contention.

1.11.15 BUSY (MC6809E). This output indicates that bus re-arbitration should be deferred and provides the indivisible memory operation required for a "test-and-set" primitive.
This output will be high for the first two cycles of any Read-Modify-Write instruction, high during the first byte of a double-byte access, and high during the first byte of any indirect access or vector-fetch operation.

1.11.16 POWER. Two inputs are used to supply power to the processor: VCC is +5.0 ±5%, while VSS is ground or 0 volts.
SECTION 2
ADDRESSING MODES

2.1 INTRODUCTION

This section contains a description of each of the addressing modes available on these processors.

2.2 ADDRESSING MODES

The addressing modes available on the MC6809 and MC6809E are: Inherent, Immediate, Extended, Direct, Indexed (with various offsets and autoincrementing/decrementing), and Branch Relative. Some of these addressing modes require an additional byte after the opcode to provide additional addressing interpretation. This byte is called a postbyte.

The following paragraphs provide a description of each addressing mode. In these descriptions the term effective address is used to indicate the address in memory from which the argument for an instruction is fetched or stored, or from which instruction processing is to proceed.

2.2.1 INHERENT. The information necessary to execute the instruction is contained in the opcode. Some operations specifying only the index registers or the accumulators, and no other arguments, are also included in this addressing mode.

Example: MUL

2.2.2 IMMEDIATE. The operand is contained in one or two bytes immediately following the opcode. This addressing mode is used to provide constant data values that do not change during program execution. Both 8-bit and 16-bit operands are used depending on the size of the argument specified in the opcode.

Example:

LDA #CR
LDB #7
LDA #$F0
LDB #1110000
LDX #$8004

Another form of immediate addressing uses a postbyte to determine the registers to be manipulated. The exchange (EXG) and transfer (TFR) instructions use the postbyte as shown in Figure 2-1(A). The push and pull instructions use the postbyte to designate the registers to be pushed or pulled as shown in Figure 2-1(B).
2.2.3 EXTENDED. The effective address of the argument is contained in the two bytes following the opcode. Instructions using the extended addressing mode can reference arguments anywhere in the 64K addressing space. Extended addressing is generally not used in position independent programs because it supplies an absolute address.

Example: LDA @CAT

2.2.4 DIRECT. The effective address is developed by concatenation of the contents of the direct page register with the byte immediately following the opcode. The direct page register contents are the most-significant byte of the address. This allows accessing 256 locations within any one of 256 pages. Therefore, the entire addressing range is available for access using a single two-byte instruction.

Example: LDA >CAT

2.2.5 INDEXED. In these addressing modes, one of the pointer registers (X, Y, U, or S), and sometimes the program counter (PC) is used in the calculation of the effective address of the instruction operand. The basic types (and their variations) of indexed addressing available are shown in Table 2-1 along with the postbyte configuration used.

2.2.5.1 Constant Offset from Register. The contents of the register designated in the postbyte are added to a twos complement offset value to form the effective address of
the instruction operand. The contents of the designated register are not affected by this addition. The offset sizes available are:

No offset — designated register contains the effective address

5-bit — 16 to +15

8-bit — 128 to +127

16-bit — 32768 to +32767

<table>
<thead>
<tr>
<th>Mode Type</th>
<th>Variation</th>
<th>Direct</th>
<th>Indirect</th>
</tr>
</thead>
<tbody>
<tr>
<td>Constant Offset from Register</td>
<td>No Offset</td>
<td>1RR00100</td>
<td>1RR10100</td>
</tr>
<tr>
<td>(Twos Complement Offset)</td>
<td>5-Bit Offset</td>
<td>0RRnnnnn</td>
<td>Defaults to 8-bit</td>
</tr>
<tr>
<td></td>
<td>8-Bit Offset</td>
<td>1RR01000</td>
<td>1RR11000</td>
</tr>
<tr>
<td></td>
<td>16-Bit Offset</td>
<td>1RR01001</td>
<td>1RR11011</td>
</tr>
<tr>
<td>Accumulator Offset from Register</td>
<td>A Accumulator Offset</td>
<td>1RR00110</td>
<td>1RR10110</td>
</tr>
<tr>
<td>(Twos Complement Offset)</td>
<td>B Accumulator Offset</td>
<td>1RR00101</td>
<td>1RR10101</td>
</tr>
<tr>
<td></td>
<td>D Accumulator Offset</td>
<td>1RR01011</td>
<td>1RR11011</td>
</tr>
<tr>
<td>Auto Increment/Decrement from Register</td>
<td>Increment by 1</td>
<td>1RR00000</td>
<td>Not Allowed</td>
</tr>
<tr>
<td></td>
<td>Increment by 2</td>
<td>1RR00001</td>
<td>1RR10001</td>
</tr>
<tr>
<td></td>
<td>Decrement by 1</td>
<td>1RR00010</td>
<td>Not Allowed</td>
</tr>
<tr>
<td></td>
<td>Decrement by 2</td>
<td>1RR00011</td>
<td>1RR10011</td>
</tr>
<tr>
<td>Constant Offset from Program Counter</td>
<td>8-Bit Offset</td>
<td>1XX01100</td>
<td>1XX11000</td>
</tr>
<tr>
<td></td>
<td>16-Bit Offset</td>
<td>1XX01101</td>
<td>1XX11101</td>
</tr>
<tr>
<td>Extended Indirect</td>
<td>16-Bit Address</td>
<td>--------</td>
<td>10011111</td>
</tr>
</tbody>
</table>

Table 2-1. Postbyte Usage for Indexed Addressing Modes

The 5-bit offset value is contained in the postbyte. The 8- and 16-bit offset values are contained in the byte or bytes immediately following the postbyte. If the Motorola assembler is used, it will automatically determine the most efficient offset; thus, the programmer need not be concerned about the offset size.

Examples: LDA ,X LDY -64000,U LDB 0,Y LDA 17,PC LDX 84,000,S LDA There,PCR

2.2.5.2 Accumulator Offset from Register. The contents of the index or pointer register designed in the postbyte are temporarily added to the twos complement offset value contained in an accumulator (A, B, or D) also designated in the postbyte. Neither the designated register nor the accumulator contents are affected by this addition.

Example: LDA A,X LDA D,U LDA B,Y

2.2.5.3 AutoIncrement/Decrement from Register. This addressing mode works in a postincrementing or predecrementing manner. The amount of increment or decrement, one or two positions, is designated in the postbyte.
In the autoincrement mode, the contents of the effective address contained in the pointer register, designated in the postbyte, and then the pointer register is automatically incremented; thus, the pointer register is postincremented.

In the autodecrement mode, the pointer register, designated in the postbyte, is automatically decremented first and then the contents of the new address are used; thus, the pointer register is predecremented.

Examples:

<table>
<thead>
<tr>
<th>AutoIncrement</th>
<th>Autodecrement</th>
</tr>
</thead>
<tbody>
<tr>
<td>LDA ,X+</td>
<td>LDA , -X</td>
</tr>
<tr>
<td>LDA ,Y+</td>
<td>LDA , -Y</td>
</tr>
<tr>
<td>LDA ,S+</td>
<td>LDA , -S</td>
</tr>
<tr>
<td>LDA ,U+</td>
<td>LDA , -U</td>
</tr>
<tr>
<td>LDA ,LDX ,X+</td>
<td>LDA ,LDX , -X</td>
</tr>
<tr>
<td>LDA ,LDX ,Y+</td>
<td>LDA ,LDX , -Y</td>
</tr>
<tr>
<td>LDA ,LDX ,U+</td>
<td>LDA ,LDX , -U</td>
</tr>
<tr>
<td>LDA ,LDX ,S+</td>
<td>LDA ,LDX , -S</td>
</tr>
</tbody>
</table>

2.2.5.4 Indirection. When using indirectness, the effective address of the base indexed addressing mode is used to fetch two bytes which contain the final effective address of the operand. It can be used with all the indexed addressing modes and the program counter relative addressing mode.

2.2.5.5 Extended Indirect. The effective address of the argument is located at the address specified by the two bytes following the postbyte. The postbyte is used to indicate indirectness.

Example: LDA [$F000]

2.2.5.6 Program Counter Relative. The program counter can also be used as a pointer with either an 8- or 16-bit signed constant offset. The offset value is added to the program counter to develop an effective address. Part of the postbyte is used to indicate whether the offset is 8 or 16 bits.

2.2.6 BRANCH RELATIVE. This addressing mode is used when branches from the current instruction location to some other location relative to the current program counter are desired. If the test condition of the branch instruction is true, then the effective address is calculated (program counter plus twos complement offset) and the branch is taken. If the test condition is false, the processor proceeds to the next in-line instruction. Note that the program counter is always pointing to the next instruction when the offset is added. Branch relative addressing is always used in position independent programs for all control transfers.

For short branches, the byte following the branch instruction opcode is treated as an 8-bit signed offset to be used to calculate the effective address of the next instruction if the branch is taken. This is called a short relative branch and the range is limited to plus 127 or minus 128 bytes from the following opcode.

For long branches, the two bytes after the opcode are used to calculate the effective address. This is called a long relative branch and the range is plus 32,767 or minus 32,768
SECTION 3
INTERRUPT CAPABILITIES

3.1 INTRODUCTION

The MC6809 and MC6809E microprocessors have six vectored interrupts (three hardware and three software). The hardware interrupts are the non-maskable interrupt (NMI), the fast maskable interrupt request (FIRQ), and the normal maskable interrupt request (IRQ). The software interrupts consist of SWI, SWI2, and SWI3. When an interrupt request is acknowledged, all the processor registers are pushed onto the hardware stack, except in the case of FIRQ where only the program counter and the condition code register is saved, and control is transferred to the address in the interrupt vector. The priority of these interrupts is, highest to lowest, NMI, SWI, FIRQ, IRQ, SWI2, and SWI3. Figure 3-1 is a detailed flowchart of interrupt processing in these processors. The interrupt vector locations are given in Table 3-1. The vector locations contain the address for the interrupt routine.

Additional information on the SWI, SWI2, and SWI3 interrupts is given in Appendix A. The hardware interrupts, NMI, FIRQ, and IRQ are listed alphabetically at the end of Appendix A.

<table>
<thead>
<tr>
<th>Interrupt Description</th>
<th>Vector Location</th>
</tr>
</thead>
<tbody>
<tr>
<td>Reset (RESET)</td>
<td>FFFE FFFF</td>
</tr>
<tr>
<td>Non-Maskable Interrupt (NMI)</td>
<td>FFFC FFFD</td>
</tr>
<tr>
<td>Software Interrupt (SWI)</td>
<td>FFFA FFFB</td>
</tr>
<tr>
<td>Interrupt Request (IRQ)</td>
<td>FFF8 FFF9</td>
</tr>
<tr>
<td>Fast Interrupt Request (FIRQ)</td>
<td>FFF6 FFF7</td>
</tr>
<tr>
<td>Software Interrupt 2 (SWI2)</td>
<td>FFF4 FFF5</td>
</tr>
<tr>
<td>Software Interrupt 3 (SWI3)</td>
<td>FFF2 FFF3</td>
</tr>
<tr>
<td>Reserved</td>
<td>FFF0 FFF1</td>
</tr>
</tbody>
</table>

Table 3-1. Interrupt Vector Locations

3.2 NON-MASKABLE INTERRUPT (NMI)

The non-maskable interrupt is edge-sensitive in the sense that if it is sampled low one cycle after it has been sampled high, a non-maskable interrupt will be triggered. Because the non-maskable interrupt cannot be masked by execution of the non-maskable interrupt handler routine, it is possible to accept another non-maskable interrupt before executing the first instruction of the interrupt routine. A fatal error will exist if a non-maskable interrupt is repeatedly allowed to occur before completing the return from interrupt (RTI) instruction of the previous non-maskable interrupt request, since the stack...
will eventually overflow. This interrupt is especially applicable to gaining immediate processor response for powerfail, software dynamic memory refresh, or other non-delayable events.

3.3 FAST MASKABLE INTERRUPT REQUEST (FIRQ)

A low level on the FIRQ input with the F (fast interrupt request mask) bit in the condition code register clear triggers this interrupt sequence. The fast interrupt request provides fast interrupt response by stacking only the program counter and condition code register. This allows fast context switching with minimal overhead. If any registers are used by the interrupt routine then they can be saved by a single push instruction.

After accepting a fast interrupt request, the processor clears the E flag, saves the program counter and condition code register, and then sets both the I and F bits to mask any further IRQ and FIRQ interrupts. After servicing the original interrupt, the user may selectively clear the I and F bits to allow multiple-level interrupts if so desired.

3.4 NORMAL MASKABLE INTERRUPT REQUEST (IRQ)

A low level on the IRQ input with the I (interrupt request mask) bit in the condition code register clear triggers this interrupt sequence. The normal maskable interrupt request provides a slower hardware response to interrupts because it causes the entire machine state to be stacked. However, this means that interrupting software routines can use all processor resources without fear of damaging the interrupted routine. A normal interrupt request, having lower priority than the fast interrupt request, is prevented from interrupting the fast interrupt handler by the automatic setting of the I bit by the fast interrupt request handler.

After accepting a normal interrupt request, the processor sets the E flag, saves the entire machine state, and then sets the I bit to mask any further interrupt request inputs. After servicing the original interrupt, the user may clear the I bit to allow multiple-level normal interrupts.

All interrupt handling routines should return to the formerly executing tasks using a return from interrupt (RTI) instruction. This instruction recovers the saved machine state from the hardware stack and control is returned to the interrupted program. If the recovered E bit is clear, it indicates that a fast interrupt request occurred and only the program counter address and condition code register are to be recovered.

3.5 SOFTWARE INTERRUPTS (SW1, SW12, SW13)

The software interrupts cause the processor to go through the normal interrupt request sequence of stacking the complete machine state even though the interrupting source is the processor itself. These interrupts are commonly used for program debugging and for calls to an operating system.
Normal processing of the SWI input sets the I and F bits to prevent either of these interrupt requests from affecting the completion of a software interrupt request. The remaining software interrupt request inputs (SWI2 and SWI3) do not have the priority of the SWI input and therefore do not mask the two hardware interrupt request inputs (FIIRQ and IRQ).
Figure 3-1. Interrupt Processing Flowchart

NOTES: 1. Asserting RESET will result in entering the reset sequence from any point in the flowchart.
2. BUSY is high during first vector fetch cycle (MC6809E).
SECTION 4
PROGRAMMING

4.1 INTRODUCTION

These processors are designed to be source-code compatible with the M6800 to make use of the substantial existing base of M6800 software and training. However, this asset should not overshadow the capabilities built into these processors that allow more modern programming techniques such as position-independence, modular programming, and reentrancy/recursion to be used on a microprocessor-based system. A brief review of these methods is given in the following paragraphs.

4.1.1 POSITION INDEPENDENCE. A program is said to be "position-independent" if it will run correctly when the same machine code is positioned arbitrarily in memory. Such a program is useful in many different hardware configurations, and might be copied from a disk into RAM when the operating system first sees a request to use a system utility. Position-independent programs never use absolute (extended or direct) addressing: instead, inherent immediate, register, indexed and relative modes are used. In particular, there should be no jump (absolute) or jump to subroutine instructions nor should absolute addresses be used. A position-independent program is almost always preferable to a position-dependent program (although position-independent code is usually 5 to 10% slower than normal code).

4.1.2 MODULAR PROGRAMMING. Modular programming is another indication of quality code. A module is a program element which can be easily disconnected from the rest of the program either for re-use in a new environment or for replacement. A module is usually a subroutine (although a subroutine is not necessarily a module); frequently, the programmer isolates register changes internal to the module by pushing these registers onto the stack upon entry, and pulling them off the stack before the return. Isolating register changes in the called module, to that module alone, allows the code in the calling program to be more easily analyzed since it can be assumed that all registers (except those specifically used for parameter transfer) are unchanged by each called module. This leaves the processor's registers free at each level for loop counts, address comparisons, etc.

4.1.2.1 Local Storage. A clean method for allocating "local" storage is required both by position-independent programs as well as modular programs. Local or temporary storage is used to hold values only during execution of a module (or called modules) and is released upon return. One way to allocate local storage is to decrement the hardware stack
pointer(s) by the number of bytes needed. Interrupts will then leave this area intact and it can be de-allocated on exiting the module. A module will almost always need more temporary storage than just the MPU registers.

4.1.2.2 Global Storage. Even in a modular environment there may be a need for "global" values which are accessible by many modules within a given system. These provide a convenient means for storing values from one invocation to another invocation of the same routine. Global storage may be created as local storage at some level, and a pointer register (usually U) used to point at this area. This register is passed unchanged in all subroutines, and may be used to index into the global area.

4.1.3 Reentrancy/Recursion. Many programs will eventually involve execution in an interrupt-driven environment. If the interrupt handlers are complex, they might well call the same routine which has just been interrupted. Therefore, to protect present programs against certain obsolescence, all programs should be written to be reentrant. A reentrant routine allocates different local variable storage upon each entry. Thus, a later entry does not destroy the processing associated with an earlier entry.

The same technique which was implemented to allow reentrancy also allows recursion. A recursive routine is defined as a routine that calls itself. A recursive routine might be written to simplify the solution of certain types of problems, especially those which have a data structure whose elements may themselves be a structure. For example, a parenthetical equation represents a case where the expression in parenthesis may be considered to be a value which is operated on by the rest of the equation. A programmer might choose to write an expression evaluator passing the parenthetical expression (which might also contain parenthetical expressions) in the call, and receive back the returned value of the expression within the parenthesis.

4.2 M6809 Capabilities

The following paragraphs briefly explain how the MC6809 is used with the programming techniques mentioned earlier.

4.2.1 Module Construction. A module can be defined as a logically self-contained and discrete part of a larger program. A properly constructed module accepts well defined inputs, carries out a set of processing actions, and produces a specified output. The use of parameters, local storage, and global storage by a program module is given in the following paragraphs. Since registers will be used inside the module (essentially a form of local storage), the first thing that is usually done at entry to a module is to push (save) them on to the stack. This can be done with one instruction (e.g., PSHS Y, X, B, A). After the body of the module is executed, the saved registers are collected, and a subroutine return is performed, at one time, by pulling the program counter from the stack (e.g., PULS A,B,X,Y,PC).
4.2.1.1 Parameters. Parameters may be passed to or from modules either in registers, if they will provide sufficient storage for parameter passage, or on the stack. If parameters are passed on the stack, they are placed there before calling the lower level module. The called module is then written to use local storage inside the stack as needed (e.g., ADDA offset, S). Notice that the required offset consists of the number of bytes pushed (upon entry), plus two from the stacked return address, plus the data offset at the time of the call. This value may be calculated, by hand, by drawing a "stack picture" diagram representing module entry, and assigning convenient mnemonics to these offsets with the assembler. Returned parameters replace those sent to the routine. If more parameters are to be returned on the stack than would normally be sent, space for their return is allocated by the calling routine before the actual call (if four additional bytes are to be returned, the caller would execute LEAS – 4, S to acquire the additional storage).

4.2.1.2 Local Storage. Local storage space is acquired from the stack while the present routine is executing and then returned to the stack prior to exit. The act of pushing registers which will be used in later calculations essentially saves those registers in temporary local storage. Additional local storage can easily be acquired from the stack e.g., executing LEAS – 2048, S acquires a buffer area running from the 0, S to 2047, S inclusive. Any byte in this area may be accessed directly by any instruction which has an indexed addressing mode. At the end of the routine, the area acquired for local storage is released (e.g., LEAS 2048, S) prior to the final pull. For cleaner programs, local storage should be allocated at entry to the module and released at the exit of the module.

4.2.1.3 Global Storage. The area required for global storage is also most effectively acquired from the stack, probably by the highest level routine in the standard package. Although this is local storage to the highest level routine, it becomes "global" by positioning a register to point at this storage, (sometimes referred to as a stack mark) then establishing the convention that all modules pass that same pointer value when calling lower level modules. In practice, it is convenient to leave this stack mark register unchanged in all modules, especially if global accesses are common. The highest level routine in the standard package would execute the following sequence upon entry (to initialize the global area):

```
PSHS U higher level mark, if any
TFR S, U new stack mark
LEAS – 17, U allocate global storage
```

Note that the U register now defines 17-bytes of locally allocated (permanent) globals (which are –1, U through –17, U) as well as other external globals (2, U and above) which have been passed on the stack by the routine which called the standard package. Any global may be accessed by any module using exactly the same offset value at any level (e.g., ROL, RAT, U; where RAT EQU – 11 has been defined). Furthermore, the values stacked prior to invoking the standard package may include pointers to data or I/O peripherals. Any indexed operation may be performed indexed indirect through those pointers, which means, for example, that the module need know nothing about the actual hardware configuration, except that (upon entry) the pointer to an I/O register has been placed at a given location on the stack.
4.2.2 POSITION-INDEPENDENT CODE. Position-independent code means that the same machine language code can be placed anywhere in memory and still function correctly. The M6809 has a long relative (16-bit offset) branch mode along with the common MC6800 branches, plus program-counter relative addressing. Program-counter relative addressing uses the program counter like an indexable register, which allows all instructions that reference memory to also reference data relative to the program counter. The M6809 also has load effective address (LEA) instructions which allow the user to point to data in a ROM in a position-independent manner.

An important rule for generating position-independent code is: NEVER USE ABSOLUTE ADDRESSING.

Program-counter relative addressing on the M6809 is a form of indexed addressing that uses the program counter as the base register for a constant-offset indexing operation. However, the M6809 assembler treats the PCR address field differently from that used in other indexed instructions. In PCR addressing, the assembly time location value is subtracted from the (constant) value of the PCR offset. The resulting distance to the desired symbol is the value placed into the machine language object code. During execution, the processor adds the value of the run time PC to the distance to get a position-independent absolute address.

The PCR indexed addressing form can be used to point at any location relative to the program regardless of position in memory. The PCR form of indexed addressing allows access to tables within the program space in a position-independent manner via use of the load effective address instruction.

In a program which is completely position-independent, some absolute locations are usually required, particularly for I/O. If the locations of I/O devices are placed on the stack (as globals) by a small setup routine before the standard package is invoked, all internal modules can do their I/O through that pointer (e.g., STA [ACIAD, U]), allowing the hardware to be easily changed, if desired. Only the single, small, and obvious setup routine need be rewritten for each different hardware configuration.

Global, permanent, and temporary values need to be easily available in a position-independent manner. Use the stack for this data since the stacked data is directly accessible. Stack the absolute address of I/O devices before calling any standard software package since the package can use the stacked addresses for I/O in any system.

The LEA instructions allow access to tables, data, or immediate values in the text of the program in a position-independent manner as shown in the following example:

```
LEAX MSG1,PCR
LBSR PDATA

MSG1 FCC /PRINT THIS!/
```
Here we wish to point at a message to be printed from the body of the program. By writing "MSG1, PCR" we signal the assembler to compute the distance between the present address (the address of the LBSR) and MSG1. This result is inserted as a constant into the LEA instruction which will be indexed from the program counter value at the time of execution. Now, no matter where the code is located, when it is executed the computer offset from the program counter will point at MSG1. This code is position-independent.

It is common to use space in the hardware stack for temporary storage. Space is made for temporary variables from 0,S through TEMP-1, S by decrementing the stack pointer equal to the length of required storage. We could use:

LEAS - TEMP,S.

Not only does this facilitate position-independent code but it is structured and helps reentrancy and recursion.

4.2.3 REENTRANT PROGRAMS. A program that can be executed by several different users sharing the same copy of it in memory is called reentrant. This is important for interrupt driven systems. This method saves considerable memory space, especially with large interrupt routines. Stacks are required for reentrant programs, and the M6809 can support up to four stacks by using the X and Y index registers as stack pointers.

Stacks are simple and convenient mechanisms for generating reentrant programs. Subroutines which use stacks for passing parameters and results can be easily made to be reentrant. Stack accesses use the indexed addressing mode for fast, efficient execution. Stack addressing is quick.

Pure code, or code that is not self-modifying, is mandatory to produce reentrant code. No internal information within the code is subject to modification. Reentrant code never has internal temporary storage, is simpler to debug, can be placed in ROM, and must be interruptable.

4.2.4 RECURSIVE PROGRAMS. A recursive program is one that can call itself. They are quite convenient for parsing mechanisms and certain arithmetic functions such as computing factorials. As with reentrant programming, stacks are very useful for this technique.

4.2.5 LOOPS. The usual structured loops (i.e., REPEAT...UNTIL, WHILE...DO, FOR..., etc.) are available in assembly language in exactly the same way a high-level language compiler could translate the construct for execution on the target machine. Using a FOR...NEXT loop as an example, it is possible to push the loop count, increment value, and termination value on the stack as variables local to that loop. On each pass through the loop, the working register is saved, the loop count picked up, the increment added in, and the result compared to the termination value. Based on this comparison, the loop counter might be updated, the working register recovered and the loop resumed, or the working register recovered and the loop variables de-allocated. Reasonable macros
could make the source form for loop trivial, even in assembly language. Such macros might reduce errors resulting from the use of multiple instructions simply to implement a standard control structure.

4.2.6 STACK PROGRAMMING. Many microprocessor applications require data stored as contiguous pieces of information in memory. The data may be temporary, that is, subject to change or it may be permanent. Temporary data will most likely be stored in RAM. Permanent data will most likely be stored in ROM.

It is important to allow the main program as well as subroutines access to this block of data, especially if arguments are to be passed from the main program to the subroutines and vice versa.

4.2.6.1 M6809 Stacking Operations. Stack pointers are markers which point to the stack and its internal contents. Although all four index registers may be used as stack registers, the S (hardware stack pointer) and the U (user stack pointer) are generally preferred because the push and pull instructions apply to these registers. Both are 16-bit indexable registers. The processor uses the S register automatically during interrupts and subroutine calls. The U register is free for any purpose needed. It is not affected by interrupts or subroutine calls implemented by the hardware.

Either stack pointer can be specified as the base address in indexed addressing. One use of the indirect addressing mode uses stack pointers to allow addresses of data to be passed to a subroutine on a stack as arguments to a subroutine. The subroutine can now reference the data with one instruction. High-level language calls that pass arguments by reference are now more efficiently coded. Also, each stack push or pull operation in a program uses a postbyte which specifies any register or set of registers to be pushed or pulled from either stack. With this option, the overhead associated with subroutine calls in both assembly and high-level language programs is greatly decreased. In fact, with the large number of instructions that use autoincrement and autodecrement, the M6809 can emulate a true stack computer architecture.

Using the S or U stack pointer, the order in which the registers are pushed or pulled is shown in Figure 4-1. Notice that we push "onto" the stack towards decreasing memory locations. The program counter is pushed first. Then the stack pointer is decremented and the "other" stack pointer is pushed onto the stack. Decrementing and storing continues until all the registers requested by the postbyte are pushed onto the stack. The stack pointer points to the top of the stack after the push operation.

The stacking order is specified by the processor. The stacking order is identical to the order used for all hardware and software interrupts. The same order is used even if a subset of the registers is pushed.

Without stacks, most modern block-structured high-level languages would be cumbersome to implement. Subroutine linkage is very important in high-level language generation. Paragraph 4.2.6.2 describes how to use a stack mark pointer for this important task.
Good programming practice dictates the use of the hardware stack for temporary storage. To reserve space, decrement the stack pointer by the amount of storage required with the instruction LEAS – TEMPS, S. This instruction makes space for temporary variables from 0,S through TEMPS – 1,S.

Figure 4-1. Stacking Order

4.2.6.2 Subroutine Linkage. In the highest level routine, global variables are sometimes considered to be local. Therefore, global storage is allocated at this point, but access to these same variables requires different offset values depending on subroutine depth. Because subroutine depth changes dynamically, the length may not be known beforehand. This problem is solved by assigning one pointer (U will be used in the following description, but X or Y could also be used) to “mark” a location on the hardware stack by using the instruction TFR S,U. If the programmer does this immediately prior to allocating global storage, then all variables will then be available at a constant negative offset location from this stack mark. If the stack is marked after the global variables are
allocated, then the global variables are available at a constant positive offset from U. Register U is then called the stack mark pointer. Recall that the hardware stack pointer may be modified by hardware interrupts. For this reason, it is fatal to use data referred to by a negative offset with respect to the hardware stack pointer, S.

4.2.6.3 Software Stacks. If more than two stacks are needed, autoincrement and autodecrement mode of addressing can be used to generate additional software stack pointers.

The X, Y, and U index registers are quite useful in loops for incrementing and decrementing purposes. The pointer is used for searching tables and also to move data from one area of memory to another (block moves). This autoincrement and autodecrement feature is available in the indexed addressing mode of the M6809 to facilitate such operations.

In autoincrement, the value contained in the index register (X or Y, U or S) is used as the effective address and then the register is incremented (preincremented). In autodecrement, the index register is first decremented and then used to obtain the effective address (predecremented). Postincrement or predecrement is always performed in this addressing mode. This is equivalent in operation to the push and pull from a stack. This equivalence allows the X and Y index registers to be used as software stack pointers. The indexed addressing mode can also implement an extra level of post indirection. This feature supports parameter and pointer operations.

4.2.7 REAL TIME PROGRAMMING. Real time programming requires special care. Sometimes a peripheral or task demands an immediate response from the processor, other times it can wait. Most real time applications are demanding in terms of processor response.

A common solution is to use the Interrupt capability of the processor in solving real time problems. Interrupts mean just that; they request a break in the current sequence of events to solve an asynchronous service request. The system designer must consider all variations of the conditions to be encountered by the system including software interaction with interrupts. As a result, problems due to software design are more common in Interrupt implementation code for real time programming than most other situations. Software timeouts, hardware interrupts, and program control Interrupts are typically used in solving real time programming problems.

4.3 PROGRAM DOCUMENTATION

Common sense dictates that a well documented program is mandatory. Comments are needed to explain each group of instructions since their use is not always obvious from looking at the code. Program boundaries and branch instructions need full clarification. Consider the following points when writing comments: up-to-date, accuracy, completeness, conciseness, and understandability.
Accurate documentation enables you and others to maintain and adapt programs for updating and/or additional use with other programs.

The following program documentation standards are suggested.

A) Each subroutine should have an associated header block containing at least the following elements:
   1) A full specification for this subroutine — including associated data structures — such that replacement code could be generated from this description alone.
   2) All usage of memory resources must be defined, including:
      a) All RAM needed from temporary (local) storage used during execution of this subroutine or called subroutines.
      b) All RAM needed for permanent storage (used to transfer values from one execution of the subroutine to future executions).
      c) All RAM accessed as global storage (used to transfer values from or to higher-level subroutines).
      d) All possible exit-state conditions, if these are to be used by calling routines to test occurrences internal to the subroutine.

B) Code internal to each subroutine should have sufficient associated line comments to help in understanding the code.

C) All code must be non-self-modifying and position-independent.

D) Each subroutine which includes a loop must be separately documented by a flowchart or pseudo high-level language algorithm.

E) Any module or subroutine should be executable starting at the first location and exit at the last location.

4.4 INSTRUCTION SET

The complete instruction set for the M6809 is given in Table 4-1.

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ABX</td>
<td>Add Accumulator B into Index Register X</td>
</tr>
<tr>
<td>ADC</td>
<td>Add with Carry into Register</td>
</tr>
<tr>
<td>ADD</td>
<td>Add Memory into Register</td>
</tr>
<tr>
<td>AND</td>
<td>Logical AND Memory into Register</td>
</tr>
<tr>
<td>ASL</td>
<td>Arithmetic Shift Left</td>
</tr>
<tr>
<td>ASR</td>
<td>Arithmetic Shift Right</td>
</tr>
<tr>
<td>BCC</td>
<td>Branch on Carry Clear</td>
</tr>
<tr>
<td>BCS</td>
<td>Branch on Carry Set</td>
</tr>
<tr>
<td>BEO</td>
<td>Branch on Equal</td>
</tr>
<tr>
<td>BGE</td>
<td>Branch on Greater Than or Equal to Zero</td>
</tr>
<tr>
<td>BGT</td>
<td>Branch on Greater</td>
</tr>
<tr>
<td>BHI</td>
<td>Branch if Higher</td>
</tr>
<tr>
<td>BHS</td>
<td>Branch if Higher or Same</td>
</tr>
<tr>
<td>BIT</td>
<td>Bit Test</td>
</tr>
<tr>
<td>BLE</td>
<td>Branch if Less than or Equal to Zero</td>
</tr>
</tbody>
</table>
Table 4-1. Instruction Set (Continued)

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>BLO</td>
<td>Branch on Lower</td>
</tr>
<tr>
<td>BLS</td>
<td>Branch on Lower or Same</td>
</tr>
<tr>
<td>BLT</td>
<td>Branch on Less than Zero</td>
</tr>
<tr>
<td>BMI</td>
<td>Branch on Minus</td>
</tr>
<tr>
<td>BNE</td>
<td>Branch Not Equal</td>
</tr>
<tr>
<td>BPL</td>
<td>Branch on Plus</td>
</tr>
<tr>
<td>BRA</td>
<td>Branch Always</td>
</tr>
<tr>
<td>BRN</td>
<td>Branch Never</td>
</tr>
<tr>
<td>BSR</td>
<td>Branch to Subroutine</td>
</tr>
<tr>
<td>BVC</td>
<td>Branch on Overflow Clear</td>
</tr>
<tr>
<td>BVS</td>
<td>Branch on Overflow Set</td>
</tr>
<tr>
<td>CLR</td>
<td>Clear</td>
</tr>
<tr>
<td>CMP</td>
<td>Compare Memory from a Register</td>
</tr>
<tr>
<td>COM</td>
<td>Complement</td>
</tr>
<tr>
<td>CWAI</td>
<td>Clear CC bits and Wait for Interrupt</td>
</tr>
<tr>
<td>DAA</td>
<td>Decimal Addition Adjust</td>
</tr>
<tr>
<td>DEC</td>
<td>Decrement</td>
</tr>
<tr>
<td>EOR</td>
<td>Exclusive OR</td>
</tr>
<tr>
<td>EXG</td>
<td>Exchange Registers</td>
</tr>
<tr>
<td>INC</td>
<td>Increment</td>
</tr>
<tr>
<td>JMP</td>
<td>Jump</td>
</tr>
<tr>
<td>JSR</td>
<td>Jump to Subroutine</td>
</tr>
<tr>
<td>LD</td>
<td>Load Register from Memory</td>
</tr>
<tr>
<td>LEA</td>
<td>Load Effective Address</td>
</tr>
<tr>
<td>LSL</td>
<td>Logical Shift Left</td>
</tr>
<tr>
<td>LSR</td>
<td>Logical Shift Right</td>
</tr>
<tr>
<td>MUL</td>
<td>Multiply</td>
</tr>
<tr>
<td>NEG</td>
<td>Negate</td>
</tr>
<tr>
<td>NOP</td>
<td>No Operation</td>
</tr>
<tr>
<td>OR</td>
<td>Inclusive OR Memory into Register</td>
</tr>
<tr>
<td>PSH</td>
<td>Push Registers</td>
</tr>
<tr>
<td>PUL</td>
<td>Pull Registers</td>
</tr>
<tr>
<td>ROL</td>
<td>Rotate Left</td>
</tr>
<tr>
<td>ROR</td>
<td>Rotate Right</td>
</tr>
<tr>
<td>RTI</td>
<td>Return from Interrupt</td>
</tr>
<tr>
<td>RTS</td>
<td>Return from Subroutine</td>
</tr>
<tr>
<td>SBC</td>
<td>Subtract with Borrow</td>
</tr>
<tr>
<td>SEX</td>
<td>Sign Extend</td>
</tr>
<tr>
<td>ST</td>
<td>Store Register into Memory</td>
</tr>
<tr>
<td>SUB</td>
<td>Subtract Memory from Register</td>
</tr>
<tr>
<td>SWI</td>
<td>Software Interrupt</td>
</tr>
<tr>
<td>SYNC</td>
<td>Synchronize to External Event</td>
</tr>
<tr>
<td>TFR</td>
<td>Transfer Register to Register</td>
</tr>
<tr>
<td>TST</td>
<td>Test</td>
</tr>
</tbody>
</table>
The instruction set can be functionally divided into five categories. They are:

8-Bit Accumulator and Memory Instructions
16-Bit Accumulator and Memory Instructions
Index Register/Stack Pointer Instructions
Branch Instructions
Miscellaneous Instructions

Tables 4-2 through 4-6 are listings of the M6809 Instructions and their variations grouped into the five categories listed.

Table 4-2. 8-Bit Accumulator and Memory Instructions

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADCA, ADCCB</td>
<td>Add memory to accumulator with carry</td>
</tr>
<tr>
<td>ADDA, ADDB</td>
<td>Add memory to accumulator</td>
</tr>
<tr>
<td>ANDA, ANDB</td>
<td>And memory with accumulator</td>
</tr>
<tr>
<td>ASL, ASLA, ASLB</td>
<td>Arithmetic shift of accumulator or memory left</td>
</tr>
<tr>
<td>ASR, ASRA, ASRB</td>
<td>Arithmetic shift of accumulator or memory right</td>
</tr>
<tr>
<td>BITA, BITB</td>
<td>Bit test memory with accumulator</td>
</tr>
<tr>
<td>CLR, CLRA, CLR</td>
<td>Clear accumulator or memory location</td>
</tr>
<tr>
<td>CMPA, CMPB</td>
<td>Compare memory from accumulator</td>
</tr>
<tr>
<td>COM, COMA, COMB</td>
<td>Complement accumulator or memory location</td>
</tr>
<tr>
<td>DAA</td>
<td>Decimal adjust A accumulator</td>
</tr>
<tr>
<td>DEC, DECA, DECB</td>
<td>Decrement accumulator or memory location</td>
</tr>
<tr>
<td>EORA, EORB</td>
<td>Exclusive or memory with accumulator</td>
</tr>
<tr>
<td>EXG R1, R2</td>
<td>Exchange R1 with R2 (R1, R2 = A, B, CC, DP)</td>
</tr>
<tr>
<td>INC, INA, INCB</td>
<td>Increment accumulator or memory location</td>
</tr>
<tr>
<td>LDA, LDB</td>
<td>Load accumulator from memory</td>
</tr>
<tr>
<td>LSL, LSLA, LSLB</td>
<td>Logical shift left accumulator or memory location</td>
</tr>
<tr>
<td>LSR, LSRA, LSRB</td>
<td>Logical shift right accumulator or memory location</td>
</tr>
<tr>
<td>MUL</td>
<td>Unsigned multiply (A x B = D)</td>
</tr>
<tr>
<td>NEG, NEGA, NEGB</td>
<td>Negate accumulator or memory</td>
</tr>
<tr>
<td>ORA, ORB</td>
<td>Or memory with accumulator</td>
</tr>
<tr>
<td>ROL, ROLA, ROLB</td>
<td>Rotate accumulator or memory left</td>
</tr>
<tr>
<td>ROR, RORA, RORB</td>
<td>Rotate accumulator or memory right</td>
</tr>
<tr>
<td>SBCA, SBCB</td>
<td>Subtract memory from accumulator with borrow</td>
</tr>
<tr>
<td>STA, STB</td>
<td>Store accumulator to memory</td>
</tr>
<tr>
<td>SUBA, SUBB</td>
<td>Subtract memory from accumulator</td>
</tr>
<tr>
<td>TST, TSTA, TSTB</td>
<td>Test accumulator or memory location</td>
</tr>
<tr>
<td>TFR R1, R2</td>
<td>Transfer R1 to R2 (R1, R2 = A, B, CC, DP)</td>
</tr>
</tbody>
</table>

NOTE: A, B, CC, or DP may be pushed to (pulled from) either stack with PSHS, PSHU (PULS, PULL) instructions.
### Table 4-3. 16-Bit Accumulator and Memory Instructions

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ADDD</td>
<td>Add memory to D accumulator</td>
</tr>
<tr>
<td>CMPD</td>
<td>Compare memory from D accumulator</td>
</tr>
<tr>
<td>EXG D, R</td>
<td>Exchange D with X, Y, S, U, or PC</td>
</tr>
<tr>
<td>LDD</td>
<td>Load D accumulator from memory</td>
</tr>
<tr>
<td>SEX</td>
<td>Sign Extend B accumulator into A accumulator</td>
</tr>
<tr>
<td>STD</td>
<td>Store D accumulator to memory</td>
</tr>
<tr>
<td>SUBD</td>
<td>Subtract memory from D accumulator</td>
</tr>
<tr>
<td>TFR D, R</td>
<td>Transfer D to X, Y, S, U, or PC</td>
</tr>
<tr>
<td>TFR R, D</td>
<td>Transfer X, Y, S, U, or PC to D</td>
</tr>
</tbody>
</table>

**NOTE:** D may be pushed (pulled) to either stack with PSHS, PSHU (PULS, PULU) instructions.

### Table 4-4. Index/Stack Pointer Instructions

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>CMPS, CMPU</td>
<td>Compare memory from stack pointer</td>
</tr>
<tr>
<td>CMPX, CMPY</td>
<td>Compare memory from index register</td>
</tr>
<tr>
<td>EXG R1, R2</td>
<td>Exchange D, X, Y, S, U or PC with D, X, Y, S, U or PC</td>
</tr>
<tr>
<td>LEAS, LEAU</td>
<td>Load effective address into stack pointer</td>
</tr>
<tr>
<td>LEAX, LEAY</td>
<td>Load effective address into index register</td>
</tr>
<tr>
<td>LDS, LDU</td>
<td>Load stack pointer from memory</td>
</tr>
<tr>
<td>LDX, LDY</td>
<td>Load index register from memory</td>
</tr>
<tr>
<td>PSHS</td>
<td>Push A, B, CC, DP, D, X, Y, U, or PC onto hardware stack</td>
</tr>
<tr>
<td>FSHU</td>
<td>Push A, B, CC, DP, D, X, Y, X, or PC onto user stack</td>
</tr>
<tr>
<td>PULS</td>
<td>Pull A, B, CC, DP, D, X, Y, U, or PC from hardware stack</td>
</tr>
<tr>
<td>PULU</td>
<td>Pull A, B, CC, DP, D, X, Y, S, or PC from hardware stack</td>
</tr>
<tr>
<td>STS, STU</td>
<td>Store stack pointer to memory</td>
</tr>
<tr>
<td>STX, STY</td>
<td>Store index register to memory</td>
</tr>
<tr>
<td>TFR R1, R2</td>
<td>Transfer D, X, Y, S, U, or PC to D, X, Y, S, U, or PC</td>
</tr>
<tr>
<td>ABX</td>
<td>Add B accumulator to X (unsigned)</td>
</tr>
</tbody>
</table>

4-12
### Table 4-5. Branch Instructions

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>BEQ, LBEQ</td>
<td>Branch if equal</td>
</tr>
<tr>
<td>BNE, LBNE</td>
<td>Branch if not equal</td>
</tr>
<tr>
<td>BMI, LBMI</td>
<td>Branch if minus</td>
</tr>
<tr>
<td>BPL, LBPL</td>
<td>Branch if plus</td>
</tr>
<tr>
<td>BCS, LBCS</td>
<td>Branch if carry set</td>
</tr>
<tr>
<td>BCC, LBCC</td>
<td>Branch if carry clear</td>
</tr>
<tr>
<td>BVS, LBVS</td>
<td>Branch if overflow set</td>
</tr>
<tr>
<td>BVC, LBVC</td>
<td>Branch if overflow clear</td>
</tr>
</tbody>
</table>

**SIMPLE BRANCHES**

**SIGNED BRANCHES**

| BGT, LBGT   | Branch if greater (signed) |
| BVGT, LBGL | Branch if invalid twos complement result |
| BGE, LBGE  | Branch if greater or equal (signed) |
| BEQ, LBEO  | Branch if equal            |
| BNE, LBNE  | Branch if not equal        |
| BLE, LBLE  | Branch if less than or equal (signed) |
| BVC, LBVC  | Branch if valid twos complement result |
| BLT, LBLT  | Branch if less than (signed) |

**UNSIGNED BRANCHES**

| BHI, LBHI  | Branch if higher (unsigned) |
| BCC, LBCC  | Branch if higher or same (unsigned) |
| BHS, LBHS  | Branch if higher or same (unsigned) |
| BEQ, LBEO  | Branch if equal            |
| BNE, LBNE  | Branch if not equal        |
| BLS, LBLS  | Branch if lower or same (unsigned) |
| BCS, LBCS  | Branch if lower (unsigned) |
| BLO, LBLO  | Branch if lower (unsigned) |

**OTHER BRANCHES**

| BSR, LB5R  | Branch to subroutine       |
| BRA, LBRA  | Branch always              |
| BRN, LBRN  | Branch never               |

### Table 4-6. Miscellaneous Instructions

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Description</th>
</tr>
</thead>
<tbody>
<tr>
<td>ANDCC</td>
<td>AND condition code register</td>
</tr>
<tr>
<td>CWAII</td>
<td>AND condition code register, then wait for interrupt</td>
</tr>
<tr>
<td>NOP</td>
<td>No operation</td>
</tr>
<tr>
<td>ORCC</td>
<td>OR condition code register</td>
</tr>
<tr>
<td>JMP</td>
<td>Jump</td>
</tr>
<tr>
<td>JSR</td>
<td>Jump to subroutine</td>
</tr>
<tr>
<td>RTI</td>
<td>Return from interrupt</td>
</tr>
<tr>
<td>RTS</td>
<td>Return from subroutine</td>
</tr>
<tr>
<td>SWI, SWI2, SWI3</td>
<td>Software interrupt (absolute indirect)</td>
</tr>
<tr>
<td>SYNC</td>
<td>Synchronize with interrupt line</td>
</tr>
</tbody>
</table>

4-13/4-14
APPENDIX A
INSTRUCTION SET DETAILS

A.1 INTRODUCTION

This appendix contains detailed information about each instruction in the MC6809 instruction set. They are arranged in an alphabetical order with the mnemonic heading set in larger type for easy reference.

A.2 NOTATION

In the operation description for each instruction, symbols are used to indicate the operation. Table A-1 lists these symbols and their meanings. Abbreviations for the various registers, bits, and bytes are also used. Table A-2 lists these abbreviations and their meanings.

Table A-1. Operation Notation

<table>
<thead>
<tr>
<th>Symbol</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>-</td>
<td>Is transferred to</td>
</tr>
<tr>
<td>A</td>
<td>Boolean AND</td>
</tr>
<tr>
<td>V</td>
<td>Boolean OR</td>
</tr>
<tr>
<td>•</td>
<td>Boolean exclusive OR</td>
</tr>
<tr>
<td>(Overline)</td>
<td>Boolean NOT</td>
</tr>
<tr>
<td>:</td>
<td>Concatenation</td>
</tr>
<tr>
<td>+</td>
<td>Arithmetic plus</td>
</tr>
<tr>
<td>-</td>
<td>Arithmetic minus</td>
</tr>
<tr>
<td>X</td>
<td>Arithmetic multiply</td>
</tr>
</tbody>
</table>
Table A-2. Register Notation

<table>
<thead>
<tr>
<th>Abbreviation</th>
<th>Meaning</th>
</tr>
</thead>
<tbody>
<tr>
<td>ACCA or A</td>
<td>Accumulator A</td>
</tr>
<tr>
<td>ACCB or B</td>
<td>Accumulator B</td>
</tr>
<tr>
<td>ACCA:ACCBB or D</td>
<td>Double accumulator D</td>
</tr>
<tr>
<td>ACCX</td>
<td>Either accumulator A or B</td>
</tr>
<tr>
<td>CCR or CC</td>
<td>Condition code register</td>
</tr>
<tr>
<td>DPR or DP</td>
<td>Direct page register</td>
</tr>
<tr>
<td>EA</td>
<td>Effective address</td>
</tr>
<tr>
<td>IFF</td>
<td>If and only if</td>
</tr>
<tr>
<td>IX or X</td>
<td>Index register X</td>
</tr>
<tr>
<td>IY or Y</td>
<td>Index register Y</td>
</tr>
<tr>
<td>LSN</td>
<td>Least significant nibble</td>
</tr>
<tr>
<td>M</td>
<td>Memory location</td>
</tr>
<tr>
<td>MI</td>
<td>Memory immediate</td>
</tr>
<tr>
<td>MSN</td>
<td>Most significant nibble</td>
</tr>
<tr>
<td>PC</td>
<td>Program counter</td>
</tr>
<tr>
<td>R</td>
<td>A register before the operation</td>
</tr>
<tr>
<td>R'</td>
<td>A register after the operation</td>
</tr>
<tr>
<td>TEMP</td>
<td>Temporary storage location</td>
</tr>
<tr>
<td>xH</td>
<td>Most significant byte of any 16-bit register</td>
</tr>
<tr>
<td>xL</td>
<td>Least significant byte of any 16-bit register</td>
</tr>
<tr>
<td>Sp or S</td>
<td>Hardware Stack pointer</td>
</tr>
<tr>
<td>Us or U</td>
<td>User Stack pointer</td>
</tr>
<tr>
<td>P</td>
<td>A memory argument with Immediate, Direct, Extended, and Indexed addressing modes</td>
</tr>
<tr>
<td>Q</td>
<td>A read-modify-write argument with Direct, Indexed, and Extended addressing modes</td>
</tr>
<tr>
<td>( )</td>
<td>The data pointed to by the enclosed (16-bit address)</td>
</tr>
<tr>
<td>dd</td>
<td>8-bit branch offset</td>
</tr>
<tr>
<td>DDDD</td>
<td>16-bit branch offset</td>
</tr>
<tr>
<td>/</td>
<td>Immediate value follows</td>
</tr>
<tr>
<td>$</td>
<td>Hexadecimal value follows</td>
</tr>
<tr>
<td>[ ]</td>
<td>Indirection</td>
</tr>
<tr>
<td>′</td>
<td>Indicates indexed addressing</td>
</tr>
</tbody>
</table>
ABX  
Add Accumulator B into Index Register X

Source Form:        ABX
Operation:          IX' ← IX + ACCB
Condition Codes:    Not affected.
Description:        Add the 8-bit unsigned value in accumulator B into index register X.
Addressing Mode:    Inherent
ADC
Add with Carry into Register

Source Forms: ADGA P; ADCB P

Operation: \( R' \leftarrow R + M + C \)

Condition Codes:
- \( H \) — Set if a half-carry is generated; cleared otherwise.
- \( N \) — Set if the result is negative; cleared otherwise.
- \( Z \) — Set if the result is zero; cleared otherwise.
- \( V \) — Set if an overflow is generated; cleared otherwise.
- \( C \) — Set if a carry is generated; cleared otherwise.

Description: Adds the contents of the C (carry) bit and the memory byte into an 8-bit accumulator.

Addressing Modes:
- Immediate
- Extended
- Direct
- Indexed
ADD (8-Bit)  Add Memory into Register  ADD (8-Bit)

Source Forms:  ADDA P; ADDB P

Operation:  \( R' = R + M \)

Condition Codes:
- \( H \) — Set if a half-carry is generated; cleared otherwise.
- \( N \) — Set if the result is negative; cleared otherwise.
- \( Z \) — Set if the result is zero; cleared otherwise.
- \( V \) — Set if an overflow is generated; cleared otherwise.
- \( C \) — Set if a carry is generated; cleared otherwise.

Description: Adds the memory byte into an 8-bit accumulator.

Addressing Modes:
- Immediate
- Extended
- Direct
- Indexed
ADD (16-Bit)  Add Memory Into Register  ADD (16-Bit)

Source Forms: ADDD P

Operation: \[ R' \leftarrow R + M:M + 1 \]

Condition Codes:
- H — Not affected.
- N — Set if the result is negative; cleared otherwise.
- Z — Set if the result is zero; cleared otherwise.
- V — Set if an overflow is generated; cleared otherwise.
- C — Set if a carry is generated; cleared otherwise.

Description: Adds the 16-bit memory value into the 16-bit accumulator

Addressing Modes: Immediate
- Extended
- Direct
- Indexed
AND
Logical AND Memory into Register

Source Forms: ANDA P; ANDB P

Operation: \[ R' \leftarrow R \land M \]

Condition Codes:
- \( H \) — Not affected.
- \( N \) — Set if the result is negative; cleared otherwise.
- \( Z \) — Set if the result is zero; cleared otherwise.
- \( V \) — Always cleared.
- \( C \) — Not affected.

Description: Performs the logical AND operation between the contents of an accumulator and the contents of memory location \( M \) and the result is stored in the accumulator.

Addressing Modes: Immediate
- Extended
- Direct
- Indexed
AND  Logical AND Immediate Memory into Condition Code Register  AND

Source Form: ANDCC #xx

Operation: R' = R ∧ M1

Condition Codes: Affected according to the operation.

Description: Performs a logical AND between the condition code register and the immediate byte specified in the instruction and places the result in the condition code register.

Addressing Mode: Immediate
Source Forms: ASL Q; ASLA; ASLB

Operation: \[ C \leftarrow \begin{array}{c} \vdots \\ b_7 \\ \vdots \end{array} \leftarrow 0 \]

Condition Codes:
- H — Undefined
- N — Set if the result is negative; cleared otherwise.
- Z — Set if the result is zero; cleared otherwise.
- V — Loaded with the result of the exclusive OR of bits six and seven of the original operand.
- C — Loaded with bit seven of the original operand.

Description: Shifts all bits of the operand one place to the left. Bit zero is loaded with a zero. Bit seven is shifted into the C (carry) bit.

Addressing Modes: Inherent
- Extended
- Direct
- Indexed
**Source Forms:** ASR Q; ASRA; ASRB

**Operation:**
```
b7  b6  b5  b4  b3  b2  b1  b0             C
```

**Condition Codes:**
- **H** — Undefined.
- **N** — Set if the result is negative; cleared otherwise.
- **Z** — Set if the result is zero; cleared otherwise.
- **V** — Not affected.
- **C** — Loaded with bit zero of the original operand.

**Description:** Shifts all bits of the operand one place to the right. Bit seven is held constant. Bit zero is shifted into the C (carry) bit.

**Addressing Modes:** Inherent
- Extended
- Direct
- Indexed
<table>
<thead>
<tr>
<th><strong>BCC</strong></th>
<th><strong>Branch on Carry Clear</strong></th>
<th><strong>BCC</strong></th>
</tr>
</thead>
<tbody>
<tr>
<td><strong>Source Forms:</strong></td>
<td>BCC dd; LBCC DDDD</td>
<td></td>
</tr>
</tbody>
</table>
| **Operation:** | TEMP — MI  
IFF C = 0 then PC' ← PC + TEMP |  |
| **Condition Codes:** | Not affected. |  |
| **Description:** | Tests the state of the C (carry) bit and causes a branch if it is clear. |  |
| **Addressing Mode:** | Relative |  |
| **Comments:** | Equivalent to BHS dd; LBHS DDDD |  |
BCS

Branch on Carry Set

Source Forms: BCS dd; LBCS DDDD

Operation: TEMP ← MI
IFF C = 1 then PC' ← PC + TEMP

Condition Codes: Not affected.

Description: Tests the state of the C (carry) bit and causes a branch if it is set.

Addressing Mode: Relative

Comments: Equivalent to BLO dd; LBLO DDDD
BEQ

Branch on Equal

Source Forms:  BEQ dd; LBEQ DDDD

Operation:    TEMP ← MI
               IFF Z = 1 then PC' ← PC + TEMP

Condition Codes:  Not affected.

Description:  Tests the state of the Z (zero) bit and causes a branch if it is set. When used after a subtract or compare operation, this instruction will branch if the compared values, signed or unsigned, were exactly the same.

Addressing Mode:  Relative
BGE
Branch on Greater than or Equal to Zero

Source Forms: BGE dd; LBGE DDDD

Operation:
TEMP ← MI
IFF [N • V] = 0 then PC' ← PC + TEMP

Condition Codes: Not affected.

Description: Causes a branch if the N (negative) bit and the V (overflow) bit are either both set or both clear. That is, branch if the sign of a valid twos complement result is, or would be, positive. When used after a subtract or compare operation on twos complement values, this instruction will branch if the register was greater than or equal to the memory operand.

Addressing Mode: Relative
BGT

Branch on Greater

Source Forms: BGT dd; LBGT DDDD

Operation: TEMP ← MI

IFF Z ∧ [N ∨ V] = 0 then PC' ← PC + TEMP

Condition Codes: Not affected.

Description: Causes a branch if the N (negative) bit and V (overflow) bit are either both set or both clear and the Z (zero) bit is clear. In other words, branch if the sign of a valid twos complement result is, or would be, positive and not zero. When used after a subtract or compare operation on twos complement values, this instruction will branch if the register was greater than the memory operand.

Addressing Mode: Relative
BHI
Branch If Higher

Source Forms: BHI dd; LBHI DDDD

Operation: TEMP ← MI
IFF [C v Z] = 0 then PC' ← PC + TEMP

Condition Codes: Not affected.

Description: Causes a branch if the previous operation caused neither a carry nor a zero result. When used after a subtract or compare operation on unsigned binary values, this instruction will branch if the register was higher than the memory operand.

Addressing Mode: Relative

Comments: Generally not useful after INC/DEC, LD/TST, and TST/CLR/COM instructions.
BHS Branch if Higher or Same

Source Forms: BHS dd; LBHS DDDD

Operation: TEMP ← MI
IFF C = 0 then PC' ← PC + MI

Condition Codes: Not affected.

Description: Tests the state of the C (carry) bit and causes a branch if it is clear. When used after a subtract or compare on unsigned binary values, this instruction will branch if the register was higher than or the same as the memory operand.

Addressing Mode: Relative

Comments: This is a duplicate assembly-language mnemonic for the single machine instruction BCC. Generally not useful after INC/DEC, LD/ST, and TST/CLR/COM instructions.
Source Form: Bit P

Operation: \( \text{TEMP} \leftarrow R \land M \)

Condition Codes:
- H — Not affected.
- N — Set if the result is negative; cleared otherwise.
- Z — Set if the result is zero; cleared otherwise.
- V — Always cleared.
- C — Not affected.

Description: Performs the logical AND of the contents of accumulator A or B and the contents of memory location M and modifies the condition codes accordingly. The contents of accumulator A or B and memory location M are not affected.

Addressing Modes: Immediate
Extended
Direct
Indexed
**BLE**

Branch on Less than or Equal to Zero

Source Forms: BLE dd; LBLE DDDD

Operation:

\[ \text{IFF } Z \lor [N \oplus V] = 1 \text{ then } PC' = PC + \text{TEMP} \]

Condition Codes: Not affected.

Description: Causes a branch if the exclusive OR of the N (negative) and V (overflow) bits is 1 or if the Z (zero) bit is set. That is, branch if the sign of a valid twos complement result is, or would be, negative. When used after a subtract or compare operation on twos complement values, this instruction will branch if the register was less than or equal to the memory operand.

Addressing Mode: Relative
Source Forms: BLO dd; LBLO DDDD

Operation: TEMP ← MI
IFF C = 1 then PC' ← PC + TEMP

Condition Codes: Not affected.

Description: Tests the state of the C (carry) bit and causes a branch if it is set. When used after a subtract or compare on unsigned binary values, this instruction will branch if the register was lower than the memory operand.

Addressing Mode: Relative

Comments: This is a duplicate assembly-language mnemonic for the single machine instruction BCS. Generally not useful after INC/DEC, LD/ST, and TST/CLR/COM instructions.
Source Forms: BLS dd; LBLS DDDD

Operation: TEMP ← MI
            IFF (C v Z) = 1 then PC' ← PC + TEMP

Condition Codes: Not affected.

Description: Causes a branch if the previous operation caused either a carry or a zero result. When used after a subtract or compare operation on unsigned binary values, this instruction will branch if the register was lower than or the same as the memory operand.

Addressing Mode: Relative

Comments: Generally not useful after INC/DEC, LD/ST, and TST/CLR/COM instructions.
BLT

Branch on Less than Zero

Source Forms: BLT dd; LBLT DDDD

Operation: TEMP ← MI
IFF [N or V] = 1 then PC' ← PC + TEMP

Condition Codes: Not affected.

Description: Causes a branch if either, but not both, of the N (negative) or V (overflow) bits is set. That is, branch if the sign of a valid twos complement result is, or would be, negative. When used after a subtract or compare operation on twos complement binary values, this instruction will branch if the register was less than the memory operand.

Addressing Mode: Relative
BMI

Source Forms: BMI dd; LBMI DDDD

Operation: TEMP ← MI
IFF N = 1 then PC' ← PC + TEMP

Condition Codes: Not affected.

Description: Tests the state of the N (negative) bit and causes a branch if set. That is, branch if the sign of the twos complement result is negative.

Addressing Mode: Relative

Comments: When used after an operation on signed binary values, this instruction will branch if the result is minus. It is generally preferred to use theLBLT instruction after signed operations.
BNE

Branch Not Equal

Source Forms: BNE dd; LBNE DDDD

Operation:
TEMP ← M1
IFF Z = 0 then PC' ← PC + TEMP

Condition Codes: Not affected.

Description: Tests the state of the Z (zero) bit and causes a branch if it is clear. When used after a subtract or compare operation on any binary values, this instruction will branch if the register is, or would be, not equal to the memory operand.

Addressing Mode: Relative
**BPL**

**Branch on Plus**

**Source Forms:**
BPL dd; LBPL DDDD

**Operation:**
TEMP ← MI
IFF N = 0 then PC' ← PC + TEMP

**Condition Codes:**
Not affected.

**Description:**
Tests the state of the N (negative) bit and causes a branch if it is clear. That is, branch if the sign of the twos complement result is positive.

**Addressing Mode:**
Relative

**Comments:**
When used after an operation on signed binary values, this instruction will branch if the result (possibly invalid) is positive. It is generally preferred to use the BGE instruction after signed operations.
BRA
Branch Always

Source Forms:  BRA dd; LBRA DDDD
Operation:     TEMP ← MI
               PC' ← PC + TEMP
Condition Codes: Not affected.
Description:   Causes an unconditional branch.
Addressing Mode: Relative
**BRN**  
*Branch Never*

**Source Forms:** BRN dd; LBRN DDDD

**Operation:** TEMP — MI

**Condition Codes:** Not affected.

**Description:** Does not cause a branch. This instruction is essentially a no operation, but has a bit pattern logically related to branch always.

**Addressing Mode:** Relative
BSR

Branch to Subroutine

Source Forms: BSR dd; LBSR DDDD

Operation:
TEMP ← MI
SP' ← SP - 1, (SP) ← PCL
SP' ← SP - 1, (SP) ← PCH
PC' ← PC + TEMP

Condition Codes: Not affected.

Description: The program counter is pushed onto the stack. The program counter is then loaded with the sum of the program counter and the offset.

Addressing Mode: Relative

Comments: A return from subroutine (RTS) instruction is used to reverse this process and must be the last instruction executed in a subroutine.
BVC

Branch on Overflow Clear

Source Forms:  BVC dd; LBVC DDDD

Operation:  TEMPM
IFF V = 0 then PC’ = PC + TEMP

Condition Codes:  Not affected.

Description:  Tests the state of the V (overflow) bit and causes a branch if it is clear. That is, branch if the twos complement result was valid. When used after an operation on twos complement binary values, this instruction will branch if there was no overflow.

Addressing Mode:  Relative
**BVS**

**Branch on Overflow Set**

**Source Forms:**

BVS dd; LBVS DDDD

**Operation:**

TEMP — MI
IFF V = 1 then PC' — PC + TEMP

**Condition Codes:**

Not affected.

**Description:**

Tests the state of the V (overflow) bit and causes a branch if it is set. That is, branch if the twos complement result was invalid. When used after an operation on twos complement binary values, this instruction will branch if there was an overflow.

**Addressing Mode:**

Relative

---

A-30
CLR

Source Form: CLR Q

Operation: TEMP — M
M — 0016

Condition Codes: H — Not affected.
N — Always cleared.
Z — Always set.
V — Always cleared.
C — Always cleared.

Description: Accumulator A or B or memory location M is loaded with 00000000.
Note that the EA is read during this operation.

Addressing Modes: Inherent
Extended
Direct
Indexed
CMP (8-Bit)  Compare Memory from Register  CMP (8-Bit)

Source Forms:  CMPA P; CMPB P

Operation:  TEMP ← R − M

Condition Codes:  H — Undefined.
N — Set if the result is negative; cleared otherwise.
Z — Set if the result is zero; cleared otherwise.
V — Set if an overflow is generated; cleared otherwise.
C — Set if a borrow is generated; cleared otherwise.

Description:  Compares the contents of memory location to the contents of the specified register and sets the appropriate condition codes. Neither memory location M nor the specified register is modified. The carry flag represents a borrow and is set to the inverse of the resulting binary carry.

Addressing Modes:  Immediate
Extended
Direct
Indexed
CMP (16-Bit) Compare Memory from Register CMP (16-Bit)

Source Forms: CMPD P; CMPX P; CMPY P; CMPLP P; CMPS P
Operation: TEMP ← R − M:M + 1
Condition Codes: H — Not affected.
N — Set if the result is negative; cleared otherwise.
Z — Set if the result is zero; cleared otherwise.
V — Set if an overflow is generated; cleared otherwise.
C — Set if a borrow is generated; cleared otherwise.

Description: Compares the 16-bit contents of the concatenated memory locations M:M + 1 to the contents of the specified register and sets the appropriate condition codes. Neither the memory locations nor the specified register is modified unless autoincrement or autodecrement are used. The carry flag represents a borrow and is set to the inverse of the resulting binary carry.

Addressing Modes: Immediate
Extended
Direct
Indexed
Complement

Source Forms: COM Q; COMA; COMB

Operation: \[ M' \leftarrow O + \bar{M} \]

Condition Codes:
- \( H \) — Not affected.
- \( N \) — Set if the result is negative; cleared otherwise.
- \( Z \) — Set if the result is zero; cleared otherwise.
- \( V \) — Always cleared.
- \( C \) — Always set.

Description: Replaces the contents of memory location \( M \) or accumulator \( A \) or \( B \) with its logical complement. When operating on unsigned values, only BEQ and BNE branches can be expected to behave properly following a COM instruction. When operating on twos complement values, all signed branches are available.

Addressing Modes:
- Inherent
- Extended
- Direct
- Indexed
CWAI
Clear CC bits and Wait for Interrupt

Source Form: CWAI #$XX  EFHINZVC

Operation:
CCR ← CCR ∧ MI (Possibly clear masks)
Set E (entire state saved)
SP′ ← SP − 1, (SP) ← PCL
SP′ ← SP − 1, (SP) ← PCH
SP′ ← SP − 1, (SP) ← USL
SP′ ← SP − 1, (SP) ← USH
SP′ ← SP − 1, (SP) ← IYL
SP′ ← SP − 1, (SP) ← IYH
SP′ ← SP − 1, (SP) ← IXL
SP′ ← SP − 1, (SP) ← IXH
SP′ ← SP − 1, (SP) ← DPR
SP′ ← SP − 1, (SP) ← ACCB
SP′ ← SP − 1, (SP) ← ACCA
SP′ ← SP − 1, (SP) ← CCR

Condition Codes: Affected according to the operation.

Description:
This instruction ANDs an immediate byte with the condition code
register which may clear the interrupt mask bits I and F, stacks the
entire machine state on the hardware stack and then looks for an in-
terrupt. When a non-masked interrupt occurs, no further machine
state information need be saved before vectoring to the interrupt
handling routine. This instruction replaced the MC6800 CLI WAI se-
quence, but does not place the buses in a high-impedance state. A
FIRQ (fast interrupt request) may enter its interrupt handler with its
entire machine state saved. The RTI (return from interrupt) instruc-
tion will automatically return the entire machine state after testing
the E (entire) bit of the recovered condition code register.

Addressing Mode: Immediate

Comments: The following immediate values will have the following results:
   FF = enable neither
   EF = enable IRQ
   BF = enable FIRQ
   AF = enable both
Source Form:  
DAA

Operation:  
ACCA' ← ACCA + CF (MSN):CF(LSN)
where CF is a Correction Factor, as follows: the CF for each nibble
(BCD) digit is determined separately, and is either 6 or 0.

Least Significant Nibble
CF(LSN) = 6 IFF 1) C = 1
   or 2) LSN > 9

Most Significant Nibble
CF(MSN) = 6 IFF 1) C = 1
   or 2) MSN > 9
   or 3) MSN > 8 and LSN > 9

Condition Codes:  
H — Not affected.
N — Set if the result is negative; cleared otherwise.
Z — Set if the result is zero; cleared otherwise.
V — Undefined.
C — Set if a carry is generated or if the carry bit was set before the
   operation; cleared otherwise.

Description:  
The sequence of a single-byte add instruction on accumulator A
(either ADDA or ADCA) and a following decimal addition adjust in-
struction results in a BCD addition with an appropriate carry bit.
Both values to be added must be in proper BCD form (each nibble
such that: 0 ≤ nibble ≤ 9). Multiple-precision addition must add the
carry generated by this decimal addition adjust into the next higher
digit during the add operation (ADCA) immediately prior to the next
decimal addition adjust.

Addressing Mode:  Inherent
**DEC**

*Decrement*

**Source Forms:**
DEC Q; DECA; DECB

**Operation:**
\[ M' = M - 1 \]

**Condition Codes:**
- **H** — Not affected.
- **N** — Set if the result is negative; cleared otherwise.
- **Z** — Set if the result is zero; cleared otherwise.
- **V** — Set if the original operand was 10000000; cleared otherwise.
- **C** — Not affected.

**Description:**
Subtract one from the operand. The carry bit is not affected, thus allowing this instruction to be used as a loop counter in multiple-precision computations. When operating on unsigned values, only BEQ and BNE branches can be expected to behave consistently. When operating on twos complement values, all signed branches are available.

**Addressing Modes:**
Inherent
Extended
Direct
Indexed
**EOR**

**Exclusive OR**

**Source Forms:**

EORA P; EORB P

**Operation:**

R' = R ⊕ M

**Condition Codes:**

H — Not affected.
N — Set if the result is negative; cleared otherwise.
Z — Set if the result is zero; cleared otherwise.
V — Always cleared.
C — Not affected.

**Description:**

The contents of memory location M is exclusive ORed into an 8-bit register.

**Addressing Modes:**

Immediate
Extended
Direct
Indexed
Source Form: EXG R1,R2
Operation: R1 ← R2
Condition Codes: Not affected (unless one of the registers is the condition code register).
Description: Exchanges data between two designated registers. Bits 3-0 of the postbyte define one register, while bits 7-4 define the other, as follows:

| 0000 = A:B  | 1000 = A  |
| 0001 = X    | 1001 = B  |
| 0010 = Y    | 1010 = CCR |
| 0011 = US   | 1011 = DPR |
| 0100 = SP   | 1100 = Undefined |
| 0101 = PC   | 1101 = Undefined |
| 0110 = Undefined | 1110 = Undefined |
| 0111 = Undefined | 1111 = Undefined |

Only like size registers may be exchanged. (8-bit with 8-bit or 16-bit with 16-bit.)

Addressing Mode: Immediate
INC

Increment

Source Forms: INC Q; INCA; INCB

Operation: M' = M + 1

Condition Codes:
H — Not affected.
N — Set if the result is negative; cleared otherwise.
Z — Set if the result is zero; cleared otherwise.
V — Set if the original operand was 01111111; cleared otherwise.
C — Not affected.

Description: Adds to the operand. The carry bit is not affected, thus allowing this instruction to be used as a loop counter in multiple-precision computations. When operating on unsigned values, only the BEQ and BNE branches can be expected to behave consistently. When operating on two's complement values, all signed branches are correctly available.

Addressing Modes: Inherent
                    Extended
                    Direct
                    Indexed
JMP

Jump

Source Form: JMP EA
Operation: PC' ← EA
Condition Codes: Not affected.
Description: Program control is transferred to the effective address.
Addressing Modes: Extended
                  Direct
                  Indexed
JSR

Jump to Subroutine

Source Form: JSR EA

Operation: SP′ ← SP − 1, (SP) ← PCL
SP′ ← SP − 1, (SP) ← PCH
PC′ ← EA

Condition Codes: Not affected.

Description: Program control is transferred to the effective address after storing the return address on the hardware stack. A RTS instruction should be the last executed instruction of the subroutine.

Addressing Modes: Extended
    Direct
    Indexed
LD (8-Bit) Load Register from Memory

Source Forms:  LDA P; LDB P
Operation:     R' ← M
Condition Codes:  H — Not affected.
                 N — Set if the loaded data is negative; cleared otherwise.
                 Z — Set if the loaded data is zero; cleared otherwise.
                 V — Always cleared.
                 C — Not affected.
Description:    Loads the contents of memory location M into the designated register.

Addressing Modes: Immediate
                 Extended
                 Direct
                 Indexed
LD (16-Bit)  Load Register from Memory  LD (16-Bit)

Source Forms:  LDD P; LDX P; LDY P; LDS P; LDU P

Operation:  \( R' \leftarrow M: M + 1 \)

Condition Codes:
- H — Not affected.
- N — Set if the loaded data is negative; cleared otherwise.
- Z — Set if the loaded data is zero; cleared otherwise.
- V — Always cleared.
- C — Not affected.

Description:  Load the contents of the memory location M:M+1 into the designated 16-bit register.

Addressing Modes:  Immediate
                 Extended
                 Direct
                 Indexed
LEA

Load Effective Address

Source Forms: LEAX, LEAY, LEAS, LEAU

Operation: R' ← EA

Condition Codes:
H — Not affected.
N — Not affected.
Z — LEAX, LEAY: Set if the result is zero; cleared otherwise.
LEAS, LEAU: Not affected.
V — Not affected.
C — Not affected.

Description:
Calculates the effective address from the indexed addressing mode and places the address in an indexable register.

LEAX and LEAY affect the Z (zero) bit to allow use of these registers as counters and for MC6800 INX/DEX compatibility.

LEAU and LEAS do not affect the Z bit to allow cleaning up the stack while returning the Z bit as a parameter to a calling routine, and also for MC6800 INS/DES compatibility.

Addressing Mode: Indexed

Comments:
Due to the order in which effective addresses are calculated internally, the LEAX, X + + and LEAX, X + do not add 2 and 1 respectively to the X register; but instead leave the X register unchanged. This also applies to the Y, U, and S registers. For the expected results, use the faster instruction LEAX 2, X and LEAX 1, X.

Some examples of LEA instruction uses are given in the following table.

<table>
<thead>
<tr>
<th>Instruction</th>
<th>Operation</th>
<th>Comment</th>
</tr>
</thead>
<tbody>
<tr>
<td>LEAX</td>
<td>X + 10 − X</td>
<td>Adds 5-bit constant 10 to X</td>
</tr>
<tr>
<td>LEAX</td>
<td>X + 500 − X</td>
<td>Adds 16-bit constant 500 to X</td>
</tr>
<tr>
<td>LEAY</td>
<td>Y + A − Y</td>
<td>Adds 8-bit accumulator to Y</td>
</tr>
<tr>
<td>LEAY</td>
<td>Y + D − Y</td>
<td>Adds 16-bit D accumulator to Y</td>
</tr>
<tr>
<td>LEAU</td>
<td>U − 10 − U</td>
<td>Subtracts 10 from U</td>
</tr>
<tr>
<td>LEAS</td>
<td>S − 10 − S</td>
<td>Used to reserve area on stack</td>
</tr>
<tr>
<td>LEAS</td>
<td>S + 10 − S</td>
<td>Used to ‘clean up’ stack</td>
</tr>
<tr>
<td>LEAX</td>
<td>S + 5 − X</td>
<td>Transfers as well as adds</td>
</tr>
</tbody>
</table>

A-45
Source Forms: LSL Q; LSLA; LSLB

Operation: \[ C \leftarrow \begin{array}{cccccc}
\text{b7} & \text{b6} & \text{b5} & \text{b4} & \text{b3} & \text{b2} & \text{b1} & \text{b0}
\end{array} \leftarrow 0 \]

Condition Codes: 
- \( H \) — Undefined.
- \( N \) — Set if the result is negative; cleared otherwise.
- \( Z \) — Set if the result is zero; cleared otherwise.
- \( V \) — Loaded with the result of the exclusive OR of bits six and seven of the original operand.
- \( C \) — Loaded with bit seven of the original operand.

Description: Shifts all bits of accumulator A or B or memory location M one place to the left. Bit zero is loaded with a zero. Bit seven of accumulator A or B or memory location M is shifted into the C (carry) bit.

Addressing Modes: Inherent
- Extended
- Direct
- Indexed

Comments: This is a duplicate assembly-language mnemonic for the single machine instruction ASL.
LSR

Logical Shift Right

Source Forms: LSR Q; LSRA; LSRB

Operation: \[ \text{b7, b6, b5, b4, b3, b2, b1, b0, c} \]

Condition Codes:
- H — Not affected.
- N — Always cleared.
- Z — Set if the result is zero; cleared otherwise.
- V — Not affected.
- C — Loaded with bit zero of the original operand.

Description: Performs a logical shift right on the operand. Shifts a zero into bit seven and bit zero into the C (carry) bit.

Addressing Modes: Inherent
- Extended
- Direct
- Indexed
MUL

Source Form: MUL

Operation: ACCA'·ACCB' = ACCA × ACCB

Condition Codes:
- H — Not affected.
- N — Not affected.
- Z — Set if the result is zero; cleared otherwise.
- V — Not affected.
- C — Set if ACCB bit 7 of result is set; cleared otherwise.

Description: Multiply the unsigned binary numbers in the accumulators and place the result in both accumulators (ACCA contains the most-significant byte of the result). Unsigned multiply allows multiple-precision operations.

Addressing Mode: Inherent

Comments: The C (carry) bit allows rounding the most-significant byte through the sequence: MUL, ADCA #0.
**NEG**

**Negate**

**Source Forms:**
NEG Q; NEGA; NEGB

**Operation:**
M' ← 0 - M

**Condition Codes:**
H — Undefined.
N — Set if the result is negative; cleared otherwise.
Z — Set if the result is zero; cleared otherwise.
V — Set if the original operand was 10000000.
C — Set if a borrow is generated; cleared otherwise.

**Description:**
Replaces the operand with its twos complement. The C (carry) bit represents a borrow and is set to the inverse of the resulting binary carry. Note that 80<sub>16</sub> is replaced by itself and only in this case is the V (overflow) bit set. The value 00<sub>16</sub> is also replaced by itself, and only in this case is the C (carry) bit cleared.

**Addressing Modes:**
Inherent
Extended
Direct
NOP  
No Operation  
NOP

Source Form:  NOP

Operation:  Not affected.

Condition Codes:  This instruction causes only the program counter to be incremented. No other registers or memory locations are affected.

Addressing Mode:  Inherent
**OR**

Inclusive OR Memory Into Register

**Source Forms:** ORA P; ORB P

**Operation:** \( R' \rightarrow R \lor M \)

**Condition Codes:**
- **H** — Not affected.
- **N** — Set if the result is negative; cleared otherwise.
- **Z** — Set if the result is zero; cleared otherwise.
- **V** — Always cleared.
- **C** — Not affected.

**Description:** Performs an inclusive OR operation between the contents of accumulator A or B and the contents of memory location M and the result is stored in accumulator A or B.

**Addressing Modes:** Immediate
- Extended
- Direct
- Indexed

A-51
OR  Inclusive OR Memory Immediate into Condition Code Register

Source Form: ORCC #XX

Operation: R' ← R v MI

Condition Codes: Affected according to the operation.

Description: Performs an Inclusive OR operation between the contents of the condition code registers and the immediate value, and the result is placed in the condition code register. This instruction may be used to set interrupt masks (disable interrupts) or any other bit(s).

Addressing Mode: Immediate
PSHS

Push Registers on the Hardware Stack

Source Form: PSHS register list
PSHS #LABEL
Postbyte:

b7  b6  b5  b4  b3  b2  b1  b0

PC  U  Y  X  DP  B  A  CC

push order-----

Operation:

IFF b7 of postbyte set, then: SP′ ← SP − 1, (SP) ← PCL
SP′ ← SP − 1, (SP) ← PCH

IFF b6 of postbyte set, then: SP′ ← SP − 1, (SP) ← USL
SP′ ← SP − 1, (SP) ← USH

IFF b5 of postbyte set, then: SP′ ← SP − 1, (SP) ← IYL
SP′ ← SP − 1, (SP) ← IYH

IFF b4 of postbyte set, then: SP′ ← SP − 1, (SP) ← IXL
SP′ ← SP − 1, (SP) ← IXH

IFF b3 of postbyte set, then: SP′ ← SP − 1, (SP) ← DPR

IFF b2 of postbyte set, then: SP′ ← SP − 1, (SP) ← ACCB

IFF b1 of postbyte set, then: SP′ ← SP − 1, (SP) ← ACCA

IFF b0 of postbyte set, then: SP′ ← SP − 1, (SP) ← CCR

Condition Codes: Not affected.

Description: All, some, or none of the processor registers are pushed onto the hardware stack (with the exception of the hardware stack pointer itself).

Addressing Mode: Immediate

Comments: A single register may be placed on the stack with the condition codes set by doing an autodecrement store onto the stack (example: STX , − − S).
PSHU

Push Registers on the User Stack

Source Form:
PSHU register list
PSHU #LABEL
Postbyte:
\[ b7 \quad b6 \quad b5 \quad b4 \quad b3 \quad b2 \quad b1 \quad b0 \]
\[ \begin{array}{cccccccc}
\end{array} \]
push order

Operation:
- IFF b7 of postbyte set, then: \( US' \leftarrow US - 1, (US) \leftarrow PCL \)
  \( US' \leftarrow US - 1, (US) \leftarrow PCH \)
- IFF b6 of postbyte set, then: \( US' \leftarrow US - 1, (US) \leftarrow SPL \)
  \( US' \leftarrow US - 1, (US) \leftarrow SPH \)
- IFF b5 of postbyte set, then: \( US' \leftarrow US - 1, (US) \leftarrow IYL \)
  \( US' \leftarrow US - 1, (US) \leftarrow IYH \)
- IFF b4 of postbyte set, then: \( US' \leftarrow US - 1, (US) \leftarrow IXL \)
  \( US' \leftarrow US - 1, (US) \leftarrow IXH \)
- IFF b3 of postbyte set, then: \( US' \leftarrow US - 1, (US) \leftarrow DPR \)
- IFF b2 of postbyte set, then: \( US' \leftarrow US - 1, (US) \leftarrow ACCB \)
- IFF b1 of postbyte set, then: \( US' \leftarrow US - 1, (US) \leftarrow ACCA \)
- IFF b0 of postbyte set, then: \( US' \leftarrow US - 1, (US) \leftarrow CCR \)

Condition Codes: Not affected.

Description: All, some, or none of the processor registers are pushed onto the user stack (with the exception of the user stack pointer itself).

Addressing Mode: Immediate

Comments: A single register may be placed on the stack with the condition codes set by doing an autodecrement store onto the stack (example: \( STX, -, -U \)).
PULS

Pull Registers from the Hardware Stack

Source Form:
PULS register list
PULS #LABEL

Postbyte:

\[
\begin{array}{cccccccc}
\text{b7} & \text{b6} & \text{b5} & \text{b4} & \text{b3} & \text{b2} & \text{b1} & \text{b0} \\
\text{PC} & \text{U} & \text{Y} & \text{X} & \text{DP} & \text{B} & \text{A} & \text{CC} \\
\end{array}
\]

\[\text{←-----pull order}\]

Operation:

- IFF b0 of postbyte set, then: \(\text{CCR}' \leftarrow (\text{SP}), \text{SP}' \leftarrow \text{SP} + 1\)
- IFF b1 of postbyte set, then: \(\text{ACCA}' \leftarrow (\text{SP}), \text{SP}' \leftarrow \text{SP} + 1\)
- IFF b2 of postbyte set, then: \(\text{ACCB}' \leftarrow (\text{SP}), \text{SP}' \leftarrow \text{SP} + 1\)
- IFF b3 of postbyte set, then: \(\text{DPR}' \leftarrow (\text{SP}), \text{SP}' \leftarrow \text{SP} + 1\)
- IFF b4 of postbyte set, then: \(\text{IXH}' \leftarrow (\text{SP}), \text{SP}' \leftarrow \text{SP} + 1\)
- IFF b5 of postbyte set, then: \(\text{IXL}' \leftarrow (\text{SP}), \text{SP}' \leftarrow \text{SP} + 1\)
- IFF b6 of postbyte set, then: \(\text{IYH}' \leftarrow (\text{SP}), \text{SP}' \leftarrow \text{SP} + 1\)
- IFF b7 of postbyte set, then: \(\text{IYL}' \leftarrow (\text{SP}), \text{SP}' \leftarrow \text{SP} + 1\)
- IFF b8 of postbyte set, then: \(\text{USH}' \leftarrow (\text{SP}), \text{SP}' \leftarrow \text{SP} + 1\)
- IFF b9 of postbyte set, then: \(\text{USL}' \leftarrow (\text{SP}), \text{SP}' \leftarrow \text{SP} + 1\)
- IFF b10 of postbyte set, then: \(\text{PCH}' \leftarrow (\text{SP}), \text{SP}' \leftarrow \text{SP} + 1\)
- IFF b11 of postbyte set, then: \(\text{PCL}' \leftarrow (\text{SP}), \text{SP}' \leftarrow \text{SP} + 1\)

Condition Codes:
May be pulled from stack; not affected otherwise.

Description:
All, some, or none of the processor registers are pulled from the hardware stack (with the exception of the hardware stack pointer itself).

Addressing Mode:
Immediate

Comments:
A single register may be pulled from the stack with condition codes set by doing an autoincrement load from the stack (example: LDX ,S + + ).
PULU

Pull Registers from the User Stack

Source Form:

PULU register list
PULU #LABEL

Postbyte:

\[ \begin{array}{cccccccc}
\text{b7} & \text{b6} & \text{b5} & \text{b4} & \text{b3} & \text{b2} & \text{b1} & \text{b0} \\
\text{PC} & \text{U} & \text{Y} & \text{X} & \text{DP} & \text{B} & \text{A} & \text{CC} \\
\end{array} \]

\[ \quad \text{←------ pull order} \]

Operation:

\[ \begin{align*}
\text{IFF b0 of postbyte set, then:} & \quad \text{CCR'} & \leftarrow (\text{US}), \text{US}' & \leftarrow \text{US} + 1 \\
\text{IFF b1 of postbyte set, then:} & \quad \text{ACCA'} & \leftarrow (\text{US}), \text{US}' & \leftarrow \text{US} + 1 \\
\text{IFF b2 of postbyte set, then:} & \quad \text{ACCB'} & \leftarrow (\text{US}), \text{US}' & \leftarrow \text{US} + 1 \\
\text{IFF b3 of postbyte set, then:} & \quad \text{DPR'} & \leftarrow (\text{US}), \text{US}' & \leftarrow \text{US} + 1 \\
\text{IFF b4 of postbyte set, then:} & \quad \text{IXH'} & \leftarrow (\text{US}), \text{US}' & \leftarrow \text{US} + 1 \\
& \quad \text{IXL'} & \leftarrow (\text{US}), \text{US}' & \leftarrow \text{US} + 1 \\
\text{IFF b5 of postbyte set, then:} & \quad \text{IYH'} & \leftarrow (\text{US}), \text{US}' & \leftarrow \text{US} + 1 \\
& \quad \text{IYL'} & \leftarrow (\text{US}), \text{US}' & \leftarrow \text{US} + 1 \\
\text{IFF b6 of postbyte set, then:} & \quad \text{SPH'} & \leftarrow (\text{US}), \text{US}' & \leftarrow \text{US} + 1 \\
& \quad \text{SPL'} & \leftarrow (\text{US}), \text{US}' & \leftarrow \text{US} + 1 \\
\text{IFF b7 of postbyte set, then:} & \quad \text{PCH} & \leftarrow (\text{US}), \text{US}' & \leftarrow \text{US} + 1 \\
& \quad \text{PCL'} & \leftarrow (\text{US}), \text{US}' & \leftarrow \text{US} + 1 \\
\end{align*} \]

Condition Codes:

May be pulled from stack; not affected otherwise.

Description:

All, some, or none of the processor registers are pulled from the user stack (with the exception of the user stack pointer itself).

Addressing Mode:

Immediate

Comments:

A single register may be pulled from the stack with condition codes set by doing an autoincrement load from the stack (example: LDX ,U + + ).
ROL

Rotate Left

Source Forms: ROL Q; ROLA; ROLB

Operation:

Condition Codes: H — Not affected.
N — Set if the result is negative; cleared otherwise.
Z — Set if the result is zero; cleared otherwise.
V — Loaded with the result of the exclusive OR of bits six and
seven of the original operand.
C — Loaded with bit seven of the original operand.

Description: Rotates all bits of the operand one place left through the C (carry) bit. This is a 9-bit rotation.

Addressing Mode: Inherent
Extended
Direct
Indexed
ROR

Rotate Right

Source Forms: ROR Q; RORA; RORB

Operation:

```
  C
  b7  b6  b5  b4  b3  b2  b1  b0
```

Condition Codes:
- H — Not affected.
- N — Set if the result is negative; cleared otherwise.
- Z — Set if the result is zero; cleared otherwise.
- V — Not affected.
- C — Loaded with bit zero of the previous operand.

Description:
Rotates all bits of the operand one place right through the C (carry) bit. This is a 9-bit rotation.

Addressing Modes:
Inherent
Extended
Direct
Indexed

A-58
RTI

Source Form: RTI

Operation: CCR' ← (SP), SP' ← SP + 1, then

IFF CCR bit E is set, then:
- ACCA' ← (SP), SP' ← SP + 1
- ACCB' ← (SP), SP' ← SP + 1
- DPR' ← (SP), SP' ← SP + 1
- IXH' ← (SP), SP' ← SP + 1
- IXL' ← (SP), SP' ← SP + 1
- IYH' ← (SP), SP' ← SP + 1
- IYL' ← (SP), SP' ← SP + 1
- USH' ← (SP), SP' ← SP + 1
- USL' ← (SP), SP' ← SP + 1
- PCH' ← (SP), SP' ← SP + 1
- PCL' ← (SP), SP' ← SP + 1

IFF CCR bit E is clear, then:
- PCH' ← (SP), SP' ← SP + 1
- PCL' ← (SP), SP' ← SP + 1

Condition Codes: Recovered from the stack.

Description: The saved machine state is recovered from the hardware stack and control is returned to the interrupted program. If the recovered E (entire) bit is clear, it indicates that only a subset of the machine state was saved (return address and condition codes) and only that subset is recovered.

Addressing Mode: Inherent
RTS

Return from Subroutine

Source Form: RTS

Operation:
PCH' ← (SP), SP' ← SP + 1
PCL' ← (SP), SP' ← SP + 1

Condition Codes: Not affected.

Description: Program control is returned from the subroutine to the calling program. The return address is pulled from the stack.

Addressing Mode: Inherent
Subtract with Borrow

Source Forms: SBCA P; SBCB P

Operation: \( R' \leftarrow R - M - C \)

Condition Codes:  
- H — Undefined.  
- N — Set if the result is negative; cleared otherwise.  
- Z — Set if the result is zero; cleared otherwise.  
- V — Set if an overflow is generated; cleared otherwise.  
- C — Set if a borrow is generated; cleared otherwise.

Description: Subtracts the contents of memory location M and the borrow (in the C (carry) bit) from the contents of the designated 8-bit register, and places the result in that register. The C bit represents a borrow and is set to the inverse of the resulting binary carry.

Addressing Modes: Immediate  
- Extended  
- Direct  
- Indexed
SEX

Sign Extended

Source Form: SEX

Operation: If bit seven of ACCB is set then ACCA′ ← FF16
else ACCA′ ← 0016

Condition Codes: H — Not affected.
N — Set if the result is negative; cleared otherwise.
Z — Set if the result is zero; cleared otherwise.
V — Not affected.
C — Not affected.

Description: This instruction transforms a twos complement 8-bit value in accumulator B into a twos complement 16-bit value in the D accumulator.

Addressing Mode: Inherent
ST (8-Bit) Store Register into Memory ST (8-Bit)

Source Forms: STA P; STB P

Operation: M' — R

Condition Codes:
H — Not affected.
N — Set if the result is negative; cleared otherwise.
Z — Set if the result is zero; cleared otherwise.
V — Always cleared.
C — Not affected.

Description: Writes the contents of an 8-bit register into a memory location.

Addressing Modes: Extended
Direct
Indexed
ST (16-Bit) Store Register Into Memory

Source Forms: STD P; STX P; STY P; STS P; STU P

Operation: M'':M + 1' ← R

Condition Codes: H — Not affected.
N — Set if the result is negative; cleared otherwise.
Z — Set if the result is zero; cleared otherwise.
V — Always cleared.
C — Not affected.

Description: Writes the contents of a 16-bit register into two consecutive memory locations.

Addressing Modes: Extended
Direct
Indexed
SUB (8-Bit)    Subtract Memory from Register

Source Forms:    SUBA P; SUBB P

Operation:    R' ← R - M

Condition Codes:

H — Undefined.
N — Set if the result is negative; cleared otherwise.
Z — Set if the result is zero; cleared otherwise.
V — Set if the overflow is generated; cleared otherwise.
C — Set if a borrow is generated; cleared otherwise.

Description:    Subtracts the value in memory location M from the contents of a designated 8-bit register. The C (carry) bit represents a borrow and is set to the inverse of the resulting binary carry.

Addressing Modes:    Immediate
                          Extended
                          Direct
                          Indexed
SUB (16-Bit)  Subtract Memory from Register  SUB (16-Bit)

Source Forms:  SUBD P

Operation:  \( R' \leftarrow R - M: M + 1 \)

Condition Codes:  
- \( H \) — Not affected.
- \( N \) — Set if the result is negative; cleared otherwise.
- \( Z \) — Set if the result is zero; cleared otherwise.
- \( V \) — Set if the overflow is generated; cleared otherwise.
- \( C \) — Set if a borrow is generated; cleared otherwise.

Description:  Subtracts the value in memory location \( M: M + 1 \) from the contents of a designated 16-bit register. The \( C \) (carry) bit represents a borrow and is set to the inverse of the resulting binary carry.

Addressing Modes:  Immediate
                    Extended
                    Direct
                    Indexed
SWI
Software Interrupt
SWI

Source Form: SWI

Operation:
Set E (entire state will be saved)
SP' ← SP − 1, (SP) ← PCL
SP' ← SP − 1, (SP) ← PCH
SP' ← SP − 1, (SP) ← USL
SP' ← SP − 1, (SP) ← USH
SP' ← SP − 1, (SP) ← IYL
SP' ← SP − 1, (SP) ← IYH
SP' ← SP − 1, (SP) ← IXL
SP' ← SP − 1, (SP) ← IXH
SP' ← SP − 1, (SP) ← DPR
SP' ← SP − 1, (SP) ← ACCB
SP' ← SP − 1, (SP) ← ACCA
SP' ← SP − 1, (SP) ← CCR
Set I, F (mask interrupts)
PC' ← (FFFA);(FFFF)

Condition Codes: Not affected.

Description: All of the processor registers are pushed onto the hardware stack (with the exception of the hardware stack pointer itself), and control is transferred through the software interrupt vector. Both the normal and fast interrupts are masked (disabled).

Addressing Mode: Inherent
Source Form: SWI2

Operation:
Set E (entire state saved)
\[ SP' \leftarrow SP - 1, (SP) \leftarrow PCL \]
\[ SP' \leftarrow SP - 1, (SP) \leftarrow PCH \]
\[ SP' \leftarrow SP - 1, (SP) \leftarrow USL \]
\[ SP' \leftarrow SP - 1, (SP) \leftarrow USH \]
\[ SP' \leftarrow SP - 1, (SP) \leftarrow IYL \]
\[ SP' \leftarrow SP - 1, (SP) \leftarrow IYH \]
\[ SP' \leftarrow SP - 1, (SP) \leftarrow IXL \]
\[ SP' \leftarrow SP - 1, (SP) \leftarrow IXH \]
\[ SP' \leftarrow SP - 1, (SP) \leftarrow DPR \]
\[ SP' \leftarrow SP - 1, (SP) \leftarrow ACCB \]
\[ SP' \leftarrow SP - 1, (SP) \leftarrow ACCA \]
\[ SP' \leftarrow SP - 1, (SP) \leftarrow CCR \]
\[ PC' \leftarrow (FFF4):(FFF5) \]

Condition Codes: Not affected.

Description: All of the processor registers are pushed onto the hardware stack (with the exception of the hardware stack pointer itself), and control is transferred through the software interrupt 2 vector. This interrupt is available to the end user and must not be used in packaged software. This interrupt does not mask (disable) the normal and fast interrupts.

Addressing Mode: Inherent
Source Form: SWI 3

Operation:
Set E (entire state will be saved)
SP' ← SP − 1, (SP) ← PCL
SP' ← SP − 1, (SP) ← PCH
SP' ← SP − 1, (SP) ← USL
SP' ← SP − 1, (SP) ← USH
SP' ← SP − 1, (SP) ← IYL
SP' ← SP − 1, (SP) ← IYH
SP' ← SP − 1, (SP) ← IXL
SP' ← SP − 1, (SP) ← IXH
SP' ← SP − 1, (SP) ← DPR
SP' ← SP − 1, (SP) ← ACCB
SP' ← SP − 1, (SP) ← ACCA
SP' ← SP − 1, (SP) ← CCR
PC' ← (FFF2):(FFF3)

Condition Codes: Not affected.

Description: All of the processor registers are pushed onto the hardware stack (with the exception of the hardware stack pointer itself), and control is transferred through the software interrupt 3 vector. This interrupt does not mask (disable) the normal and fast interrupts.

Addressing Mode: Inherent
SYNC

Synchronize to External Event

Source Form: SYNC

Operation: Stop processing instructions

Condition Codes: Not affected.

Description: When a SYNC instruction is executed, the processor enters a synchronizing state, stops processing instructions, and waits for an interrupt. When an interrupt occurs, the synchronizing state is cleared and processing continues. If the interrupt is enabled, and it lasts three cycles or more, the processor will perform the interrupt routine. If the interrupt is masked or is shorter than three cycles, the processor simply continues to the next instruction. While in the synchronizing state, the address and data buses are in the high-impedance state.

This instruction provides software synchronization with a hardware process. Consider the following example for high-speed acquisition of data:

<table>
<thead>
<tr>
<th>FAST</th>
<th>SYNC</th>
<th>WAIT FOR DATA</th>
</tr>
</thead>
<tbody>
<tr>
<td></td>
<td>Interrupt!</td>
<td></td>
</tr>
<tr>
<td>LDA</td>
<td>DISC</td>
<td>DATA FROM DISC AND CLEAR INTERRUPT</td>
</tr>
<tr>
<td>STA</td>
<td>.X+</td>
<td>PUT IN BUFFER</td>
</tr>
<tr>
<td>DEC8</td>
<td></td>
<td>COUNT IT, DONE?</td>
</tr>
<tr>
<td>BNE</td>
<td>FAST</td>
<td>GO AGAIN IF NOT.</td>
</tr>
</tbody>
</table>

The synchronizing state is cleared by any interrupt. Of course, enabled interrupts at this point may destroy the data transfer and, as such, should represent only emergency conditions.

The same connection used for interrupt-driven I/O service may also be used for high-speed data transfers by setting the interrupt mask and using the SYNC instruction as the above example demonstrates.

Addressing Mode: Inherent
TFR  
Transfer Register to Register  

**Source Form:**  TFR R1, R2  
**Operation:**  R1 → R2  
**Condition Code:**  Not affected unless R2 is the condition code register.  
**Description:**  Transfers data between two designated registers. Bits 7-4 of the postbyte define the source register, while bits 3-0 define the destination register, as follows:

<table>
<thead>
<tr>
<th>Source Register</th>
<th>Destination Register</th>
</tr>
</thead>
<tbody>
<tr>
<td>0000 = A:B</td>
<td>1000 = A</td>
</tr>
<tr>
<td>0001 = X</td>
<td>1001 = B</td>
</tr>
<tr>
<td>0010 = Y</td>
<td>1010 = CCR</td>
</tr>
<tr>
<td>0011 = US</td>
<td>1011 = DPR</td>
</tr>
<tr>
<td>0100 = SP</td>
<td>1100 = Undefined</td>
</tr>
<tr>
<td>0101 = PC</td>
<td>1101 = Undefined</td>
</tr>
<tr>
<td>0110 = Undefined</td>
<td>1110 = Undefined</td>
</tr>
<tr>
<td>0111 = Undefined</td>
<td>1111 = Undefined</td>
</tr>
</tbody>
</table>

Only like size registers may be transferred. (8-bit to 8-bit, or 16-bit to 16-bit.)  

**Addressing Mode:**  Immediate
Source Forms: TST Q; TSTA; TSTB

Operation: TEMP ← M - 0

Condition Codes:
H — Not affected.
N — Set if the result is negative; cleared otherwise.
Z — Set if the result is zero; cleared otherwise.
V — Always cleared.
C — Not affected.

Description: Set the N (negative) and Z (zero) bits according to the contents of memory location M, and clear the V (overflow) bit. The TST instruction provides only minimum information when testing unsigned values; since no unsigned value is less than zero, BLO and BLS have no utility. While BHI could be used after TST, it provides exactly the same control as BNE, which is preferred. The signed branches are available.

Addressing Modes: Inherent
Extended
Direct
Indexed

Comments: The MC6800 processor clears the C (carry) bit.
FIRQ

Fast Interrupt Request (Hardware Interrupt)

Operation:
IFF F bit clear, then:
SP' ← SP - 1, (SP) ← PCL
SP' ← SP - 1, (SP) ← PCH
Clear E (subset state is saved)
SP' ← SP - 1, (SP) ← CCR
Set F, I (mask further interrupts)
PC' ← (FFF6)(FFF7)

Condition Codes: Not affected.

Description: A FIRQ (fast interrupt request) with the F (fast interrupt request mask) bit clear causes this interrupt sequence to occur at the end of the current instruction. The program counter and condition code register are pushed onto the hardware stack. Program control is transferred through the fast interrupt request vector. An RTI (return from interrupt) instruction returns the processor to the original task. It is possible to enter the fast interrupt request routine with the entire machine state saved if the fast interrupt request occurs after a clear and wait for interrupt instruction. A normal interrupt request has lower priority than the fast interrupt request and is prevented from interrupting the fast interrupt request routine by automatic setting of the I (interrupt request mask) bit. This mask bit could then be reset during the interrupt routine if priority was not desired. The fast interrupt request allows operations on memory, TST, INC, DEC, etc. instructions without the overhead of saving the entire machine state on the stack.

Addressing Mode: Inherent
**Interrupt Request (Hardware Interrupt)**

**Operation:** IFF I bit clear, then:

- \( SP' \leftarrow SP - 1 \), \( (SP) \leftarrow PCL \)
- \( SP' \leftarrow SP - 1 \), \( (SP) \leftarrow PCH \)
- \( SP' \leftarrow SP - 1 \), \( (SP) \leftarrow USL \)
- \( SP' \leftarrow SP - 1 \), \( (SP) \leftarrow USH \)
- \( SP' \leftarrow SP - 1 \), \( (SP) \leftarrow IYL \)
- \( SP' \leftarrow SP - 1 \), \( (SP) \leftarrow IYH \)
- \( SP' \leftarrow SP - 1 \), \( (SP) \leftarrow IXL \)
- \( SP' \leftarrow SP - 1 \), \( (SP) \leftarrow IXH \)
- \( SP' \leftarrow SP - 1 \), \( (SP) \leftarrow DPR \)
- \( SP' \leftarrow SP - 1 \), \( (SP) \leftarrow ACCB \)
- \( SP' \leftarrow SP - 1 \), \( (SP) \leftarrow ACCA \)
- Set E (entire state saved)
- \( SP' \leftarrow SP - 1 \), \( (SP) \leftarrow CCR \)
- Set I (mask further IRQ interrupts)
- \( PC' \leftarrow (FFFF):(FFFG) \)

**Condition Codes:** Not affected.

**Description:** If the I (interrupt request mask) bit is clear, a low level on the IRQ input causes this interrupt sequence to occur at the end of the current instruction. Control is returned to the interrupted program using a RTI (return from interrupt) instruction. A FIRQ (fast interrupt request) may interrupt a normal IRQ (interrupt request) routine and be recognized anytime after the interrupt vector is taken.

**Addressing Mode:** Inherent
Non-Maskable Interrupt (Hardware Interrupt)

Operation:
- \( SP' \rightarrow SP - 1 \), \( (SP) \leftarrow PCL \)
- \( SP' \rightarrow SP - 1 \), \( (SP) \leftarrow PCH \)
- \( SP' \rightarrow SP - 1 \), \( (SP) \leftarrow USL \)
- \( SP' \rightarrow SP - 1 \), \( (SP) \leftarrow USH \)
- \( SP' \rightarrow SP - 1 \), \( (SP) \leftarrow IYL \)
- \( SP' \rightarrow SP - 1 \), \( (SP) \leftarrow IYH \)
- \( SP' \rightarrow SP - 1 \), \( (SP) \leftarrow IXL \)
- \( SP' \rightarrow SP - 1 \), \( (SP) \leftarrow IXH \)
- \( SP' \rightarrow SP - 1 \), \( (SP) \leftarrow DPR \)
- \( SP' \rightarrow SP - 1 \), \( (SP) \leftarrow ACCB \)
- \( SP' \rightarrow SP - 1 \), \( (SP) \leftarrow ACCA \)
- Set E (entire state save)
- \( SP' \rightarrow SP - 1 \), \( (SP) \leftarrow CCR \)
- Set I, F (mask interrupts)
- \( PC' \leftarrow \text{FFFF}; (FFFF) \)

Condition Codes: Not affected.

Description: A negative edge on the \( \overline{\text{NMI}} \) (non-maskable interrupt) input causes all of the processor's registers (except the hardware stack pointer) to be pushed onto the hardware stack, starting at the end of the current instruction. Program control is transferred through the NMI vector. Successive negative edges on the NMI input will cause successive NMI operations. Non-maskable interrupt operation can be internally blocked by a \( \text{RESET} \) operation and any non-maskable interrupt that occurs will be latched. If this happens, the non-maskable interrupt operation will occur after the first load into the stack pointer (LDS; TFR r,s; EXG r,s; etc.) after \( \text{RESET} \).

Addressing Mode: Inherent
**RESTART**  
Restart (Hardware Interrupt)  

**Operation:**
- $\text{CCR'} = \text{X1X1XXX}$
- $\text{DPR'} = \text{0016}$
- $\text{PC'} = (\text{FFFF})(\text{FFFF})$

**Condition Codes:** Not affected.

**Description:** The processor is initialized (required after power-on) to start program execution. The starting address is fetched from the restart vector.

**Addressing Mode:** Extended Indirect