

# A

## Summary of the 6809 Instruction Set

Appendix A uses the following symbols:

**The registers:**

|      |                                                         |
|------|---------------------------------------------------------|
| A, B | Accumulators                                            |
| D    | Double Accumulator (A and B concatenated, A high-order) |
| DP   | Direct Page Register                                    |
| X, Y | Index registers                                         |
| PC   | Program Counter                                         |
| S    | Hardware Stack Pointer                                  |
| U    | User Stack Pointer                                      |
| CC   | Status (Condition Code) Register                        |

**The flags (statuses), starting with bit 0 of the condition code register and proceeding to bit 7:**

|   |                              |
|---|------------------------------|
| C | Carry (Borrow) flag          |
| V | Overflow flag                |
| Z | Zero flag                    |
| N | Sign (Negative) flag         |
| I | (Regular) Interrupt Mask bit |
| H | Half-Carry flag              |
| F | Fast Interrupt Mask bit      |
| E | Entire flag                  |

**Symbols in the Status (flags) columns:**

|         |                                |
|---------|--------------------------------|
| (blank) | Operation does not affect flag |
| X       | Operation affects flag         |
| 0       | Operation clears flag          |
| 1       | Operation sets flag            |

**Other symbols and abbreviations:**

|                           |                                                                                                                                |
|---------------------------|--------------------------------------------------------------------------------------------------------------------------------|
| <b>ACx</b>                | An accumulator, either Accumulator A or Accumulator B                                                                          |
| <b>adr8</b>               | An 8-bit address, a 1-byte quantity which may be used to directly address memory locations on the base (direct) page           |
| <b>adr16</b>              | A 16-bit memory address                                                                                                        |
| <b>b0-b7</b>              | Bits of a Post Byte or an 8-bit register                                                                                       |
| <b>C</b>                  | Contents of the Carry flag, either 0 or 1                                                                                      |
| <b>data8</b>              | An 8-bit unit of binary data                                                                                                   |
| <b>data16</b>             | A 16-bit unit of binary data                                                                                                   |
| <b>disp8</b>              | An 8-bit signed binary address displacement                                                                                    |
| <b>disp16</b>             | A 16-bit signed binary address displacement                                                                                    |
| <b>EA</b>                 | Effective address calculated by any addressing method                                                                          |
| <b>M</b>                  | Memory address as determined by base page direct, extended direct, indexed, or indirect addressing                             |
| <b>[M]</b>                | Contents of M                                                                                                                  |
| <b>[M] : [M + 1]</b>      | 16-bit data item; its high-order byte is the contents of M, and its low-order byte is the contents of the next higher address. |
| <b>reg</b>                | A 16-bit index register or stack pointer (S, U, X, or Y)                                                                       |
| <b>reg. list</b>          | A list of registers to be stored on or retrieved from a stack                                                                  |
| <b>R16</b>                | A 16-bit register (D, S, U, X, or Y)                                                                                           |
| <b>R1, R2</b>             | Two registers, both 8-bit or both 16-bit                                                                                       |
| <b>SP</b>                 | A stack pointer (either S or U)                                                                                                |
| <b>Ind. forms</b>         | Any of the indexed or indirect addressing methods described in Appendix B                                                      |
| <b>[interrupt vector]</b> | The address contained in one of the interrupt vectors (see Table 15-1)                                                         |
| <b>xx(HI)</b>             | The high-order 8 bits of the 16-bit quantity xx                                                                                |
| <b>xx(LO)</b>             | The low-order 8 bits of the 16-bit quantity xx                                                                                 |
| <b>[ ]</b>                | Contents of location enclosed by brackets                                                                                      |
| <b>[[ ]]</b>              | Implied memory address: the contents of the memory location designated by the contents of a register                           |
| <b>Λ</b>                  | Logical AND                                                                                                                    |
| <b>∨</b>                  | Logical (Inclusive) OR                                                                                                         |
| <b>✗</b>                  | Logical Exclusive-OR                                                                                                           |
| <b>←</b>                  | Data is transferred in the direction of the arrow                                                                              |
| <b>↔</b>                  | Data is transferred in both directions simultaneously, thus exchanging the contents of the source and the destination.         |

## **Appendix A. A Summary of the 6809 Instruction Set**

| Type                             | Mnemonic       | Operand(s) | Bytes | Cycles | Status |   |   |   |   |   |   | Operation Performed                                                                                                                          |                                                                                                                                                          |
|----------------------------------|----------------|------------|-------|--------|--------|---|---|---|---|---|---|----------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                  |                |            |       |        | E      | F | H | I | N | Z | V |                                                                                                                                              |                                                                                                                                                          |
| Primary Memory Reference and I/O | LDA {<br>LDB { | adr8       | 2     | 4      |        |   |   |   | X | X | 0 |                                                                                                                                              | The 6809 permits the following addressing modes for all Primary Memory Reference instructions: base page direct, extended direct, indexed, and indirect. |
|                                  |                | adr16      | 3     | 5      |        |   |   |   |   |   |   | [ACx] ← [M]                                                                                                                                  |                                                                                                                                                          |
|                                  |                | ind. forms | 2+    | 4+     |        |   |   |   |   |   |   | Load Accumulator A or B from specified memory location.                                                                                      |                                                                                                                                                          |
|                                  | STA {<br>STB { | adr8       | 2     | 4      |        |   |   |   | X | X | 0 |                                                                                                                                              |                                                                                                                                                          |
|                                  |                | adr16      | 3     | 5      |        |   |   |   |   |   |   | [M] ← [ACx]                                                                                                                                  |                                                                                                                                                          |
|                                  |                | ind. forms | 2+    | 4+     |        |   |   |   |   |   |   | Store contents of Accumulator A or B in specified memory location.                                                                           |                                                                                                                                                          |
|                                  | LDD            | adr8       | 2     | 5      |        |   |   |   | X | X | 0 |                                                                                                                                              |                                                                                                                                                          |
|                                  |                | adr16      | 3     | 6      |        |   |   |   |   |   |   | [D] ← [M]:[M + 1]                                                                                                                            |                                                                                                                                                          |
|                                  |                | ind. forms | 2+    | 5+     |        |   |   |   |   |   |   | Load double Accumulator from specified memory location. Sign flag (N) takes the value of bit 15 of the data (bit 7 of Accumulator A).        |                                                                                                                                                          |
|                                  | STD            | adr8       | 2     | 5      |        |   |   |   | X | X | 0 |                                                                                                                                              |                                                                                                                                                          |
|                                  |                | adr16      | 3     | 6      |        |   |   |   |   |   |   | [M]:[M + 1] ← [D]                                                                                                                            |                                                                                                                                                          |
|                                  |                | ind. forms | 2+    | 5+     |        |   |   |   |   |   |   | Store contents of double Accumulator in specified memory location. Sign flag takes the value of bit 15 of the data (bit 7 of Accumulator A). |                                                                                                                                                          |
|                                  | LDX {<br>LDU { | adr8       | 2     | 5      |        |   |   |   | X | X | 0 |                                                                                                                                              |                                                                                                                                                          |
|                                  |                | adr16      | 3     | 6      |        |   |   |   |   |   |   | [reg] ← [M]:[M + 1]                                                                                                                          |                                                                                                                                                          |
|                                  |                | ind. forms | 2+    | 5+     |        |   |   |   |   |   |   | Load specified register (X, Y, U, or S) from memory. Sign flag (N) takes the value of bit 15 of the data.                                    |                                                                                                                                                          |
|                                  | LDY {<br>LDS { | adr8       | 3     | 6      |        |   |   |   | X | X | 0 |                                                                                                                                              |                                                                                                                                                          |
|                                  |                | adr16      | 4     | 7      |        |   |   |   |   |   |   |                                                                                                                                              |                                                                                                                                                          |
|                                  |                | ind. forms | 3+    | 6+     |        |   |   |   |   |   |   |                                                                                                                                              |                                                                                                                                                          |
|                                  | STX {<br>STU { | adr8       | 2     | 5      |        |   |   |   | X | X | 0 |                                                                                                                                              |                                                                                                                                                          |
|                                  |                | adr16      | 3     | 6      |        |   |   |   |   |   |   | [M]:[M + 1] ← [reg]                                                                                                                          |                                                                                                                                                          |
|                                  |                | ind. forms | 2+    | 5+     |        |   |   |   |   |   |   | Store contents of specified register (X, Y, U, or S) in memory. Sign flag (N) takes the value of bit 15 of the register.                     |                                                                                                                                                          |
|                                  | STY {<br>STS { | adr8       | 3     | 6      |        |   |   |   | X | X | 0 |                                                                                                                                              |                                                                                                                                                          |
|                                  |                | adr16      | 4     | 7      |        |   |   |   |   |   |   |                                                                                                                                              |                                                                                                                                                          |
|                                  |                | ind. forms | 3+    | 6+     |        |   |   |   |   |   |   |                                                                                                                                              |                                                                                                                                                          |

**Appendix A. A Summary of the 6809 Instruction Set (Continued)**

| Type                                        | Mnemonic | Operand(s) | Bytes | Cycles | Status |   |   |   |   |   |   | Operation Performed |                                                                                                                                                                                                                                                             |
|---------------------------------------------|----------|------------|-------|--------|--------|---|---|---|---|---|---|---------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                             |          |            |       |        | E      | F | H | I | N | Z | V |                     |                                                                                                                                                                                                                                                             |
| Secondary Memory Reference (Memory Operate) | ADCA {   | adr8       | 2     | 4      |        |   |   | X |   | X | X | X                   | [ACx] $\leftarrow$ [ACx] + [M] + C<br>Add with carry to Accumulator A or B.                                                                                                                                                                                 |
|                                             | ADCB }   | adr16      | 3     | 5      |        |   |   |   |   |   |   |                     |                                                                                                                                                                                                                                                             |
|                                             |          | ind. forms | 2+    | 4+     |        |   |   |   |   |   |   |                     |                                                                                                                                                                                                                                                             |
|                                             | ADDA {   | adr8       | 2     | 4      |        |   | X |   | X | X | X | X                   | [ACx] $\leftarrow$ [ACx] + [M]<br>Add contents of specified memory location to Accumulator A or B.                                                                                                                                                          |
|                                             | ADDB }   | adr16      | 3     | 5      |        |   |   |   |   |   |   |                     |                                                                                                                                                                                                                                                             |
|                                             |          | ind. forms | 2+    | 4+     |        |   |   |   |   |   |   |                     |                                                                                                                                                                                                                                                             |
|                                             | ADDD     | adr8       | 2     | 6      |        |   |   | X | X | X | X | X                   | [D] $\leftarrow$ [D] + [M]:[M + 1]<br>Add 16-bit value from memory to double Accumulator. The operand's high-order byte is in the specified memory location; the low-order byte is in the next higher address.                                              |
|                                             |          | adr16      | 3     | 7      |        |   |   |   |   |   |   |                     |                                                                                                                                                                                                                                                             |
|                                             |          | ind. forms | 2+    | 6+     |        |   |   |   |   |   |   |                     |                                                                                                                                                                                                                                                             |
|                                             | ANDA {   | adr8       | 2     | 4      |        |   |   |   | X | X | 0 |                     | [ACx] $\leftarrow$ [ACx] $\Lambda$ [M]<br>AND contents of specified memory location with Accumulator A or B.                                                                                                                                                |
|                                             | ANDB }   | adr16      | 3     | 5      |        |   |   |   |   |   |   |                     |                                                                                                                                                                                                                                                             |
|                                             |          | ind. forms | 2+    | 4+     |        |   |   |   |   |   |   |                     |                                                                                                                                                                                                                                                             |
| Secondary Memory Reference (Memory Operate) | BITA {   | adr8       | 2     | 4      |        |   |   |   | X | X | 0 |                     | [ACx] $\Lambda$ [M]<br>AND contents of specified memory location with Accumulator A or B. Only the Status register is affected.                                                                                                                             |
|                                             | BITB }   | adr16      | 3     | 5      |        |   |   |   |   |   |   |                     |                                                                                                                                                                                                                                                             |
|                                             |          | ind. forms | 2+    | 4+     |        |   |   |   |   |   |   |                     |                                                                                                                                                                                                                                                             |
|                                             | CMPA {   | adr8       | 2     | 4      |        |   | X |   | X | X | X | X                   | [ACx] $\leftarrow$ [M]<br>Compare contents of specified memory location with Accumulator A or B. Only the Status register is affected.                                                                                                                      |
|                                             | CMPB }   | adr16      | 3     | 5      |        |   |   |   |   |   |   |                     |                                                                                                                                                                                                                                                             |
|                                             |          | ind. forms | 2+    | 4+     |        |   |   |   |   |   |   |                     |                                                                                                                                                                                                                                                             |
|                                             | CMPD     | adr8       | 3     | 7      |        |   |   | X | X | X | X | X                   | [D] $\leftarrow$ [M]:[M + 1]<br>Compare 16-bit data with double Accumulator. Only the status register is affected. The high-order byte of the data is in the specified memory location; the low-order byte is in the next higher address.                   |
|                                             |          | adr16      | 4     | 8      |        |   |   |   |   |   |   |                     |                                                                                                                                                                                                                                                             |
|                                             |          | ind. forms | 3+    | 7+     |        |   |   |   |   |   |   |                     |                                                                                                                                                                                                                                                             |
|                                             | CMPS {   | adr8       | 3     | 7      |        |   |   |   | X | X | X | X                   | [reg] $\leftarrow$ [M]:[M + 1]<br>Compare 16-bit data with specified register (S, U, X, or Y). Only the status register is affected. The high-order byte of the data is in the specified memory location; the low-order byte is in the next higher address. |
|                                             | CMPU }   | adr16      | 4     | 8      |        |   |   |   |   |   |   |                     |                                                                                                                                                                                                                                                             |
|                                             |          | ind. forms | 3+    | 7+     |        |   |   |   |   |   |   |                     |                                                                                                                                                                                                                                                             |

## Appendix A. A Summary of the 6809 Instruction Set (Continued)

| Type                                                    | Mnemonic | Operand(s)                  | Bytes        | Cycles       | Status |   |   |   |   |   |   | Operation Performed |                                                                                                                                                                                                         |
|---------------------------------------------------------|----------|-----------------------------|--------------|--------------|--------|---|---|---|---|---|---|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                         |          |                             |              |              | E      | F | H | I | N | Z | V |                     |                                                                                                                                                                                                         |
| Secondary Memory Reference (Memory Operate) (Continued) | CMPX     | adr8<br>adr16<br>ind. forms | 2<br>3<br>2+ | 6<br>7<br>6+ |        |   |   |   | X | X | X | X                   | Same as CMPS/CMPU/CMPY. See page A-4.                                                                                                                                                                   |
|                                                         | EORA }   | adr8                        | 2            | 4            |        |   |   |   | X | X | 0 |                     | [ACx] ← [ACx] $\vee$ [M]                                                                                                                                                                                |
|                                                         | EORB }   | adr16                       | 3            | 5            |        |   |   |   |   |   |   |                     | Logical Exclusive-OR contents of specified memory location with Accumulator A or B.                                                                                                                     |
|                                                         |          | ind. forms                  | 2+           | 4+           |        |   |   |   |   |   |   |                     |                                                                                                                                                                                                         |
|                                                         | ORA }    | adr8                        | 2            | 4            |        |   |   |   | X | X | 0 |                     | [ACx] ← [ACx] $\vee$ [M]                                                                                                                                                                                |
|                                                         | ORB }    | adr16                       | 3            | 5            |        |   |   |   |   |   |   |                     | Logical (Inclusive) OR contents of specified memory location with Accumulator A or B.                                                                                                                   |
|                                                         | SBCA }   | adr8                        | 2            | 4            |        |   | X |   | X | X | X | X                   | [ACx] ← [ACx] – [M] – C                                                                                                                                                                                 |
|                                                         | SBCB }   | adr16                       | 3            | 5            |        |   |   |   |   |   |   |                     | Subtract contents of specified memory location and contents of Carry flag from Accumulator A or B.                                                                                                      |
|                                                         |          | ind. forms                  | 2+           | 4+           |        |   |   |   |   |   |   |                     |                                                                                                                                                                                                         |
|                                                         | SUBA }   | adr8                        | 2            | 4            |        |   | X |   | X | X | X | X                   | [ACx] ← [ACx] – [M]                                                                                                                                                                                     |
|                                                         | SUBB }   | adr16                       | 3            | 5            |        |   |   |   |   |   |   |                     | Subtract contents of specified memory location from Accumulator A or B.                                                                                                                                 |
|                                                         |          | ind. forms                  | 2+           | 4+           |        |   |   |   |   |   |   |                     |                                                                                                                                                                                                         |
| SUBD                                                    |          |                             |              |              |        |   |   |   |   |   |   |                     |                                                                                                                                                                                                         |
|                                                         |          | adr8<br>adr16<br>ind. forms | 2<br>3<br>2+ | 6<br>7<br>6+ |        |   |   |   | X | X | X | X                   | [D] ← [D] – [M]:[M + 1]<br>Subtract 16-bit value in memory from double Accumulator. The operand's high-order byte is in the specified memory address; the low-order byte is in the next higher address. |
| ASL                                                     |          |                             |              |              |        |   |   |   |   |   |   |                     |                                                                                                                                                                                                         |
|                                                         |          | adr8<br>adr16<br>ind. forms | 2<br>3<br>2+ | 6<br>7<br>6+ |        |   | X |   | X | X | X | X                   | <br>Arithmetic shift left. Bit 0 is set to 0.                                                                        |
| ASR                                                     |          |                             |              |              |        |   |   |   |   |   |   |                     |                                                                                                                                                                                                         |
|                                                         |          | adr8<br>adr16<br>ind. forms | 2<br>3<br>2+ | 6<br>7<br>6+ |        |   | X |   | X | X |   | X                   | <br>Arithmetic shift right. Bit 7 stays the same.                                                                    |

**Appendix A. A Summary of the 6809 Instruction Set (Continued)**

| Type                                                    | Mnemonic | Operand(s)                  | Bytes        | Cycles       | Status |   |   |   |   |   |   | Operation Performed |                                                                                                                                                                                                                       |
|---------------------------------------------------------|----------|-----------------------------|--------------|--------------|--------|---|---|---|---|---|---|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                         |          |                             |              |              | E      | F | H | I | N | Z | V |                     |                                                                                                                                                                                                                       |
| Secondary Memory Reference (Memory Operate) (Continued) | CLR      | adr8<br>adr16<br>ind. forms | 2<br>3<br>2+ | 6<br>7<br>6+ |        |   |   |   | 0 | 1 | 0 | 0                   | $[M] \leftarrow 00_{16}$<br>Clear specified memory location.                                                                                                                                                          |
|                                                         | COM      | adr8<br>adr16<br>ind. forms | 2<br>3<br>2+ | 6<br>7<br>6+ |        |   |   |   | X | X | 0 | 1                   | $[M] \leftarrow \neg [M]$<br>Ones complement contents of memory location.                                                                                                                                             |
|                                                         | DEC      | adr8<br>adr16<br>ind. forms | 2<br>3<br>2+ | 6<br>7<br>6+ |        |   |   |   | X | X | X |                     | $[M] \leftarrow [M]-1$<br>Decrement (by 1) contents of memory location.                                                                                                                                               |
|                                                         | INC      | adr8<br>adr16<br>ind. forms | 2<br>3<br>2+ | 6<br>7<br>6+ |        |   |   |   | X | X | X |                     | $[M] \leftarrow [M]+1$<br>Increment (by 1) contents of memory location.                                                                                                                                               |
|                                                         | LSL      | adr8<br>adr16<br>ind. forms | 2<br>3<br>2+ | 6<br>7<br>6+ |        | X |   |   | X | X | X | X                   | <br>Logical shift left. Same as ASL.                                                                                               |
|                                                         | LSR      | adr8<br>adr16<br>ind. forms | 2<br>3<br>2+ | 6<br>7<br>6+ |        |   |   |   | 0 | X |   | X                   | <br>Logical shift right. Bit 7 is set to 0.                                                                                        |
|                                                         | NEG      | adr8<br>adr16<br>ind. forms | 2<br>3<br>2+ | 6<br>7<br>6+ |        | X |   |   | X | X | X | X                   | $[M] \leftarrow 00_{16} - [M]$<br>Twos complement (negate) contents of memory location. Set Carry if result is $00_{16}$ and clear Carry otherwise. Set Overflow if result is $80_{16}$ and clear Overflow otherwise. |
|                                                         | ROL      | adr8<br>adr16<br>ind. forms | 2<br>3<br>2+ | 6<br>7<br>6+ |        |   |   |   | X | X | X | X                   | <br>Rotate contents of memory location left through Carry flag.                                                                    |

## Appendix A. A Summary of the 6809 Instruction Set (Continued)

| Type                                                       | Mnemonic         | Operand(s)                  | Bytes        | Cycles       | Status |   |   |   |   |   |   | Operation Performed |                                                                                                                                                              |
|------------------------------------------------------------|------------------|-----------------------------|--------------|--------------|--------|---|---|---|---|---|---|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                            |                  |                             |              |              | E      | F | H | I | N | Z | V |                     |                                                                                                                                                              |
| Secondary Memory Reference<br>(Memory Operate) (Continued) | ROR              | adr8<br>adr16<br>ind. forms | 2<br>3<br>2+ | 6<br>7<br>6+ |        |   |   |   | X | X |   | X                   | <br>[M]<br>Rotate contents of memory location right through Carry flag.   |
|                                                            | TST              | adr8<br>adr16<br>ind. forms | 2<br>3<br>2+ | 6<br>7<br>6+ |        |   |   |   | X | X | 0 |                     | [M] - 0018<br>Test contents of memory location for zero or negative value.                                                                                   |
| Immediate                                                  | LDA {<br>LDB }   | data8                       | 2            | 2            |        |   |   |   | X | X | 0 |                     | [ACx] ← data8<br>Load Accumulator A or B immediate.                                                                                                          |
|                                                            | LDD              | data16                      | 3            | 3            |        |   |   |   | X | X | 0 |                     | [D] ← data16<br>Load double Accumulator immediate. Sign flag reflects bit 15 of the data (bit 7 of Accumulator A).                                           |
|                                                            | LDU {<br>LDX }   | data16                      | 3            | 3            |        |   |   |   | X | X | 0 |                     | [reg] ← data16<br>Load specified register (X,Y,U, or S) immediate. Sign flag (N) reflects bit 15 of the register.                                            |
|                                                            | LDS {<br>LDY }   | data16                      | 4            | 4            |        |   |   |   | X | X | 0 |                     |                                                                                                                                                              |
| Immediate Operate                                          | ADCA {<br>ADCB } | data8                       | 2            | 2            |        | X |   | X | X | X | X |                     | [ACx] ← [ACx] + data8 + C<br>Add immediate with carry to Accumulator A or B.                                                                                 |
|                                                            | ADDA {<br>ADDB } | data8                       | 2            | 2            |        | X |   | X | X | X | X |                     | [ACx] ← [ACx] + data8<br>Add immediate to Accumulator A or B.                                                                                                |
|                                                            | ADDD             | data16                      | 3            | 4            |        |   |   | X | X | X | X |                     | [D] ← [D] + data16<br>Add 16-bit data to double Accumulator. The high-order byte follows the operation code; the low-order byte follows the high-order byte. |

**Appendix A. A Summary of the 6809 Instruction Set (Continued)**

| Type                            | Mnemonic | Operand(s) | Bytes | Cycles | Status |   |   |   |   |   |   | Operation Performed |                                                                                                                    |
|---------------------------------|----------|------------|-------|--------|--------|---|---|---|---|---|---|---------------------|--------------------------------------------------------------------------------------------------------------------|
|                                 |          |            |       |        | E      | F | H | I | N | Z | V | C                   |                                                                                                                    |
| (Immediate Operate) (Continued) | ANDA }   | data8      | 2     | 2      |        |   |   |   | X | X | 0 |                     | [ACx] ← [ACx] $\wedge$ data8<br>Logical AND immediate with Accumulator A or B.                                     |
|                                 | ANDB }   |            |       |        |        |   |   |   | X | X | 0 |                     | [ACx] $\wedge$ data8<br>Logical AND immediate with Accumulator A or B but affect only the status register.         |
|                                 | BITA }   | data8      | 2     | 2      |        |   |   | X |   |   |   |                     | [ACx] $\wedge$ data8<br>Logical AND immediate with Accumulator A or B but affect only the status register.         |
|                                 | BITB }   |            |       |        |        |   |   | X |   |   |   |                     | [ACx] $\wedge$ data8<br>Logical AND immediate with Accumulator A or B but affect only the status register.         |
|                                 | CMPA }   | data8      | 2     | 2      |        |   | X |   | X | X | X | X                   | [ACx] – data8<br>Subtract immediate from Accumulator A or B but affect only the status register.                   |
|                                 | CMPB }   |            |       |        |        |   | X |   | X | X | X | X                   | [ACx] – data8<br>Subtract immediate from Accumulator A or B but affect only the status register.                   |
|                                 | CMPD     | data16     | 4     | 5      |        |   |   | X | X | X | X | X                   | [D] – data16<br>Subtract immediate from double Accumulator but affect only the status register.                    |
|                                 | CMPS }   | data16     | 4     | 5      |        |   |   | X | X | X | X | X                   | [reg] – data16<br>Subtract immediate from specified register (S, U, X, or Y), but affect only the status register. |
|                                 | CMPU }   |            |       |        |        |   |   | X | X | X | X | X                   | [reg] – data16<br>Subtract immediate from specified register (S, U, X, or Y), but affect only the status register. |
|                                 | CMPY }   |            |       |        |        |   |   | X | X | X | X | X                   | [reg] – data16<br>Subtract immediate from specified register (S, U, X, or Y), but affect only the status register. |
|                                 | CMPX     | data16     | 3     | 4      |        |   |   | X | X | X | X | X                   | [ACx] $\leftarrow$ [ACx] $\vee$ data8<br>Logical Exclusive-OR immediate with Accumulator A or B.                   |
|                                 | EORA }   |            |       |        |        |   |   | X | X | 0 |   |                     | [ACx] $\leftarrow$ [ACx] $\vee$ data8<br>Logical Exclusive-OR immediate with Accumulator A or B.                   |
|                                 | EORB }   |            |       |        |        |   |   | X | X | 0 |   |                     | [ACx] $\leftarrow$ [ACx] V data8<br>Logical (Inclusive) OR immediate with Accumulator A or B.                      |
|                                 | ORA }    | data8      | 2     | 2      |        |   |   | X | X | 0 |   |                     | [ACx] $\leftarrow$ [ACx] V data8<br>Logical (Inclusive) OR immediate with Accumulator A or B.                      |
|                                 | ORB }    |            |       |        |        |   |   | X | X | 0 |   |                     | [ACx] $\leftarrow$ [ACx] V data8<br>Logical (Inclusive) OR immediate with Accumulator A or B.                      |
|                                 | SBCA }   | data8      | 2     | 2      |        |   | X |   | X | X | X | X                   | [ACx] $\leftarrow$ [ACx] – data8 – C<br>Subtract with borrow (carry) immediate from Accumulator A or B.            |
|                                 | SBCB }   |            |       |        |        |   | X |   | X | X | X | X                   | [ACx] $\leftarrow$ [ACx] – data8 – C<br>Subtract with borrow (carry) immediate from Accumulator A or B.            |
|                                 | SUBA }   | data8      | 2     | 2      |        |   | X |   | X | X | X | X                   | [ACx] $\leftarrow$ [ACx] – data8<br>Subtract immediate from Accumulator A or B.                                    |
|                                 | SUBB }   |            |       |        |        |   | X |   | X | X | X | X                   | [ACx] $\leftarrow$ [ACx] – data8<br>Subtract immediate from Accumulator A or B.                                    |
|                                 | SUBD     | data16     | 3     | 4      |        |   |   | X | X | X | X | X                   | [D] $\leftarrow$ [D] – data16<br>Subtract immediate from double Accumulator D.                                     |

## Appendix A. A Summary of the 6809 Instruction Set (Continued)

| Type                       | Mnemonic | Operand(s)                  | Bytes        | Cycles       | Status |   |   |   |   |   |   |   | Operation Performed |                                                                                                                                                                                                                                                                                                                                                   |
|----------------------------|----------|-----------------------------|--------------|--------------|--------|---|---|---|---|---|---|---|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                            |          |                             |              |              | E      | F | H | I | N | Z | V | C |                     |                                                                                                                                                                                                                                                                                                                                                   |
| Jump                       | BRA      | disp8                       | 2            | 3            |        |   |   |   |   |   |   |   |                     | $[PC] \leftarrow [PC] + \text{disp8} + 2$<br>Unconditional branch relative to current contents of Program Counter.                                                                                                                                                                                                                                |
|                            | JMP      | adr8<br>adr16<br>ind. forms | 2<br>3<br>2+ | 3<br>4<br>3+ |        |   |   |   |   |   |   |   |                     | $[PC] \leftarrow EA$<br>Unconditional jump to the specified (effective) address using base page direct, extended direct, indexed, or indirect addressing.                                                                                                                                                                                         |
|                            | LBRA     | disp16                      | 3            | 5            |        |   |   |   |   |   |   |   |                     | $[PC] \leftarrow [PC] + \text{disp16} + 3$<br>Unconditional long branch relative to current contents of Program Counter.                                                                                                                                                                                                                          |
|                            | TFR      | R16,PC                      | 2            | 7            |        |   |   |   |   |   |   |   |                     | $[PC] \leftarrow [R16]$<br>Unconditional jump to the address in the specified 16-bit register (D, S, U, X, or Y).                                                                                                                                                                                                                                 |
| Subroutine Call and Return | BSR      | disp8                       | 2            | 7            |        |   |   |   |   |   |   |   |                     | $[(S)-1] \leftarrow [PC(LO)]$<br>$[(S)-2] \leftarrow [PC(HI)]$<br>$[S] \leftarrow [S] - 2$<br>$[PC] \leftarrow [PC] + \text{disp8} + 2$<br>Unconditional branch to subroutine relative to current contents of Program Counter, saving current Program Counter in the Hardware Stack before performing branch.                                     |
|                            | EXG      | R16,PC                      | 2            | 8            |        |   |   |   |   |   |   |   |                     | $[R16] \leftarrow [PC]$<br>Unconditional jump to the address in the specified 16-bit register (D, S, U, X, or Y), save current Program Counter in the specified register. Can be used to call a subroutine or return from a subroutine; the specified 16-bit register acts as a link.                                                             |
|                            | JSR      | adr8<br>adr16<br>ind. forms | 2<br>3<br>2+ | 7<br>8<br>7+ |        |   |   |   |   |   |   |   |                     | $[(S)-1] \leftarrow [PC(LO)]$<br>$[(S)-2] \leftarrow [PC(HI)]$<br>$[S] \leftarrow [S] - 2$<br>$[PC] \leftarrow EA$<br>Unconditional jump to subroutine at the specified (effective) address using base page direct, extended direct, indirect, or indexed addressing. Saves current Program Counter in the Hardware Stack before performing jump. |

**Appendix A. A Summary of the 6809 Instruction Set (Continued)**

| Type                                     | Mnemonic | Operand(s)    | Bytes | Cycles | Status |   |   |   |   |   |   |   | Operation Performed |                                                                                                                                                                                                                                                                                                                  |
|------------------------------------------|----------|---------------|-------|--------|--------|---|---|---|---|---|---|---|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                          |          |               |       |        | E      | F | H | I | N | Z | V | C |                     |                                                                                                                                                                                                                                                                                                                  |
| (Subroutine Call and Return (Continued)) | LBSR     | disp16        | 3     | 9      |        |   |   |   |   |   |   |   |                     | $[(S) - 1] \leftarrow [PC(LO)]$<br>$[(S) - 2] \leftarrow [PC(HI)]$<br>$[S] \leftarrow [S] - 2$<br>$[PC] \leftarrow [PC] + disp16 + 3$<br>Unconditional long branch to subroutine relative to current contents of Program Counter, saving current Program Counter in the Hardware Stack before performing branch. |
|                                          | PULS }   | PC, reg. list | 2     | 5+     |        |   |   |   |   |   |   |   |                     | Return from Subroutine and load other registers from Hardware or User Stack as specified in post byte. Bit 7 of the post byte must be 1 so that the Program Counter is among the registers loaded from the Stack. See the Stack functions section of this table for a description of PULS and PULU operation.    |
|                                          | RTS      |               | 1     | 5      |        |   |   |   |   |   |   |   |                     | $[PC(HI)] \leftarrow [(S)]$<br>$[PC(LO)] \leftarrow [(S) + 1]$<br>$[S] \leftarrow [S] + 2$<br>Return from subroutine: remove program counter from top of Hardware Stack and increment Hardware Stack Pointer twice.                                                                                              |
| Branch on Condition                      | BCC      | disp8         | 2     | 3      |        |   |   |   |   |   |   |   |                     | $[PC] \leftarrow [PC] + disp8 + 2$ if the given condition is true:<br>C = 0<br>C = 1<br>Z = 1<br>$N \neq V = 0$<br>$Z V(N \neq V) = 0$<br>$C V Z = 0$<br>C = 0<br>$Z V(N \neq V) = 1$<br>C = 1<br>$C V Z = 1$<br>$N \neq V = 1$<br>N = 1<br>Z = 0<br>N = 0                                                       |
|                                          | BCS      | disp8         | 2     | 3      |        |   |   |   |   |   |   |   |                     |                                                                                                                                                                                                                                                                                                                  |
|                                          | BEQ      | disp8         | 2     | 3      |        |   |   |   |   |   |   |   |                     |                                                                                                                                                                                                                                                                                                                  |
|                                          | BGE      | disp8         | 2     | 3      |        |   |   |   |   |   |   |   |                     |                                                                                                                                                                                                                                                                                                                  |
|                                          | BGT      | disp8         | 2     | 3      |        |   |   |   |   |   |   |   |                     |                                                                                                                                                                                                                                                                                                                  |
|                                          | BHI      | disp8         | 2     | 3      |        |   |   |   |   |   |   |   |                     |                                                                                                                                                                                                                                                                                                                  |
|                                          | BHS      | disp8         | 2     | 3      |        |   |   |   |   |   |   |   |                     |                                                                                                                                                                                                                                                                                                                  |
|                                          | BLE      | disp8         | 2     | 3      |        |   |   |   |   |   |   |   |                     |                                                                                                                                                                                                                                                                                                                  |
|                                          | BLO      | disp8         | 2     | 3      |        |   |   |   |   |   |   |   |                     |                                                                                                                                                                                                                                                                                                                  |
|                                          | BLS      | disp8         | 2     | 3      |        |   |   |   |   |   |   |   |                     |                                                                                                                                                                                                                                                                                                                  |
|                                          | BLT      | disp8         | 2     | 3      |        |   |   |   |   |   |   |   |                     |                                                                                                                                                                                                                                                                                                                  |
|                                          | BMI      | disp8         | 2     | 3      |        |   |   |   |   |   |   |   |                     |                                                                                                                                                                                                                                                                                                                  |
|                                          | BNE      | disp8         | 2     | 3      |        |   |   |   |   |   |   |   |                     |                                                                                                                                                                                                                                                                                                                  |
|                                          | BPL      | disp8         | 2     | 3      |        |   |   |   |   |   |   |   |                     |                                                                                                                                                                                                                                                                                                                  |

## Appendix A. A Summary of the 6809 Instruction Set (Continued)

| Type                            | Mnemonic | Operand(s) | Bytes | Cycles | Status |   |   |   |   |   |   |   | Operation Performed |                                                                                                                 |
|---------------------------------|----------|------------|-------|--------|--------|---|---|---|---|---|---|---|---------------------|-----------------------------------------------------------------------------------------------------------------|
|                                 |          |            |       |        | E      | F | H | I | N | Z | V | C |                     |                                                                                                                 |
| Branch on Condition (Continued) | BVC      | disp8      | 2     | 3      |        |   |   |   |   |   |   |   |                     | V = 0                                                                                                           |
|                                 | BVS      | disp8      | 2     | 3      |        |   |   |   |   |   |   |   |                     | V = 1                                                                                                           |
|                                 | LBCC     | disp16     | 4     | 5(6)   |        |   |   |   |   |   |   |   |                     | [PC] ← [PC] + 2 if the given condition is not true.                                                             |
|                                 | LBCS     | disp16     | 4     | 5(6)   |        |   |   |   |   |   |   |   |                     | Note that BHS and BCC are different mnemonics for the same operation code, as are BLO and BCS.                  |
|                                 | LBEQ     | disp16     | 4     | 5(6)   |        |   |   |   |   |   |   |   |                     | [PC] ← [PC] + disp16 + 4 if the given condition is true:                                                        |
|                                 | LBGE     | disp16     | 4     | 5(6)   |        |   |   |   |   |   |   |   |                     | C = 0                                                                                                           |
|                                 | LBGT     | disp16     | 4     | 5(6)   |        |   |   |   |   |   |   |   |                     | C = 1                                                                                                           |
|                                 | LBHI     | disp16     | 4     | 5(6)   |        |   |   |   |   |   |   |   |                     | Z = 1                                                                                                           |
|                                 | LBHS     | disp16     | 4     | 5(6)   |        |   |   |   |   |   |   |   |                     | N $\neq$ V = 0                                                                                                  |
|                                 | LBLE     | disp16     | 4     | 5(6)   |        |   |   |   |   |   |   |   |                     | Z V(N $\neq$ V) = 0                                                                                             |
|                                 | LBLO     | disp16     | 4     | 5(6)   |        |   |   |   |   |   |   |   |                     | C V Z = 0                                                                                                       |
|                                 | LBLS     | disp16     | 4     | 5(6)   |        |   |   |   |   |   |   |   |                     | C = 0                                                                                                           |
|                                 | LBLT     | disp16     | 4     | 5(6)   |        |   |   |   |   |   |   |   |                     | Z V(N $\neq$ V) = 1                                                                                             |
|                                 | LBMI     | disp16     | 4     | 5(6)   |        |   |   |   |   |   |   |   |                     | C = 1                                                                                                           |
|                                 | LBNE     | disp16     | 4     | 5(6)   |        |   |   |   |   |   |   |   |                     | C V Z = 1                                                                                                       |
|                                 | LBPL     | disp16     | 4     | 5(6)   |        |   |   |   |   |   |   |   |                     | N $\neq$ V = 1                                                                                                  |
|                                 | LBVC     | disp16     | 4     | 5(6)   |        |   |   |   |   |   |   |   |                     | N = 1                                                                                                           |
|                                 | LBVS     | disp16     | 4     | 5(6)   |        |   |   |   |   |   |   |   |                     | Z = 0                                                                                                           |
|                                 |          |            |       |        |        |   |   |   |   |   |   |   |                     | N = 0                                                                                                           |
|                                 |          |            |       |        |        |   |   |   |   |   |   |   |                     | V = 0                                                                                                           |
|                                 |          |            |       |        |        |   |   |   |   |   |   |   |                     | V = 1                                                                                                           |
| Register to Register Move       | EXG      | R1, R2     | 2     | 8      |        |   |   |   |   |   |   |   |                     | [R1] ←→ [R2]                                                                                                    |
|                                 | TFR      | R1, R2     | 2     | 7      |        |   |   |   |   |   |   |   |                     | Exchange contents of specified registers. No effect on Status register (CC) unless R1 or R2 is Status register. |
|                                 |          |            |       |        |        |   |   |   |   |   |   |   |                     | [R2] ← [R1]                                                                                                     |
|                                 |          |            |       |        |        |   |   |   |   |   |   |   |                     | Transfer contents of R1 to R2. No effect on Status register (CC) unless R2 is CC.                               |

## Appendix A. A Summary of the 6809 Instruction Set (Continued)

| Type                         | Mnemonic          | Operand(s) | Bytes | Cycles | Status |   |   |   |   |   |   |   | Operation Performed |                                                                                                                                                                                                                                                                                                                  |
|------------------------------|-------------------|------------|-------|--------|--------|---|---|---|---|---|---|---|---------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                              |                   |            |       |        | E      | F | H | I | N | Z | V | C |                     |                                                                                                                                                                                                                                                                                                                  |
| Register-Register<br>Operate | ABX               |            | 1     | 3      |        |   |   |   |   |   |   |   |                     | [X] $\leftarrow$ [X] + [B]<br>Add unsigned contents of Accumulator B to Index Register X.                                                                                                                                                                                                                        |
|                              | MUL               |            | 1     | 11     |        |   |   |   |   | X |   |   | X                   | [D] $\leftarrow$ [A] $\times$ [B]<br>Multiply unsigned numbers in Accumulators A and B and place result in D.<br>Carry flag takes the value of bit 7 of Accumulator B.<br>[A] $\leftarrow$ FF <sub>16</sub> if bit 7 of Accumulator B is 1.<br>[A] $\leftarrow$ 00 <sub>16</sub> if bit 7 of Accumulator B is 0. |
|                              | SEX               |            | 1     | 2      |        |   |   |   | X | X |   |   |                     | Transform an 8-bit two's complement number in B into a 16-bit two's complement number in D.                                                                                                                                                                                                                      |
| Register Operate             | ASLA {<br>ASLB }  |            | 1     | 2      |        |   | X |   | X | X | X | X |                     | [ACx]<br>Arithmetic shift left Accumulator A or B. Bit 0 is set to 0.                                                                                                                                                                                                                                            |
|                              | ASRA {<br>ASRB }  |            | 1     | 2      |        |   | X |   | X | X |   | X |                     | [ACx]<br>Arithmetic shift right Accumulator A or B. Bit 7 stays the same.                                                                                                                                                                                                                                        |
|                              | CLRA {<br>CLRB }  |            | 1     | 2      |        |   |   |   | 0 | 1 | 0 | 0 |                     | [ACx] $\leftarrow$ 00 <sub>16</sub><br>Clear Accumulator A or B.                                                                                                                                                                                                                                                 |
|                              | COMA {<br>COMB }  |            | 1     | 2      |        |   |   |   | X | X | 0 | 1 |                     | [ACx] $\leftarrow$ [ACx]<br>Ones complement contents of Accumulator A or B.                                                                                                                                                                                                                                      |
|                              | DAA               |            | 1     | 2      |        |   |   |   | X | X | X | X |                     | Decimal adjust Accumulator A. Convert contents of Accumulator A (assumed to be the binary sum of BCD operands) to BCD format. Carry is set if it was previously set or if the adjustment results in a carry.                                                                                                     |
|                              | DECA {<br>DEC B } |            | 1     | 2      |        |   |   |   | X | X | X |   |                     | [ACx] $\leftarrow$ [ACx] - 1<br>Decrement (by 1) contents of Accumulator A or B. Set Overflow flag if result is 7F <sub>16</sub> and clear Overflow flag otherwise.                                                                                                                                              |

## **Appendix A. A Summary of the 6809 Instruction Set (Continued)**

| Type                         | Mnemonic          | Operand(s) | Bytes | Cycles | Status |   |   |   |   |   |   | Operation Performed |                                                                                                                                                                                                                                                  |
|------------------------------|-------------------|------------|-------|--------|--------|---|---|---|---|---|---|---------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                              |                   |            |       |        | E      | F | H | I | N | Z | V | C                   |                                                                                                                                                                                                                                                  |
| Register Operate (Continued) | INCA {<br>INC B } |            | 1     | 2      |        |   |   |   | X | X | X |                     | [ACx] $\leftarrow [ACx] + 1$<br>Increment (by 1) contents of Accumulator A or B. Set Overflow flag if result is $80_{16}$ and clear Overflow flag otherwise.                                                                                     |
|                              | LSLA {<br>LSL B } |            | 1     | 2      |        |   | X |   | X | X | X | X                   |  [ACx]                                                                                                                                                        |
|                              | LSRA {<br>LSR B } |            | 1     | 2      |        |   |   |   | 0 | X |   | X                   |  [ACx]                                                                                                                                                        |
|                              | NEGA {<br>NEG B } |            | 1     | 2      |        | X |   | X | X | X | X |                     | [ACx] $\leftarrow 00_{16} - [ACx]$<br>Twos complement (negate) contents of Accumulator A or B. Set Carry flag if result is $00_{16}$ and clear Carry flag otherwise. Set Overflow flag if result is $80_{16}$ and clear Overflow flag otherwise. |
|                              | ROLA {<br>ROL B } |            | 1     | 2      |        |   |   |   | X | X | X | X                   |  [ACx]                                                                                                                                                        |
|                              | RORA {<br>ROR B } |            | 1     | 2      |        |   |   |   | X | X |   | X                   |  [ACx]                                                                                                                                                        |

**Appendix A. A Summary of the 6809 Instruction Set (Continued)**

| Type                         | Mnemonic         | Operand(s) | Bytes | Cycles | Status |   |   |   |   |   |   |   | Operation Performed                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|------------------------------|------------------|------------|-------|--------|--------|---|---|---|---|---|---|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                              |                  |            |       |        | E      | F | H | I | N | Z | V | C |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Register Operate (Continued) | TSTA {<br>TSTB } | ind. forms | 1     | 2      |        |   |   |   | X | X | 0 |   | [ACx] - 00 <sub>16</sub><br>Test contents of Accumulator A or B for zero or negative value.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|                              | LEAX {<br>LEAY } |            | 2+    | 4+     |        |   |   |   |   | X |   |   | [reg] ← EA<br>Form the effective address according to any of the indexed/ indirect addressing modes (see Appendix B) and load that address into the specified register (X, Y, S, or U). LEA instructions are primarily intended to calculate an effective address once for repeated use, but may also be employed to perform 16-bit arithmetic.                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                              | LEAS {<br>LEAU } | ind. forms | 2+    | 4+     |        |   |   |   |   |   |   |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| Stack                        | PSHS {<br>PSHU } | reg. list  | 2     | 5+     |        |   |   |   |   |   |   |   | Test post byte and store registers in specified stack as follows:<br>Condition:<br>b7 = 1; [SP] ← [SP] - 1, [[SP]] ← [PC(LO)]<br>[SP] ← [SP] - 1, [[SP]] ← [PC(HI)]<br>b6 = 1; [SP] ← [SP] - 1, [[SP]] ← [U(LO)] or [S(LO)]<br>[SP] ← [SP] - 1, [[SP]] ← [U(HI)] or [S(HI)]<br>b5 = 1; [SP] ← [SP] - 1, [[SP]] ← [Y(LO)]<br>[SP] ← [SP] - 1, [[SP]] ← [Y(HI)]<br>b4 = 1; [SP] ← [SP] - 1, [[SP]] ← [X(LO)]<br>[SP] ← [SP] - 1, [[SP]] ← [X(HI)]<br>b3 = 1; [SP] ← [SP] - 1, [[SP]] ← [DP]<br>b2 = 1; [SP] ← [SP] - 1, [[SP]] ← [B]<br>b1 = 1; [SP] ← [SP] - 1, [[SP]] ← [A]<br>b0 = 1; [SP] ← [SP] - 1, [[SP]] ← [CC]<br>Push all, none, or any subset of registers onto the specified Stack, except for the pointer to that Stack.<br>Execution time increases by one cycle for each byte pushed. |
|                              |                  |            |       |        |        |   |   |   |   |   |   |   |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |

## Appendix A. A Summary of the 6809 Instruction Set (Continued)

| Type              | Mnemonic         | Operand(s) | Bytes | Cycles | Status |   |   |   |   |   |   |   | Operation Performed |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-------------------|------------------|------------|-------|--------|--------|---|---|---|---|---|---|---|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                   |                  |            |       |        | E      | F | H | I | N | Z | V | C |                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| Stack (Continued) | PULS {<br>PULU } | reg. list  | 2     | 5+     |        |   |   |   |   |   |   |   |                     | <p>Test post byte and load registers from specified stack as follows:</p> <p>Condition:</p> <p>b0 = 1; [CC] ← [[SP]], [SP] ← [SP] + 1<br/> b1 = 1; [A] ← [[SP]], [SP] ← [SP] + 1<br/> b2 = 1; [B] ← [[SP]], [SP] ← [SP] + 1<br/> b3 = 1; [DP] ← [[SP]], [SP] ← [SP] + 1<br/> b4 = 1; [X(HI)] ← [[SP]], [SP] ← [SP] + 1<br/> [X(LO)] ← [[SP]], [SP] ← [SP] + 1<br/> b5 = 1; [Y(HI)] ← [[SP]], [SP] ← [SP] + 1<br/> [Y(LO)] ← [[SP]], [SP] ← [SP] + 1<br/> b6 = 1; [U(HI)] or [S(HI)] ← [[SP]], [SP] ← [SP] + 1<br/> [U(LO)] or [S(LO)] ← [[SP]], [SP] ← [SP] + 1<br/> b7 = 1; [PC(HI)] ← [[SP]], [SP] ← [SP] + 1<br/> [PC(LO)] ← [[SP]], [SP] ← [SP] + 1</p> <p>Pull all, none, or any subset of registers from the specified stack, except for the Pointer to that Stack. Status register bits are determined by byte pulled from Stack.</p> <p>Execution time increases by one cycle for each byte pulled.</p> |

**Appendix A. A Summary of the 6809 Instruction Set (Continued)**

| Type      | Mnemonic | Operand(s) | Bytes | Cycles | Status |   |   |   |   |   |   |   | Operation Performed                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----------|----------|------------|-------|--------|--------|---|---|---|---|---|---|---|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           |          |            |       |        | E      | F | H | I | N | Z | V | C |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| Interrupt | CWAI     | data8      | 2     | 20     |        |   |   |   |   |   |   |   | [CC] $\leftarrow$ [CC] $\wedge$ data8. This may clear CC bits.<br>E $\leftarrow$ 1<br>[S] $\leftarrow$ [S] - 1, [[S]] $\leftarrow$ [PC(LO)]<br>[S] $\leftarrow$ [S] - 1, [[S]] $\leftarrow$ [PC(HI)]<br>[S] $\leftarrow$ [S] - 1, [[S]] $\leftarrow$ [U(LO)]<br>[S] $\leftarrow$ [S] - 1, [[S]] $\leftarrow$ [U(HI)]<br>[S] $\leftarrow$ [S] - 1, [[S]] $\leftarrow$ [Y(LO)]<br>[S] $\leftarrow$ [S] - 1, [[S]] $\leftarrow$ [Y(HI)]<br>[S] $\leftarrow$ [S] - 1, [[S]] $\leftarrow$ [X(LO)]<br>[S] $\leftarrow$ [S] - 1, [[S]] $\leftarrow$ [X(HI)]<br>[S] $\leftarrow$ [S] - 1, [[S]] $\leftarrow$ [DP]<br>[S] $\leftarrow$ [S] - 1, [[S]] $\leftarrow$ [B]<br>[S] $\leftarrow$ [S] - 1, [[S]] $\leftarrow$ [A]<br>[S] $\leftarrow$ [S] - 1, [[S]] $\leftarrow$ [CC]<br>Stores all registers in Hardware Stack and waits for an interrupt. When non-masked interrupt occurs, vectors to corresponding interrupt service routine. Note that a fast interrupt (FIRQ) service routine will be entered with all registers saved, but RTI will restore them correctly since CWAI sets E flag. CWAI does not float the system busses. |

## Appendix A. A Summary of the 6809 Instruction Set (Continued)

| Type                  | Mnemonic | Operand(s) | Bytes | Cycles | Status |   |   |   |   |   |   |   | Operation Performed                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----------------------|----------|------------|-------|--------|--------|---|---|---|---|---|---|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                       |          |            |       |        | E      | F | H | I | N | Z | V | C |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| Interrupt (Continued) | RTI      |            | 1     | 6/15   |        |   |   |   |   |   |   |   | Pull registers from Hardware Stack in accordance with value of E flag in Status register.<br>If E = 0, pull the subset:<br>[CC] ← [(S)], [S] ← [S] + 1<br>[PC(HI)] ← [(S)], [S] ← [S] + 1<br>[PC(LO)] ← [(S)], [S] ← [S] + 1                                                                                                                                                                                                                                                                                                 |
|                       | SWI      |            | 1     | 19     |        |   |   |   |   |   |   |   | If E = 1, pull the full complement of registers:<br>[CC] ← [(S)], [S] ← [S] + 1<br>[A] ← [(S)], [S] ← [S] + 1<br>[B] ← [(S)], [S] ← [S] + 1<br>[DP] ← [(S)], [S] ← [S] + 1<br>[X(HI)] ← [(S)], [S] ← [S] + 1<br>[X(LO)] ← [(S)], [S] ← [S] + 1<br>[Y(HI)] ← [(S)], [S] ← [S] + 1<br>[Y(LO)] ← [(S)], [S] ← [S] + 1<br>[U(HI)] ← [(S)], [S] ← [S] + 1<br>[U(LO)] ← [(S)], [S] ← [S] + 1<br>[PC(HI)] ← [(S)], [S] ← [S] + 1<br>[PC(LO)] ← [(S)], [S] ← [S] + 1<br>Status register bits are as removed from the Hardware Stack. |
|                       | SWI2     |            | 2     | 20     | 1      | 1 |   |   |   |   |   |   | Save all registers in the Hardware Stack and transfer control to interrupt subroutine. Vectors are in:<br>FFFA and FFFB for SWI<br>FFF4 and FFF5 for SWI2<br>FFF2 and FFF3 for SWI3                                                                                                                                                                                                                                                                                                                                          |
|                       | SWI3     |            | 2     | 20     | 1      |   |   |   |   |   |   |   | E ← 1<br>[S] ← [S] - 1, [(S)] ← [PC(LO)]<br>[S] ← [S] - 1, [(S)] ← [PC(HI)]<br>[S] ← [S] - 1, [(S)] ← [U(LO)]<br>[S] ← [S] - 1, [(S)] ← [U(HI)]<br>[S] ← [S] - 1, [(S)] ← [Y(LO)]<br>[S] ← [S] - 1, [(S)] ← [Y(HI)]<br>[S] ← [S] - 1, [(S)] ← [X(LO)]<br>[S] ← [S] - 1, [(S)] ← [X(HI)]                                                                                                                                                                                                                                      |

**Appendix A. A Summary of the 6809 Instruction Set (Continued)**

| Type                  | Mnemonic           | Operand(s)      | Bytes       | Cycles      | Status |   |   |   |   |   |   |   | Operation Performed |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----------------------|--------------------|-----------------|-------------|-------------|--------|---|---|---|---|---|---|---|---------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                       |                    |                 |             |             | E      | F | H | I | N | Z | V | C |                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Interrupt (Continued) | SYNC               |                 | 1           | 2           |        |   |   |   |   |   |   |   |                     | <p><math>[S] \leftarrow [S] - 1</math>, <math>[(S)] \leftarrow [DP]</math><br/> <math>[S] \leftarrow [S] - 1</math>, <math>[(S)] \leftarrow [B]</math><br/> <math>[S] \leftarrow [S] - 1</math>, <math>[(S)] \leftarrow [A]</math><br/> <math>[S] \leftarrow [S] - 1</math>, <math>[(S)] \leftarrow [CC]</math><br/> <math>[PC] \leftarrow [\text{interrupt vector}]</math></p> <p>Note that the SWI disables the regular and fast interrupts, whereas SWI2 and SWI3 do not affect either one.</p> <p>Stop processing instructions. Float system busses and wait for an interrupt. When an interrupt occurs, resume processing as follows:</p> <ol style="list-style-type: none"> <li>If interrupt is enabled, transfer control to the service routine.</li> <li>If interrupt is disabled, continue execution at next instruction in sequence.</li> </ol> |
| Status                | ANDCC              | data8           | 2           | 3           |        |   |   |   |   |   |   |   |                     | <p><math>[CC] \leftarrow [CC] \wedge \text{data8}</math></p> <p>Logically AND immediate data with contents of status register. Used to clear bits of status register by logically ANDing them with '0's.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|                       | ORCC               | data8           | 2           | 3           |        |   |   |   |   |   |   |   |                     | <p><math>[CC] \leftarrow [CC] \vee \text{data8}</math></p> <p>Logically (Inclusive) OR immediate data with contents of status register. Used to set bits of status register by logically ORing them with '1's.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
| No Operations         | BRN<br>LBRN<br>NOP | disp8<br>disp16 | 2<br>5<br>2 | 3<br>4<br>1 |        |   |   |   |   |   |   |   |                     | <p>Branch never. This is a No operation.<br/>     Long branch never. This is a No operation.<br/>     No operation.</p>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

B

# **Summary of 6809 Indexed and Indirect Addressing Modes**

| Type                       | Form                | Non-indirect   |                   | Cycles<br>+<br>+ | Indirect       |                   | Cycles<br>+<br>+ |
|----------------------------|---------------------|----------------|-------------------|------------------|----------------|-------------------|------------------|
|                            |                     | Assembler Form | Post-Byte Op-code |                  | Assembler Form | Post-Byte Op-code |                  |
| Constant Offset from R     | No Offset           | ,R             | 1RR00100          | 0                | [,R]           | 1RR10100          | 3                |
|                            | 5-Bit Offset        | n,R            | ORRnnnnn          | 1                | [,R]           | Defaults to 8-bit | 0                |
|                            | 8-Bit Offset        | nn,R           | 1RR01000          | 1                | [nn,R]         | 1RR11000          | 4                |
|                            | 16-Bit Offset       | mmnn,R         | 1RR01001          | 4                | [mmnn,R]       | 1RR11001          | 2                |
| Accumulator Offset from R  | A — Register Offset | A,R            | 1RR00110          | 1                | [A,R]          | 1RR10110          | 4                |
|                            | B — Register Offset | B,R            | 1RR00101          | 1                | [B,R]          | 1RR10101          | 4                |
|                            | D — Register Offset | D,R            | 1RR01011          | 4                | [D,R]          | 1RR11011          | 0                |
| Auto Increment/Decrement R | Increment by 1      | ,R+            | 1RR00000          | 2                | [,R++]         | Not allowed       | 6                |
|                            | Increment by 2      | ,R++           | 1RR00001          | 3                | [,R++]         | 1RR10001          | 0                |
|                            | Decrement by 1      | ,-R            | 1RR00010          | 2                | [,-R]          | Not allowed       | 6                |
|                            | Decrement by 2      | ,--R           | 1RR00011          | 3                | [,-R]          | 1RR10011          | 0                |
| Constant Offset from PC    | 8-Bit Offset        | label,PCR      | 1XX01100          | 1                | [label,PCR]    | 1XX11100          | 4                |
|                            | 16-Bit Offset       | label,PCR      | 1XX01101          | 5                | [label,PCR]    | 1XX11101          | 2                |
| Extended Indirect          | 16-Bit Address      | —              | —                 | —                | [mmnn]         | 10011111          | 5                |

## **6809 Instruction Codes, Memory Requirements, and Execution Times**

| Address Mode         | Inherent    |               |              | Immediate       |               |              | Direct      |               |              | Extended    |               |              | Indexed/Indirect |               |              | Relative              |               |              |
|----------------------|-------------|---------------|--------------|-----------------|---------------|--------------|-------------|---------------|--------------|-------------|---------------|--------------|------------------|---------------|--------------|-----------------------|---------------|--------------|
| Operand Form         |             |               |              | data8 or data16 |               |              | adr8        |               |              | adr16       |               |              | See Appendix B   |               |              | label or displacement |               |              |
| Instruction Mnemonic | Object Code | No. of Cycles | No. of Bytes | Object Code     | No. of Cycles | No. of Bytes | Object Code | No. of Cycles | No. of Bytes | Object Code | No. of Cycles | No. of Bytes | Object Code      | No. of Cycles | No. of Bytes | Object Code           | No. of Cycles | No. of Bytes |
| ABX                  | 3A          | 3             | 1            | 89              | 2             | 2            | 99          | 4             | 2            | B9          | 5             | 3            | A9               | 4+            | 2+           |                       |               |              |
| ADCA                 |             |               |              | C9              | 2             | 2            | D9          | 4             | 2            | F9          | 5             | 3            | E9               | 4+            | 2+           |                       |               |              |
| ADCB                 |             |               |              | 8B              | 2             | 2            | 9B          | 4             | 2            | BB          | 5             | 3            | AB               | 4+            | 2+           |                       |               |              |
| ADDA                 |             |               |              | CB              | 2             | 2            | DB          | 4             | 2            | FB          | 5             | 3            | EB               | 4+            | 2+           |                       |               |              |
| ADDB                 |             |               |              | C3              | 4             | 3            | D3          | 6             | 2            | F3          | 7             | 3            | E3               | 6+            | 2+           |                       |               |              |
| ADDD                 |             |               |              | 84              | 2             | 2            | 94          | 4             | 2            | B4          | 5             | 3            | A4               | 4+            | 2+           |                       |               |              |
| ANDA                 |             |               |              | C4              | 2             | 2            | D4          | 4             | 2            | F4          | 5             | 3            | E4               | 4+            | 2+           |                       |               |              |
| ANDB                 |             |               |              | 1C              | 3             | 2            |             |               |              |             |               |              |                  |               |              |                       |               |              |
| ANDCC                |             |               |              |                 |               |              | 08          | 6             | 2            | 78          | 7             | 3            | 68               | 6+            | 2+           |                       |               |              |
| ASL                  |             |               |              |                 |               |              | 07          | 6             | 2            | 77          | 7             | 3            | 67               | 6+            | 2+           |                       |               |              |
| ASLA                 | 48          | 2             | 1            |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |
| ASLB                 | 58          | 2             | 1            |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |
| ASR                  |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |
| ASRA                 | 47          | 2             | 1            |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |
| ASRB                 | 57          | 2             | 1            |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |
| BCC                  |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              | 24                    | 3             | 2            |
| BCS                  |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              | 25                    | 3             | 2            |
| BEQ                  |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              | 27                    | 3             | 2            |
| BGE                  |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              | 2C                    | 3             | 2            |
| BGT                  |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              | 2E                    | 3             | 2            |
| BHI                  |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              | 22                    | 3             | 2            |
| BHS                  |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              | 24                    | 3             | 2            |
| BITA                 |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |
| BITB                 |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |
| BLE                  |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              | 2F                    | 3             | 2            |
| BLO                  |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              | 25                    | 3             | 2            |
| BLS                  |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              | 23                    | 3             | 2            |
| BLT                  |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              | 2D                    | 3             | 2            |
| BMH                  |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              | 2B                    | 3             | 2            |
| BNE                  |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              | 26                    | 3             | 2            |
| BPL                  |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              | 2A                    | 3             | 2            |
| BRA                  |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              | 20                    | 3             | 2            |
| BRN                  |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              | 21                    | 3             | 2            |
| BSR                  |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              | 8D                    | 7             | 2            |
| BVC                  |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              | 28                    | 3             | 2            |
| BVS                  |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              | 29                    | 3             | 1            |
| CLR                  |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |
| CLRA                 | 4F          | 2             | 1            |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |
| CLRB                 | 5F          | 2             | 1            |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |
| CMPA                 |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |
| CMPB                 |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |
| CMPD                 |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |
|                      |             |               |              | 81              | 2             | 2            | 91          | 4             | 2            | B1          | 5             | 3            | A1               | 4+            | 2+           |                       |               |              |
|                      |             |               |              | C1              | 2             | 2            | D1          | 4             | 2            | F1          | 5             | 3            | E1               | 4+            | 2+           |                       |               |              |
|                      |             |               |              | 10 83           | 5             | 4            | 10 93       | 7             | 3            | 10 B3       | 8             | 4            | 10 A3            | 7+            | 3+           |                       |               |              |

C-2 6809 Instruction Codes, Memory Requirements, and Execution Times

| Address Mode →         | Inherent    |               |              | Immediate       |               |              | Direct      |               |              | Extended    |               |              | Indexed/Indirect |               |              | Relative              |               |              | notes |
|------------------------|-------------|---------------|--------------|-----------------|---------------|--------------|-------------|---------------|--------------|-------------|---------------|--------------|------------------|---------------|--------------|-----------------------|---------------|--------------|-------|
| Operand Form →         |             |               |              | data8 or data16 |               |              | adr8        |               |              | adr16       |               |              | See Appendix B   |               |              | label or displacement |               |              |       |
| Instruction Mnemonic ↓ | Object Code | No. of Cycles | No. of Bytes | Object Code     | No. of Cycles | No. of Bytes | Object Code | No. of Cycles | No. of Bytes | Object Code | No. of Cycles | No. of Bytes | Object Code      | No. of Cycles | No. of Bytes | Object Code           | No. of Cycles | No. of Bytes |       |
| CMPS                   |             |               |              | 11 8C           | 5             | 4            | 11 9C       | 7             | 3            | 11 BC       | 8             | 4            | 11 AC            | 7+            | 3+           |                       |               |              | 2     |
| CMPU                   |             |               |              | 11 83           | 5             | 4            | 11 93       | 7             | 3            | 11 B3       | 8             | 4            | 11 A3            | 7+            | 3+           |                       |               |              |       |
| CMPX                   |             |               |              | 8C              | 4             | 3            | 9C          | 6             | 2            | BC          | 7             | 3            | AC               | 6+            | 2+           |                       |               |              |       |
| CMPY                   |             |               |              | 10 8C           | 5             | 4            | 10 9C       | 7             | 3            | 10 BC       | 8             | 4            | 10 AC            | 7+            | 3+           |                       |               |              |       |
| COM                    |             |               |              |                 |               |              | 03          | 6             | 2            | 73          | 7             | 3            | 63               | 6+            | 2+           |                       |               |              |       |
| COMA                   | 43          | 2             | 1            | 3C              | 20            | 2            | 0A          | 6             | 2            | 7A          | 7             | 3            | 6A               | 6+            | 2+           |                       |               |              |       |
| COMB                   | 53          | 2             | 1            |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |       |
| CWAI                   |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |       |
| DAA                    | 19          | 2             | 1            |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |       |
| DEC                    |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |       |
| DECA                   | 4A          | 2             | 1            |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |       |
| DECB                   | 5A          | 2             | 1            |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |       |
| EORA                   |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |       |
| EORB                   |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |       |
| EXG                    |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |       |
| INC                    |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |       |
| INCA                   |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |       |
| INC8                   |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |       |
| JMP                    |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |       |
| JSR                    |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |       |
| LBCC                   |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |       |
| LBCS                   |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |       |
| LBEQ                   |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |       |
| LBGE                   |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |       |
| LBGT                   |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |       |
| LBHI                   |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |       |
| LBHS                   |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |       |
| LBLE                   |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |       |
| LBLO                   |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |       |
| LBLS                   |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |       |
| LBLT                   |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |       |
| LBWN                   |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |       |
| LBNE                   |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |       |
| LBPL                   |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |       |
| LBRA                   |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |       |
| LBRN                   |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |       |
| LSR                    |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |       |
| LBVC                   |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |       |
| LBVS                   |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |       |
| LDA                    |             |               |              | 86              | 2             | 2            | 96          | 4             | 2            | B6          | 5             | 3            | A6               | 4+            | 2+           |                       |               |              |       |
| LDB                    |             |               |              | C6              | 2             | 2            | D6          | 4             | 2            | F6          | 5             | 3            | E6               | 4+            | 2+           |                       |               |              |       |
| LDI                    |             |               |              | CC              | 3             | 3            | DC          | 5             | 2            | FC          | 6             | 3            | EC               | 5+            | 2+           |                       |               |              |       |



**C-4 6809 Instruction Codes, Memory Requirements, and Execution Times**

| Address Mode<br>→         | Inherent    |               |              | Immediate       |               |              | Direct      |               |              | Extended    |               |              | Indexed/Indirect |               |              | Relative              |               |              | notes |
|---------------------------|-------------|---------------|--------------|-----------------|---------------|--------------|-------------|---------------|--------------|-------------|---------------|--------------|------------------|---------------|--------------|-----------------------|---------------|--------------|-------|
| Operand Form<br>→         |             |               |              | data8 or data16 |               |              | adr8        |               |              | adr16       |               |              | See Appendix B   |               |              | label or displacement |               |              |       |
| Instruction Mnemonic<br>↓ | Object Code | No. of Cycles | No. of Bytes | Object Code     | No. of Cycles | No. of Bytes | Object Code | No. of Cycles | No. of Bytes | Object Code | No. of Cycles | No. of Bytes | Object Code      | No. of Cycles | No. of Bytes | Object Code           | No. of Cycles | No. of Bytes |       |
| STU                       |             |               |              |                 |               |              | DF          | 5             | 2            | FF          | 6             | 3            | EF               | 5+            | 2+           |                       |               |              | 2     |
| STX                       |             |               |              |                 |               |              | 9F          | 5             | 2            | BF          | 6             | 3            | AF               | 5+            | 2+           |                       |               |              |       |
| STY                       |             |               |              |                 |               |              | 10 9F       | 6             | 3            | 10 BF       | 7             | 4            | 10 AF            | 6+            | 3+           |                       |               |              |       |
| SUBA                      |             |               |              |                 |               |              | 90          | 4             | 2            | BO          | 5             | 3            | A0               | 4+            | 2+           |                       |               |              |       |
| SUBB                      |             |               |              |                 |               |              | D0          | 4             | 2            | F0          | 5             | 3            | E0               | 4+            | 2+           |                       |               |              |       |
| SUBD                      |             |               |              |                 |               |              | 93          | 6             | 2            | B3          | 7             | 3            | A3               | 6+            | 2+           |                       |               |              |       |
| SWI                       | 3F          | 19            | 1            |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |       |
| SWI2                      | 10 3F       | 20            | 2            |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |       |
| SWI3                      | 11 3F       | 20            | 2            |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |       |
| SYNC                      | 13          | 2             | 1            |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |       |
| TFR                       |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |       |
| TST                       |             |               |              |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |       |
| TSTA                      | 4D          | 2             | 1            |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |       |
| TSTB                      | 5D          | 2             | 1            |                 |               |              |             |               |              |             |               |              |                  |               |              |                       |               |              |       |

Note 1: The cycle count in parentheses applies if the branch is taken.

Note 2: The immediate data in this instruction's object code is always an encoded register specification.  
See the description of this instruction in Chapter 22 for details.

Note 3: A PSH or PUL instruction requires 5 cycles plus one cycle for each byte pushed or pulled.

# D

## 6809 Instruction Object Codes in Numerical Order

The following symbols and abbreviations appear in this appendix:

|        |                                               |
|--------|-----------------------------------------------|
| adr8   | 8-bit address                                 |
| adr16  | 16-bit address                                |
| data8  | 8-bit data                                    |
| data16 | 16-bit data                                   |
| dd     | 8-bit data                                    |
| dd dd  | 16-bit data                                   |
| label  | The destination of a Jump or Branch           |
| mm     | 8-bit displacement in the object code         |
| mm nn  | 16-bit displacement in the object code        |
| pp     | post byte for indexed and indirect addressing |
| qq     | 8-bit address                                 |
| ssqq   | 16-bit address                                |

## D-2 6809 Instruction Object Codes

### 6809 Instruction Object Codes in Numerical Order

| Object Code <sup>1</sup> | Instruction <sup>2, 3</sup> | Addressing Mode    |
|--------------------------|-----------------------------|--------------------|
| 00 qq                    | NEG adr8                    | Base page (direct) |
| 03 qq                    | COM adr8                    | Base page (direct) |
| 04 qq                    | LSR adr8                    | Base page (direct) |
| 06 qq                    | ROR adr8                    | Base page (direct) |
| 07 qq                    | ASR adr8                    | Base page (direct) |
| 08 qq                    | ASL adr8 / LSL adr8         | Base page (direct) |
| 09 qq                    | ROL adr8                    | Base page (direct) |
| 0A qq                    | DEC adr8                    | Base page (direct) |
| 0C qq                    | INC adr8                    | Base page (direct) |
| 0D qq                    | TST adr8                    | Base page (direct) |
| 0E qq                    | JMP adr8                    | Base page (direct) |
| 0F qq                    | CLR adr8                    | Base page (direct) |
| 10 21 mm nn              | LBRN label                  | Relative           |
| 10 22 mm nn              | LBHI label                  | Relative           |
| 10 23 mm nn              | LBLS label                  | Relative           |
| 10 24 mm nn              | LBHS label / LBCC label     | Relative           |
| 10 25 mm nn              | LBLO label / LBCS label     | Relative           |
| 10 26 mm nn              | LBNE label                  | Relative           |
| 10 27 mm nn              | LBEQ label                  | Relative           |
| 10 28 mm nn              | LBVC label                  | Relative           |
| 10 29 mm nn              | LBVS label                  | Relative           |
| 10 2A mm nn              | LBPL label                  | Relative           |
| 10 2B mm nn              | LBMI label                  | Relative           |
| 10 2C mm nn              | LBGE label                  | Relative           |
| 10 2D mm nn              | LBLT label                  | Relative           |
| 10 2E mm nn              | LBGT label                  | Relative           |
| 10 2F mm nn              | LBLE label                  | Relative           |
| 10 3F                    | SWI2                        | Inherent           |
| 10 83 dd dd              | CMPD data16                 | Immediate          |
| 10 8C dd dd              | CMPY data16                 | Immediate          |
| 10 8E dd dd              | LDY data16                  | Immediate          |
| 10 93 qq                 | CMPD adr8                   | Base page (direct) |
| 10 9C qq                 | CMPY adr8                   | Base page (direct) |
| 10 9E qq                 | LDY adr8                    | Base page (direct) |
| 10 9F qq                 | STY adr8                    | Base page (direct) |
| 10 A3 pp <sup>1</sup>    | CMPD indexed forms          | Indexed / indirect |
| 10 AC pp <sup>1</sup>    | CMPY indexed forms          | Indexed / indirect |
| 10 AE pp <sup>1</sup>    | LDY indexed forms           | Indexed / indirect |
| 10 AF pp <sup>1</sup>    | STY indexed forms           | Indexed / indirect |
| 10 B3 ss qq              | CMPD adr16                  | Extended (direct)  |
| 10 BC ss qq              | CMPY adr16                  | Extended (direct)  |
| 10 BE ss qq              | LDY adr16                   | Extended (direct)  |
| 10 BF ss qq              | STY adr16                   | Extended (direct)  |
| 10 CE dd dd              | LDS data16                  | Immediate          |

**Note 1.** The post byte may be followed by two bytes, one byte, or no byte. See Appendix B and the discussion of the post byte in Chapter 3 for more details. Appendix E lists all possible post bytes and the operand forms that produce them.

**Note 2.** Some instructions have two mnemonics. In each such case, we show both forms, separated by a slash (/).

**Note 3.** Appendix B displays the "indexed forms" for operands in the indexed and indirect addressing modes.

**Note 4.** In the instructions EXG and TFR, the processor interprets the second byte (the immediate data) as designating the source and destination registers.

**Note 5.** In the instructions PSHS, PULS, PSHU, and PULU, the processor interprets the second byte (the immediate data) as designating which registers are to be included in the transfer of data to or from the stack.

## 6809 Instruction Object Codes in Numerical Order (Continued)

| Object Code <sup>1</sup> | Instruction <sup>2, 3</sup> | Addressing Mode       |
|--------------------------|-----------------------------|-----------------------|
| 10 DE qq                 | LDS adr8                    | Base page (direct)    |
| 10 DF qq                 | STS adr8                    | Base page (direct)    |
| 10 EE pp <sup>1</sup>    | LDS indexed forms           | Indexed / indirect    |
| 10 EF pp <sup>1</sup>    | STS indexed forms           | Indexed / indirect    |
| 10 FE ss qq              | LDS adr16                   | Extended (direct)     |
| 10 FF ss qq              | STS adr16                   | Extended (direct)     |
| 11 3F                    | SWI3                        | Inherent              |
| 11 83 dd dd              | CMPU data16                 | Immediate             |
| 11 8C dd dd              | CMPS data16                 | Immediate             |
| 11 93 qq                 | CMPU adr8                   | Base page (direct)    |
| 11 9C qq                 | CMPS adr8                   | Base page (direct)    |
| 11 A3 pp <sup>1</sup>    | CMPU indexed forms          | Indexed / indirect    |
| 11 AC pp <sup>1</sup>    | CMPS indexed forms          | Indexed / indirect    |
| 11 B3 ss qq              | CMPU adr16                  | Extended (direct)     |
| 11 BC ss qq              | CMPS adr16                  | Extended (direct)     |
| 12                       | NOP                         | Inherent              |
| 13                       | SYNC                        | Inherent              |
| 16 mm nn                 | LBRA label                  | Relative              |
| 17 mm nn                 | LBSR label                  | Relative              |
| 19                       | DAA                         | Inherent              |
| 1A dd                    | ORCC data8                  | Immediate             |
| 1C dd                    | ANDCC data8                 | Immediate             |
| 1D                       | SEX                         | Inherent              |
| 1E dd                    | EXG data8                   | Register <sup>4</sup> |
| 1F dd                    | TFR data8                   | Register <sup>4</sup> |
| 20 mm                    | BRA label                   | Relative              |
| 21 mm                    | BRN label                   | Relative              |
| 22 mm                    | BHI label                   | Relative              |
| 23 mm                    | BLS label                   | Relative              |
| 24 mm                    | BCC label / BHS label       | Relative              |
| 25 mm                    | BCS label / BLO label       | Relative              |
| 26 mm                    | BNE label                   | Relative              |
| 27 mm                    | BEQ label                   | Relative              |
| 28 mm                    | BVC label                   | Relative              |
| 29 mm                    | BVS label                   | Relative              |
| 2A mm                    | BPL label                   | Relative              |
| 2B mm                    | BMI label                   | Relative              |
| 2C mm                    | BGE label                   | Relative              |
| 2D mm                    | BLT label                   | Relative              |
| 2E mm                    | BGT label                   | Relative              |
| 2F mm                    | BLE label                   | Relative              |
| 30 pp <sup>1</sup>       | LEAX indexed forms          | Indexed / indirect    |
| 31 pp <sup>1</sup>       | LEAY indexed forms          | Indexed / indirect    |
| 32 pp <sup>1</sup>       | LEAS indexed forms          | Indexed / indirect    |
| 33 pp <sup>1</sup>       | LEAU indexed forms          | Indexed / indirect    |
| 34 dd                    | PSHS data8                  | Register <sup>5</sup> |
| 35 dd                    | PULS data8                  | Register <sup>5</sup> |
| 36 dd                    | PSHU data8                  | Register <sup>5</sup> |
| 37 dd                    | PULU data8                  | Register <sup>5</sup> |
| 39                       | RTS                         | Inherent (Stack)      |
| 3A                       | ABX                         | Inherent              |
| 3B                       | RTI                         | Inherent (Stack)      |
| 3C dd                    | CWAI data8                  | Immediate             |
| 3D                       | MUL                         | Inherent              |
| 3F                       | SWI                         | Inherent              |
| 40                       | NEGA                        | Accumulator           |
| 43                       | COMA                        | Accumulator           |
| 44                       | LSRA                        | Accumulator           |
| 46                       | RORA                        | Accumulator           |

## D-4 6809 Instruction Object Codes

6809 Instruction Object Codes in Numerical Order (Continued)

| Object Code <sup>1</sup> | Instruction <sup>2, 3</sup> | Addressing Mode    |
|--------------------------|-----------------------------|--------------------|
| 47                       | ASRA                        | Accumulator        |
| 48                       | ASLA / LSLA                 | Accumulator        |
| 49                       | ROLA                        | Accumulator        |
| 4A                       | DECA                        | Accumulator        |
| 4C                       | INCA                        | Accumulator        |
| 4D                       | TSTA                        | Accumulator        |
| 4F                       | CLRA                        | Accumulator        |
| 50                       | NEGB                        | Accumulator        |
| 53                       | COMB                        | Accumulator        |
| 54                       | LSRB                        | Accumulator        |
| 56                       | RORB                        | Accumulator        |
| 57                       | ASRB                        | Accumulator        |
| 58                       | ASLB / LSLB                 | Accumulator        |
| 59                       | ROLB                        | Accumulator        |
| 5A                       | DEC8                        | Accumulator        |
| 5C                       | INC8                        | Accumulator        |
| 5D                       | TSTB                        | Accumulator        |
| 5F                       | CLRB                        | Accumulator        |
| 60 pp <sup>1</sup>       | NEG indexed forms           | Indexed / indirect |
| 63 pp <sup>1</sup>       | COM indexed forms           | Indexed / indirect |
| 64 pp <sup>1</sup>       | LSR indexed forms           | Indexed / indirect |
| 66 pp <sup>1</sup>       | ROR indexed forms           | Indexed / indirect |
| 67 pp <sup>1</sup>       | ASR indexed forms           | Indexed / indirect |
| 68 pp <sup>1</sup>       | ASL / LSL indexed forms     | Indexed / indirect |
| 69 pp <sup>1</sup>       | ROL indexed forms           | Indexed / indirect |
| 6A pp <sup>1</sup>       | DEC indexed forms           | Indexed / indirect |
| 6C pp <sup>1</sup>       | INC indexed forms           | Indexed / indirect |
| 6D pp <sup>1</sup>       | TST indexed forms           | Indexed / indirect |
| 6E pp <sup>1</sup>       | JMP indexed forms           | Indexed / indirect |
| 6F pp <sup>1</sup>       | CLR indexed forms           | Indexed / indirect |
| 70 ss qq                 | NEG adr16                   | Extended (direct)  |
| 73 ss qq                 | COM adr16                   | Extended (direct)  |
| 74 ss qq                 | LSR adr16                   | Extended (direct)  |
| 76 ss qq                 | ROR adr16                   | Extended (direct)  |
| 77 ss qq                 | ASR adr16                   | Extended (direct)  |
| 78 ss qq                 | ASL adr16 / LSL adr16       | Extended (direct)  |
| 79 ss qq                 | ROL adr16                   | Extended (direct)  |
| 7A ss qq                 | DEC adr16                   | Extended (direct)  |
| 7C ss qq                 | INC adr16                   | Extended (direct)  |
| 7D ss qq                 | TST adr16                   | Extended (direct)  |
| 7E ss qq                 | JMP adr16                   | Extended (direct)  |
| 7F ss qq                 | CLR adr16                   | Extended (direct)  |
| 80 dd                    | SUBA data8                  | Immediate          |
| 81 dd                    | CMPA data8                  | Immediate          |
| 82 dd                    | SBCA data8                  | Immediate          |
| 83 dd dd                 | SUBD data16                 | Immediate          |
| 84 dd                    | ANDA data8                  | Immediate          |
| 85 dd                    | BITA data8                  | Immediate          |
| 86 dd                    | LDA data8                   | Immediate          |
| 88 dd                    | EORA data8                  | Immediate          |
| 89 dd                    | ADCA data8                  | Immediate          |
| 8A dd                    | ORA data8                   | Immediate          |
| 8B dd                    | ADDA data8                  | Immediate          |
| 8C dd dd                 | CMPX data16                 | Immediate          |
| 8D mm                    | BSR label                   | Relative           |
| 8E dd dd                 | LDX data16                  | Immediate          |
| 90 qq                    | SUBA adr8                   | Base page (direct) |
| 91 qq                    | CMPA adr8                   | Base page (direct) |
| 92 qq                    | SBCA adr8                   | Base page (direct) |
| 93 qq                    | SUBD adr8                   | Base page (direct) |

## 6809 Instruction Object Codes in Numerical Order (Continued)

| Object Code <sup>1</sup> | Instruction <sup>2, 3</sup> | Addressing Mode    |
|--------------------------|-----------------------------|--------------------|
| 94 qq                    | ANDA adr8                   | Base page (direct) |
| 95 qq                    | BITA adr8                   | Base page (direct) |
| 96 qq                    | LDA adr8                    | Base page (direct) |
| 97 qq                    | STA adr8                    | Base page (direct) |
| 98 qq                    | EORA adr8                   | Base page (direct) |
| 99 qq                    | ADCA adr8                   | Base page (direct) |
| 9A qq                    | ORA adr8                    | Base page (direct) |
| 9B qq                    | ADDA adr8                   | Base page (direct) |
| 9C qq                    | CMPX adr8                   | Base page (direct) |
| 9D qq                    | JSR adr8                    | Base page (direct) |
| 9E qq                    | LDX adr8                    | Base page (direct) |
| 9F qq                    | STX adr8                    | Base page (direct) |
| A0 pp <sup>1</sup>       | SUBA indexed forms          | Indexed / indirect |
| A1 pp <sup>1</sup>       | CMPA indexed forms          | Indexed / indirect |
| A2 pp <sup>1</sup>       | SBCA indexed forms          | Indexed / indirect |
| A3 pp <sup>1</sup>       | SUBD indexed forms          | Indexed / indirect |
| A4 pp <sup>1</sup>       | ANDA indexed forms          | Indexed / indirect |
| A5 pp <sup>1</sup>       | BITA indexed forms          | Indexed / indirect |
| A6 pp <sup>1</sup>       | LDA indexed forms           | Indexed / indirect |
| A7 pp <sup>1</sup>       | STA indexed forms           | Indexed / indirect |
| A8 pp <sup>1</sup>       | EORA indexed forms          | Indexed / indirect |
| A9 pp <sup>1</sup>       | ADCA indexed forms          | Indexed / indirect |
| AA pp <sup>1</sup>       | ORA indexed forms           | Indexed / indirect |
| AB pp <sup>1</sup>       | ADDA indexed forms          | Indexed / indirect |
| AC pp <sup>1</sup>       | CMPX indexed forms          | Indexed / indirect |
| AD pp <sup>1</sup>       | JSR indexed forms           | Indexed / indirect |
| AE pp <sup>1</sup>       | LDX indexed forms           | Indexed / indirect |
| AF pp <sup>1</sup>       | STX indexed forms           | Indexed / indirect |
| B0 ss qq                 | SUBA adr16                  | Extended (direct)  |
| B1 ss qq                 | CMPA adr16                  | Extended (direct)  |
| B2 ss qq                 | SBCA adr16                  | Extended (direct)  |
| B3 ss qq                 | SUBD adr16                  | Extended (direct)  |
| B4 ss qq                 | ANDA adr16                  | Extended (direct)  |
| B5 ss qq                 | BITA adr16                  | Extended (direct)  |
| B6 ss qq                 | LDA adr16                   | Extended (direct)  |
| B7 ss qq                 | STA adr16                   | Extended (direct)  |
| B8 ss qq                 | EORA adr16                  | Extended (direct)  |
| B9 ss qq                 | ADCA adr16                  | Extended (direct)  |
| BA ss qq                 | ORA adr16                   | Extended (direct)  |
| BB ss qq                 | ADDA adr16                  | Extended (direct)  |
| BC ss qq                 | CMPX adr16                  | Extended (direct)  |
| BD ss qq                 | JSR adr16                   | Extended (direct)  |
| BE ss qq                 | LDX adr16                   | Extended (direct)  |
| BF ss qq                 | STX adr16                   | Extended (direct)  |
| C0 dd                    | SUBB data8                  | Immediate          |
| C1 dd                    | CMPB data8                  | Immediate          |
| C2 dd                    | SBCB data8                  | Immediate          |
| C3 dd dd                 | ADDD data16                 | Immediate          |
| C4 dd                    | ANDB data8                  | Immediate          |
| C5 dd                    | BITB data8                  | Immediate          |
| C6 dd                    | LDB data8                   | Immediate          |
| C8 dd                    | EORB data8                  | Immediate          |
| C9 dd                    | ADCB data8                  | Immediate          |
| CA dd                    | ORB data8                   | Immediate          |
| CB dd                    | ADDB data8                  | Immediate          |
| CC dd dd                 | LDL data16                  | Immediate          |
| CE dd dd                 | LDU data16                  | Immediate          |
| D0 qq                    | SUBB adr8                   | Base page (direct) |
| D1 qq                    | CMPB adr8                   | Base page (direct) |

## D-6 6809 Instruction Object Codes

6809 Instruction Object Codes in Numerical Order (Continued)

| Object Code <sup>1</sup> | Instruction <sup>2, 3</sup> | Addressing Mode    |
|--------------------------|-----------------------------|--------------------|
| D2 qq                    | SBCB adr8                   | Base page (direct) |
| D3 qq                    | ADDB adr8                   | Base page (direct) |
| D4 qq                    | ANDB adr8                   | Base page (direct) |
| D5 qq                    | BITB adr8                   | Base page (direct) |
| D6 qq                    | LDB adr8                    | Base page (direct) |
| D7 qq                    | STB adr8                    | Base page (direct) |
| D8 qq                    | EORB adr8                   | Base page (direct) |
| D9 qq                    | ADCB adr8                   | Base page (direct) |
| DA qq                    | ORB adr8                    | Base page (direct) |
| DB qq                    | ADDB adr8                   | Base page (direct) |
| DC qq                    | LDD adr8                    | Base page (direct) |
| DD qq                    | STD adr8                    | Base page (direct) |
| DE qq                    | LDU adr8                    | Base page (direct) |
| DF qq                    | STU adr8                    | Base page (direct) |
| E0 pp <sup>1</sup>       | SUBB indexed forms          | Indexed / indirect |
| E1 pp <sup>1</sup>       | CMPB indexed forms          | Indexed / indirect |
| E2 pp <sup>1</sup>       | SBCB indexed forms          | Indexed / indirect |
| E3 pp <sup>1</sup>       | ADDB indexed forms          | Indexed / indirect |
| E4 pp <sup>1</sup>       | ANDB indexed forms          | Indexed / indirect |
| E5 pp <sup>1</sup>       | BITB indexed forms          | Indexed / indirect |
| E6 pp <sup>1</sup>       | LDB indexed forms           | Indexed / indirect |
| E7 pp <sup>1</sup>       | STB indexed forms           | Indexed / indirect |
| E8 pp <sup>1</sup>       | EORB indexed forms          | Indexed / indirect |
| E9 pp <sup>1</sup>       | ADCB indexed forms          | Indexed / indirect |
| EA pp <sup>1</sup>       | ORB indexed forms           | Indexed / indirect |
| EB pp <sup>1</sup>       | ADDB indexed forms          | Indexed / indirect |
| EC pp <sup>1</sup>       | LDD indexed forms           | Indexed / indirect |
| ED pp <sup>1</sup>       | STD indexed forms           | Indexed / indirect |
| EE pp <sup>1</sup>       | LDU indexed forms           | Indexed / indirect |
| EF pp <sup>1</sup>       | STU indexed forms           | Indexed / indirect |
| F0 ss qq                 | SUBB adr16                  | Extended (direct)  |
| F1 ss qq                 | CMPB adr16                  | Extended (direct)  |
| F2 ss qq                 | SBCB adr16                  | Extended (direct)  |
| F3 ss qq                 | ADDB adr16                  | Extended (direct)  |
| F4 ss qq                 | ANDB adr16                  | Extended (direct)  |
| F5 ss qq                 | BITB adr16                  | Extended (direct)  |
| F6 ss qq                 | LDB adr16                   | Extended (direct)  |
| F7 ss qq                 | STB adr16                   | Extended (direct)  |
| F8 ss qq                 | EORB adr16                  | Extended (direct)  |
| F9 ss qq                 | ADCB adr16                  | Extended (direct)  |
| FA ss qq                 | ORB adr16                   | Extended (direct)  |
| FB ss qq                 | ADDB adr16                  | Extended (direct)  |
| FC ss qq                 | LDD adr16                   | Extended (direct)  |
| FD ss qq                 | STD adr16                   | Extended (direct)  |
| FE ss qq                 | LDU adr16                   | Extended (direct)  |
| FF ss qq                 | STU adr16                   | Extended (direct)  |

E

# 6809 Post Bytes in Numerical Order

| Post Byte | Operand Form <sup>1</sup> |
|-----------|---------------------------|-----------|---------------------------|-----------|---------------------------|-----------|---------------------------|
| 00        | 0,X                       | 37        | -9,Y                      | 6E        | 14,S                      | B4        | [,Y]                      |
| 01        | 1,X                       | 38        | -8,Y                      | 6F        | 15,S                      | B5        | [B,Y]                     |
| 02        | 2,X                       | 39        | -7,Y                      | 70        | -16,S                     | B6        | [A,Y]                     |
| 03        | 3,X                       | 3A        | -6,Y                      | 71        | -15,S                     | B8        | [nn,Y]                    |
| 04        | 4,X                       | 3B        | -5,Y                      | 72        | -14,S                     | B9        | [mmnn,Y]                  |
| 05        | 5,X                       | 3C        | -4,Y                      | 73        | -13,S                     | BB        | [D,Y]                     |
| 06        | 6,X                       | 3D        | -3,Y                      | 74        | -12,S                     | BC        | [nn,PC] <sup>3</sup>      |
| 07        | 7,X                       | 3E        | -2,Y                      | 75        | -11,S                     | BD        | [mmnn,PC] <sup>3</sup>    |
| 08        | 8,X                       | 3F        | -1,Y                      | 76        | -10,S                     | BF        | [mmmn]                    |
| 09        | 9,X                       | 40        | 0,U                       | 77        | -9,S                      | C0        | .U+                       |
| 0A        | 10,X                      | 41        | 1,U                       | 78        | -8,S                      | C1        | .U++                      |
| 0B        | 11,X                      | 42        | 2,U                       | 79        | -7,S                      | C2        | .-U                       |
| 0C        | 12,X                      | 43        | 3,U                       | 7A        | -6,S                      | C3        | .--U                      |
| 0D        | 13,X                      | 44        | 4,U                       | 7B        | -5,S                      | C4        | .U                        |
| 0E        | 14,X                      | 45        | 5,U                       | 7C        | -4,S                      | C5        | B,U                       |
| 0F        | 15,X                      | 46        | 6,U                       | 7D        | -3,S                      | C6        | A,U                       |
| 10        | -16,X                     | 47        | 7,U                       | 7E        | -2,S                      | C8        | nn,U                      |
| 11        | -15,X                     | 48        | 8,U                       | 7F        | -1,S                      | C9        | mmmn,U                    |
| 12        | -14,X                     | 49        | 9,U                       | 80        | .X+                       | CB        | D,U                       |
| 13        | -13,X                     | 4A        | 10,U                      | 81        | .X++                      | CC        | nn,PC <sup>2</sup>        |
| 14        | -12,X                     | 4B        | 11,U                      | 82        | .-X                       | CD        | mmmn,PC <sup>2</sup>      |
| 15        | -11,X                     | 4C        | 12,U                      | 83        | .--X                      | D1        | [.U++]                    |
| 16        | -10,X                     | 4D        | 13,U                      | 84        | .X                        | D3        | [.---U]                   |
| 17        | -9,X                      | 4E        | 14,U                      | 85        | B,X                       | D4        | [.U]                      |
| 18        | -8,X                      | 4F        | 15,U                      | 86        | A,X                       | D5        | [B,U]                     |
| 19        | -7,X                      | 50        | -16,U                     | 88        | nn,X                      | D6        | [A,U]                     |
| 1A        | -6,X                      | 51        | -15,U                     | 89        | mmnn,X                    | D8        | [nn,U]                    |
| 1B        | -5,X                      | 52        | -14,U                     | 8B        | D,X                       | D9        | [mmnn,U]                  |
| 1C        | -4,X                      | 53        | -13,U                     | 8C        | nn,PC <sup>2</sup>        | DB        | [D,U]                     |
| 1D        | -3,X                      | 54        | -12,U                     | 8D        | mmmn,PC <sup>2</sup>      | DC        | [nn,PC] <sup>3</sup>      |
| 1E        | -2,X                      | 55        | -11,U                     | 91        | [.X++]                    | DD        | [mmnn,PC] <sup>3</sup>    |
| 1F        | -1,X                      | 56        | -10,U                     | 93        | [.---X]                   | DF        | [mmnn]                    |
| 20        | 0,Y                       | 57        | -9,U                      | 94        | [.X]                      | EO        | .S+                       |
| 21        | 1,Y                       | 58        | -8,U                      | 95        | [B,X]                     | E1        | .S++                      |
| 22        | 2,Y                       | 59        | -7,U                      | 96        | [A,X]                     | E2        | .-S                       |
| 23        | 3,Y                       | 5A        | -6,U                      | 98        | [nn,X]                    | E3        | .--S                      |
| 24        | 4,Y                       | 5B        | -5,U                      | 99        | [mmmn,X]                  | E4        | .S                        |
| 25        | 5,Y                       | 5C        | -4,U                      | 9B        | [D,X]                     | E5        | B,S                       |
| 26        | 6,Y                       | 5D        | -3,U                      | 9C        | [nn,PC] <sup>3</sup>      | E6        | A,S                       |
| 27        | 7,Y                       | 5E        | -2,U                      | 9D        | [mmnn,PC] <sup>3</sup>    | E8        | nn,S                      |
| 28        | 8,Y                       | 5F        | -1,U                      | 9F        | [mmnn]                    | E9        | mmnn,S                    |
| 29        | 9,Y                       | 60        | 0,S                       | A0        | .Y+                       | EB        | D,S                       |
| 2A        | 10,Y                      | 61        | 1,S                       | A1        | .Y++                      | EC        | nn,PC <sup>2</sup>        |
| 2B        | 11,Y                      | 62        | 2,S                       | A2        | .-Y                       | ED        | mmmn,PC <sup>2</sup>      |
| 2C        | 12,Y                      | 63        | 3,S                       | A3        | .--Y                      | F1        | [.S++]                    |
| 2D        | 13,Y                      | 64        | 4,S                       | A4        | .Y                        | F3        | [.---S]                   |
| 2E        | 14,Y                      | 65        | 5,S                       | A5        | B,Y                       | F4        | [.S]                      |
| 2F        | 15,Y                      | 66        | 6,S                       | A6        | A,Y                       | F5        | [B,S]                     |
| 30        | -16,Y                     | 67        | 7,S                       | A8        | nn,Y                      | F6        | [A,S]                     |
| 31        | -15,Y                     | 68        | 8,S                       | A9        | mmnn,Y                    | F8        | [nn,S]                    |
| 32        | -14,Y                     | 69        | 9,S                       | AB        | D,Y                       | F9        | [mmnn,S]                  |
| 33        | -13,Y                     | 6A        | 10,S                      | AC        | nn,PC <sup>2</sup>        | FB        | [D,S]                     |
| 34        | -12,Y                     | 6B        | 11,S                      | AD        | mmnn,PC <sup>2</sup>      | FC        | [nn,PC] <sup>3</sup>      |
| 35        | -11,Y                     | 6C        | 12,S                      | B1        | [.Y++]                    | FD        | [mmnn,PC] <sup>3</sup>    |
| 36        | -10,Y                     | 6D        | 13,S                      | B3        | [.---Y]                   | FF        | [mmnn]                    |

Note 1: See Appendix B for addressing modes which the operand forms represent.

Note 2: May appear in source listing in the form label,PCR.

Note 3: May appear in source listing in the form [label,PCR].