

## 6502 INSTRUCTION SET

Instructions often frighten microcomputer users who are new to programming. Taken in isolation, the operations involved in the execution of a single instruction are usually easy to follow. The purpose of this chapter is to isolate and explain those operations.

Why are the instructions of a microcomputer referred to as an instruction "set"? Because the microcomputer designer selects (or at least should select) the instructions with great care; it must be easy to execute complex operations as a sequence of simple events, each of which is represented by one instruction from a well-designed instruction "set".

**Remaining consistent with An Introduction to Microcomputers: Volume 2, Table 3-4 summarizes the 6502 microcomputer instruction set, with similar instructions grouped together. Individual instructions are listed numerically by object code in Table 3-5 and in alphabetical order by instruction mnemonic in Table 3-6.** Table 3-6 also compares the 6800 instruction set with that of the 6502. We will discuss the 6800 and 6502 much later in this chapter, after detailing the 6502 instruction set.

In addition to simply stating what each instruction does, the individual instruction descriptions discuss the purpose of the instruction within normal programming logic.

### ABBREVIATIONS

**These are the abbreviations used in this chapter:**

The registers:

|    |                                                 |
|----|-------------------------------------------------|
| A  | Accumulator                                     |
| X  | Index Register X                                |
| Y  | Index Register Y                                |
| PC | Program Counter                                 |
| SP | Stack Pointer                                   |
| P  | Status register, with bits assigned as follows: |



Statuses:

|   |                          |
|---|--------------------------|
| S | Sign or Negative status  |
| V | Overflow status          |
| B | Break status             |
| D | Decimal Mode status      |
| I | Interrupt Disable status |
| Z | Zero status              |
| C | Carry status             |

Symbols in the column labeled STATUS:

|               |                                                                                                                                                                                                                                                                                                                                                                                    |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| (blank)       | Operation does not affect status                                                                                                                                                                                                                                                                                                                                                   |
| X             | Operation affects status                                                                                                                                                                                                                                                                                                                                                           |
| 0             | Operation clears status                                                                                                                                                                                                                                                                                                                                                            |
| 1             | Operation sets status                                                                                                                                                                                                                                                                                                                                                              |
| 6             | Operation reflects bit 6 of memory location                                                                                                                                                                                                                                                                                                                                        |
| 7             | Operation reflects bit 7 of memory location                                                                                                                                                                                                                                                                                                                                        |
| addr          | 8 bits of absolute or base address                                                                                                                                                                                                                                                                                                                                                 |
| [addr+1,addr] | The address constructed from the contents of memory locations addr and addr+1. This address is used in post-indexed indirect addressing.                                                                                                                                                                                                                                           |
| addr16        | 16 bits of absolute or base address                                                                                                                                                                                                                                                                                                                                                |
| data          | 8 bits of immediate data                                                                                                                                                                                                                                                                                                                                                           |
| disp          | An 8-bit, signed address displacement                                                                                                                                                                                                                                                                                                                                              |
| label         | 16-bit absolute address, destination of Jump or Jump-to-Subroutine                                                                                                                                                                                                                                                                                                                 |
| PC(HI)        | The high-order 8 bits of the Program Counter                                                                                                                                                                                                                                                                                                                                       |
| PC(LO)        | The low-order 8 bits of the Program Counter                                                                                                                                                                                                                                                                                                                                        |
| pp            | The second byte of a two- or three-byte instruction object code                                                                                                                                                                                                                                                                                                                    |
| qq            | The third byte of a three-byte object code                                                                                                                                                                                                                                                                                                                                         |
| [ ]           | Contents of the memory location designated inside the brackets. For example, [FFE] represents the contents of memory location FFE <sub>16</sub> ; [addr16+X] represents the contents of the location addressed by adding the contents of register X to addr16; [SP] represents the value at the top of the Stack (contents of the memory location addressed by the Stack Pointer). |
| [[ ]]         | Indirect addressing: the contents of the memory byte addressed by the contents of the memory location designated within the inner brackets. For example, [[addr+X]] represents the contents of a memory location addressed via pre-indexed indirect addressing.                                                                                                                    |
| +             | Addition — either unsigned binary addition or BCD addition, depending on the condition of the Decimal Mode status.                                                                                                                                                                                                                                                                 |
| -             | Binary or BCD subtraction, performed by adding the twos complement of the subtrahend to the minuend.                                                                                                                                                                                                                                                                               |
| —             | The ones complement of the quantity denoted beneath the bar; for example, $\bar{A}$ represents the complement of the contents of the Accumulator; $\bar{C}$ represents the complement of the value of the Carry status.                                                                                                                                                            |
| Λ             | Logical AND                                                                                                                                                                                                                                                                                                                                                                        |
| ∨             | Logical OR                                                                                                                                                                                                                                                                                                                                                                         |
| ⊻             | Logical Exclusive-OR                                                                                                                                                                                                                                                                                                                                                               |
| →             | Data is transferred in the direction of the arrow.                                                                                                                                                                                                                                                                                                                                 |

## INSTRUCTION MNEMONICS

Table 3-4 summarizes the 6502 instruction set. The INSTRUCTION column shows the instruction mnemonic (LDA, STA, CLC) and the operands, if any, used with the instruction mnemonic.

The fixed part of an assembly language instruction is shown in UPPER CASE. The variable part (immediate data, address, or label) is shown in lower case.

If a mnemonic has more than one type of operand, each type is listed separately without repeating the mnemonic. For instance, some examples of the format entry

STX

addr

addr,Y

addr16

are:

STX \$75

STX \$60,Y

STX \$4276

## INSTRUCTION OBJECT CODES

For instruction bytes without variations, object codes are represented as two hexadecimal digits (e.g., 8A). For instruction bytes with variations, the object code is shown as eight binary digits (e.g., 101aaa01).

The object code and instruction length in bytes is shown in Table 3-4 for each instruction variation. Table 3-5 lists the object codes in numerical order, and Table 3-6 shows the corresponding object codes for the mnemonics, listed in alphabetical order.

## INSTRUCTION EXECUTION TIMES

Table 3-4 lists the instruction execution times in numbers of clock periods. Actual execution time can be derived by dividing the given number of clock periods by the clock speed. For example, for an instruction that requires 5 clock periods, a 2 MHz clock will result in a 2.5 microsecond execution time.

## STATUS

The status flags are stored in the Status register (P) as follows:



In the individual instruction descriptions, the effect of instruction execution on status is illustrated as follows:



An X identifies a status that is set or reset. A 0 identifies a status that is always cleared. A 1 identifies a status that is always set. A blank means the status does not change. The numbers 7 and 6 show that the flag contains the value of bit 7 or bit 6 of the byte tested by the instruction.

**STATUS CHANGES  
WITH INSTRUCTION  
EXECUTION**

Table 3-4. A Summary of the 6502 Instruction Set

| Type                             | Instruction   | Object Code   | Bytes | Clock Periods | Status |   |   |   |   | Operation Performed                                               |
|----------------------------------|---------------|---------------|-------|---------------|--------|---|---|---|---|-------------------------------------------------------------------|
|                                  |               |               |       |               | S      | V | D | I | Z |                                                                   |
| I/O and Primary Memory Reference | LDA           |               |       |               |        |   |   |   |   | Load Accumulator from memory.                                     |
|                                  | addr          | A5 pp         | 2     | 3             | X      |   |   |   | X | A $\leftarrow$ [addr]                                             |
|                                  | addr,X        | B5 pp         | 2     | 4             | X      |   |   |   | X | A $\leftarrow$ [addr+X]                                           |
|                                  | (addr,X)      | A1 pp         | 2     | 6             | X      |   |   |   | X | A $\leftarrow$ [[addr+X]]                                         |
|                                  | (addr,Y)      | B1 pp         | 2     | 5*            | X      |   |   |   | X | A $\leftarrow$ [[addr+1,addr]+Y]                                  |
|                                  | addr16        | AD ppqq       | 3     | 4             | X      |   |   |   | X | A $\leftarrow$ [addr16]                                           |
|                                  | addr16,X or Y | 11011x01 ppqq | 3     | 4*            | X      |   |   |   | X | A $\leftarrow$ [addr16+X] or A $\leftarrow$ [addr16+Y]            |
|                                  | STA           |               |       |               |        |   |   |   |   | Store Accumulator to memory.                                      |
|                                  | addr          | 85 pp         | 2     | 3             |        |   |   |   |   | [addr] $\leftarrow$ A                                             |
|                                  | addr,X        | 95 pp         | 2     | 4             |        |   |   |   |   | [addr+X] $\leftarrow$ A                                           |
| Index Register Reference         | (addr,X)      | 81 pp         | 2     | 6             |        |   |   |   |   | [[addr+X]] $\leftarrow$ A                                         |
|                                  | (addr,Y)      | 91 pp         | 2     | 6             |        |   |   |   |   | [[addr+1,addr]+Y] $\leftarrow$ A                                  |
|                                  | addr16        | 8D ppqq       | 3     | 4             |        |   |   |   |   | [addr16] $\leftarrow$ A                                           |
|                                  | addr16,X or Y | 10011x01 ppqq | 3     | 5             |        |   |   |   |   | [addr16+X] $\leftarrow$ A or [addr16+Y] $\leftarrow$ A            |
|                                  | LDX           |               |       |               |        |   |   |   |   | Load Index Register X from memory. Index through Register Y only. |
|                                  | addr          | A6 pp         | 2     | 3             | X      |   |   |   | X | X $\leftarrow$ [addr]                                             |
|                                  | addr,Y        | B6 pp         | 2     | 4             | X      |   |   |   | X | X $\leftarrow$ [addr+Y]                                           |
|                                  | addr16        | AE ppqq       | 3     | 4             | X      |   |   |   | X | X $\leftarrow$ [addr16]                                           |
|                                  | addr16,Y      | BE ppqq       | 3     | 4*            | X      |   |   |   | X | X $\leftarrow$ [addr16+Y]                                         |
| Accumulator Reference            | STX           |               |       |               |        |   |   |   |   | Store Index Register X to memory. Index through Register Y only.  |
|                                  | addr          | 86 pp         | 2     | 3             |        |   |   |   |   | [addr] $\leftarrow$ X                                             |
|                                  | addr,Y        | 96 pp         | 2     | 4             |        |   |   |   |   | [addr+Y] $\leftarrow$ X                                           |
|                                  | addr16        | 8E ppqq       | 3     | 4             |        |   |   |   |   | [addr16] $\leftarrow$ X                                           |
| Index Register Reference         | LDY           |               |       |               |        |   |   |   |   | Load Index Register Y from memory. Index through Register X only. |
|                                  | addr          | A4 pp         | 2     | 3             | X      |   |   |   | X | Y $\leftarrow$ [addr]                                             |
|                                  | addr,X        | B4 pp         | 2     | 4             | X      |   |   |   | X | Y $\leftarrow$ [addr+X]                                           |
|                                  | addr16        | AC ppqq       | 3     | 4             | X      |   |   |   | X | Y $\leftarrow$ [addr16]                                           |
|                                  | addr16,X      | BC ppqq       | 3     | 4             | X      |   |   |   | X | Y $\leftarrow$ [addr16+X]                                         |

\* Add one clock period if page boundary is crossed. In the object code, "x" designates the index register: x = 0 for Register Y, x = 1 for Register X.

Table 3-4. A Summary of the 6502 Instruction Set (Continued)

| Type                                         | Instruction                                                              | Object Code                                                  | Bytes                      | Clock Periods                | Status                                 |        |   |                                        |                                                                                                                                                                                                                                                                                                                                                                               |   | Operation Performed                                                                                                                                         |
|----------------------------------------------|--------------------------------------------------------------------------|--------------------------------------------------------------|----------------------------|------------------------------|----------------------------------------|--------|---|----------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|-------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                              |                                                                          |                                                              |                            |                              | S                                      | V      | D | I                                      | Z                                                                                                                                                                                                                                                                                                                                                                             | C |                                                                                                                                                             |
| I/O and Primary Memory Reference (Continued) | STY<br>addr<br>addr,X<br>addr16                                          | 84 pp<br>94 pp<br>8C ppqq                                    | 2<br>2<br>3                | 3<br>4<br>4                  |                                        |        |   |                                        |                                                                                                                                                                                                                                                                                                                                                                               |   | Store Index Register Y to memory. Index through Register X only.<br>[addr]—Y Zero page direct<br>[addr+X]—Y Zero page indexed<br>[addr16]—Y Extended direct |
| Secondary Memory Reference (Memory Operate)  | ADC<br>addr<br>addr,X<br>(addr,X)<br>(addr),Y<br>addr16<br>addr16,X or Y | 65 pp<br>75 pp<br>61 pp<br>71 pp<br>6D ppqq<br>01111x01 ppqq | 2<br>2<br>2<br>2<br>3<br>3 | 3<br>4<br>6<br>5*<br>4<br>4* | X X<br>X X<br>X X<br>X X<br>X X<br>X X |        |   | X X<br>X X<br>X X<br>X X<br>X X<br>X X | Add contents of memory location, with carry, to those of Accumulator.<br>A—A+[addr]+C Zero page direct<br>A—A+[addr+X]+C Zero page indexed<br>A—A+[(addr+X)]+C Pre-indexed indirect<br>A—A+[(addr+1, addr)+Y]+C Post-indexed indirect<br>A—A+[addr16]+C Extended direct<br>A—A+[addr16+X]+C or A—A+[addr16+Y]+C Absolute indexed<br>(Zero flag is not valid in Decimal Mode). |   |                                                                                                                                                             |
|                                              | AND<br>addr<br>addr,X<br>(addr,X)<br>(addr),Y<br>addr16<br>addr16,X or Y | 25 pp<br>35 pp<br>21 pp<br>31 pp<br>2D ppqq<br>00111x01 ppqq | 2<br>2<br>2<br>2<br>3<br>3 | 3<br>4<br>6<br>5*<br>4<br>4* | X<br>X<br>X<br>X<br>X<br>X             |        |   | X<br>X<br>X<br>X<br>X<br>X             | AND contents of Accumulator with those of memory location.<br>A—AΛ[addr] Zero page direct<br>A—AΛ[addr+X] Zero page indexed<br>A—AΛ[(addr+X)] Pre-indexed indirect<br>A—AΛ[(addr+1, addr)+Y] Post-indexed indirect<br>A—AΛ[addr16] Extended direct<br>A—AΛ[addr16+X] or A—AΛ[addr16+Y] Absolute indexed                                                                       |   |                                                                                                                                                             |
|                                              | BIT                                                                      |                                                              |                            |                              |                                        |        |   |                                        |                                                                                                                                                                                                                                                                                                                                                                               |   | AND contents of Accumulator with those of memory location. Only the status bits are affected.                                                               |
|                                              | addr<br>addr16                                                           | 24 pp<br>2C ppqq                                             | 2<br>3                     | 3<br>4                       | 7<br>7                                 | 6<br>6 |   | X<br>X                                 |                                                                                                                                                                                                                                                                                                                                                                               |   | AΛ[addr] Zero page direct<br>AΛ[addr16] Extended direct                                                                                                     |

\* Add one clock period if page boundary is crossed. In the object code, "x" designates the index register: x = 0 for Register Y, x = 1 for Register X.

Table 3-4. A Summary of the 6502 Instruction Set (Continued)

| Type                         | Instruction   | Object Code   | Bytes | Clock Periods | Status |   |   |   |   |   | Operation Performed                                                                               |                       |
|------------------------------|---------------|---------------|-------|---------------|--------|---|---|---|---|---|---------------------------------------------------------------------------------------------------|-----------------------|
|                              |               |               |       |               | S      | V | D | I | Z | C |                                                                                                   |                       |
| (Memory Operate) (Continued) | CMP           |               |       |               |        |   |   |   |   |   | Compare contents of Accumulator with those of memory location. Only the status bits are affected. |                       |
|                              | addr          | C5 pp         | 2     | 3             | X      |   |   |   | X | X | A-[addr]                                                                                          | Zero page direct      |
|                              | addr,X        | D5 pp         | 2     | 4             | X      |   |   |   | X | X | A-[addr+X]                                                                                        | Zero page indexed     |
|                              | (addr,X)      | C1 pp         | 2     | 6             | X      |   |   |   | X | X | A-[addr+X]]                                                                                       | Pre-indexed indirect  |
|                              | (addr),Y      | D1 pp         | 2     | 5*            | X      |   |   |   | X | X | A-[[addr+1, addr]+Y]                                                                              | Post-indexed indirect |
|                              | addr16        | CD ppqq       | 3     | 4             | X      |   |   |   | X | X | A-[addr16]                                                                                        | Extended direct       |
|                              | addr16,X or Y | 11011x01 ppqq | 3     | 4*            | X      |   |   |   | X | X | A-[addr16+X] or A-[addr16+Y]                                                                      | Absolute indexed      |
|                              | EOR           |               |       |               |        |   |   |   |   |   | Exclusive-OR contents of Accumulator with those of memory location.                               |                       |
|                              | addr          | 45 pp         | 2     | 3             | X      |   |   |   | X |   | A-A $\vee$ [addr]                                                                                 | Zero page direct      |
|                              | addr,X        | 55 pp         | 2     | 4             | X      |   |   |   | X |   | A-A $\vee$ [addr+X]                                                                               | Zero page indexed     |
|                              | (addr,X)      | 41 pp         | 2     | 6             | X      |   |   |   | X |   | A-A $\vee$ [[addr+X]]                                                                             | Pre-indexed indirect  |
|                              | (addr),Y      | 51 pp         | 2     | 5*            | X      |   |   |   | X |   | A-A $\vee$ [[addr+1, addr]+Y]                                                                     | Post-indexed indirect |
|                              | addr16        | 4D ppqq       | 3     | 4             | X      |   |   |   | X |   | A-A $\vee$ [addr16]                                                                               | Extended direct       |
|                              | addr16,X or Y | 01011x01 ppqq | 3     | 4*            | X      |   |   |   | X |   | A-A $\vee$ [addr16+X] or A-A $\vee$ [addr16+Y]                                                    | Absolute indexed      |
|                              | ORA           |               |       |               |        |   |   |   |   |   | OR contents of Accumulator with those of memory location.                                         |                       |
|                              | addr          | 05 pp         | 2     | 3             | X      |   |   |   | X |   | A-AV[addr]                                                                                        | Zero page direct      |
|                              | addr,X        | 15 pp         | 2     | 4             | X      |   |   |   | X |   | A-AV[addr+X]                                                                                      | Zero page indexed     |
|                              | (addr,X)      | 01 pp         | 2     | 6             | X      |   |   |   | X |   | A-AV[[addr+X]]                                                                                    | Pre-indexed indirect  |
|                              | (addr),Y      | 11 pp         | 2     | 5*            | X      |   |   |   | X |   | A-AV[[addr+1, addr]+Y]                                                                            | Post-indexed indirect |
|                              | addr16        | 0D ppqq       | 3     | 4             | X      |   |   |   | X |   | A-AV[addr16]                                                                                      | Extended direct       |
|                              | addr16,X or Y | 00011x01 ppqq | 3     | 4*            | X      |   |   |   | X |   | A-AV[addr16+X] or A-AV[addr16+Y]                                                                  | Absolute indexed      |

\* Add one clock period if page boundary is crossed. In the object code, "x" designates the Index register: x = 0 for Register Y, x = 1 for Register X.

Table 3-4. A Summary of the 6502 Instruction Set (Continued)

| Type                                                    | Instruction   | Object Code   | Bytes | Clock Periods | Status |   |   |   |   |   | Operation Performed                                                                                                            |
|---------------------------------------------------------|---------------|---------------|-------|---------------|--------|---|---|---|---|---|--------------------------------------------------------------------------------------------------------------------------------|
|                                                         |               |               |       |               | S      | V | D | I | Z | C |                                                                                                                                |
| Secondary Memory Reference (Memory Operate) (Continued) | SBC           |               |       |               |        |   |   |   |   |   | Subtract contents of memory location, with borrow, from contents of Accumulator.                                               |
|                                                         | addr          | E5 pp         | 2     | 3             | X      | X |   |   | X | X | $A \leftarrow A - [addr] - \bar{C}$                                                                                            |
|                                                         | addr,X        | F5 pp         | 2     | 4             | X      | X |   |   | X | X | $A \leftarrow A - [addr+X] - \bar{C}$                                                                                          |
|                                                         | (addr,X)      | E1 pp         | 2     | 6             | X      | X |   |   | X | X | $A \leftarrow A - [(addr+X)] - \bar{C}$                                                                                        |
|                                                         | (addr,Y)      | F1 pp         | 2     | 5*            | X      | X |   |   | X | X | $A \leftarrow A - [(addr+Y)] - \bar{C}$                                                                                        |
|                                                         | addr16        | ED ppqq       | 3     | 4             | X      | X |   |   | X | X | $A \leftarrow A - [(addr+1,addr)+Y] - \bar{C}$                                                                                 |
|                                                         | addr16,X or Y | 11111x01 ppqq | 3     | 4*            | X      | X |   |   | X | X | $A \leftarrow A - [addr16] - \bar{C}$<br>$A \leftarrow A - [addr16+X] - \bar{C}$ or<br>$A \leftarrow A - [addr16+Y] - \bar{C}$ |
|                                                         |               |               |       |               |        |   |   |   |   |   | (Note that Carry value is the complement of the borrow.)                                                                       |
|                                                         | INC           |               |       |               |        |   |   |   |   |   | Increment contents of memory location. Index through Register X only.                                                          |
|                                                         | addr          | E6 pp         | 2     | 5             | X      |   |   |   | X |   | $[addr] \leftarrow [addr]+1$                                                                                                   |
|                                                         | addr,X        | F6 pp         | 2     | 6             | X      |   |   |   | X |   | $[addr+X] \leftarrow [addr+X]+1$                                                                                               |
|                                                         | addr16        | EE ppqq       | 3     | 6             | X      |   |   |   | X |   | $[addr16] \leftarrow [addr16]+1$                                                                                               |
|                                                         | addr16,X      | FE ppqq       | 3     | 7             | X      |   |   |   | X |   | $[addr16+X] \leftarrow [addr16+X]+1$                                                                                           |
|                                                         | DEC           |               |       |               |        |   |   |   |   |   | Decrement contents of memory location. Index through Register X only.                                                          |
|                                                         | addr          | C6 pp         | 2     | 5             | X      |   |   |   | X |   | $[addr] \leftarrow [addr]-1$                                                                                                   |
|                                                         | addr,X        | D6 pp         | 2     | 6             | X      |   |   |   | X |   | $[addr+X] \leftarrow [addr+X]-1$                                                                                               |
|                                                         | addr16        | CE ppqq       | 3     | 6             | X      |   |   |   | X |   | $[addr16] \leftarrow [addr16]-1$                                                                                               |
|                                                         | addr16,X      | DE ppqq       | 3     | 7             | X      |   |   |   | X |   | $[addr16+X] \leftarrow [addr16+X]-1$                                                                                           |
|                                                         | CPX           |               |       |               |        |   |   |   |   |   | Compare contents of X register with those of memory location. Only the status flags are affected.                              |
|                                                         | addr          | E4 pp         | 2     | 3             | X      |   |   |   | X | X | $X - [addr]$                                                                                                                   |
|                                                         | addr16        | EC ppqq       | 3     | 4             | X      |   |   |   | X | X | $X - [addr16]$                                                                                                                 |
|                                                         | CPY           |               |       |               |        |   |   |   |   |   | Compare contents of Y register with those of memory location. Only the status flags are affected.                              |
|                                                         | addr          | C4 pp         | 2     | 3             | X      |   |   |   | X | X | $Y - [addr]$                                                                                                                   |
|                                                         | addr16        | CC ppqq       | 3     | 4             | X      |   |   |   | X | X | $Y - [addr16]$                                                                                                                 |
|                                                         |               |               |       |               |        |   |   |   |   |   | Zero page direct<br>Extended direct                                                                                            |

\* Add one clock period if page boundary is crossed. In the object code, "x" designates the index register: x = 0 for

Register Y. x = 1 for Register X.

Table 3-4. A Summary of the 6502 Instruction Set (Continued)

| Type                                                    | Instruction | Object Code | Bytes | Clock Periods | Status |   |   |   |   |   | Operation Performed                                                                             |
|---------------------------------------------------------|-------------|-------------|-------|---------------|--------|---|---|---|---|---|-------------------------------------------------------------------------------------------------|
|                                                         |             |             |       |               | S      | V | D | I | Z | C |                                                                                                 |
| Secondary Memory Reference (Memory Operate) (Continued) | ROL         |             |       |               |        |   |   |   |   |   | Rotate contents of memory location one bit left through Carry. Index through Register X only.   |
|                                                         | addr        | 26 pp       | 2     | 5             | X      |   |   |   | X | X | [addr]                                                                                          |
|                                                         | addr,X      | 36 pp       | 2     | 6             | X      |   |   |   | X | X | [addr+X]                                                                                        |
|                                                         | addr16      | 2E ppqq     | 3     | 6             | X      |   |   |   | X | X | [addr16]                                                                                        |
|                                                         | addr16,X    | 3E ppqq     | 3     | 7             | X      |   |   |   | X | X | [addr16+X]                                                                                      |
|                                                         | ROR         |             |       |               |        |   |   |   |   |   | Rotate contents of memory location one bit right, through Carry. Index through Register X only. |
|                                                         | addr        | 66 pp       | 2     | 5             | X      |   |   |   | X | X | [addr]                                                                                          |
|                                                         | addr,X      | 76 pp       | 2     | 6             | X      |   |   |   | X | X | [addr+X]                                                                                        |
|                                                         | addr16      | 6E pp       | 3     | 6             | X      |   |   |   | X | X | [addr16]                                                                                        |
|                                                         | addr16,X    | 7E ppqq     | 3     | 7             | X      |   |   |   | X | X | [addr16+X]                                                                                      |
| Secondary Memory Reference (Memory Operate) (Continued) | ASL         |             |       |               |        |   |   |   |   |   | Arithmetic shift left contents of memory location. Index through Register X only.               |
|                                                         | addr        | 06 pp       | 2     | 5             | X      |   |   |   | X | X | [addr]                                                                                          |
|                                                         | addr,X      | 16 pp       | 2     | 6             | X      |   |   |   | X | X | [addr+X]                                                                                        |
|                                                         | addr16      | 0E ppqq     | 3     | 6             | X      |   |   |   | X | X | [addr16]                                                                                        |
|                                                         | addr16,X    | 1E ppqq     | 3     | 7             | X      |   |   |   | X | X | [addr16+X]                                                                                      |



Rotate contents of memory location one bit left through Carry. Index through Register X only.



Rotate contents of memory location one bit right, through Carry. Index through Register X only.



Arithmetic shift left contents of memory location. Index through Register X only.

Table 3-4. A Summary of the 6502 Instruction Set (Continued)

| Type                                              | Instruction | Object Code | Bytes | Clock Periods | Status |   |   |   |   |   | Operation Performed                                                             |
|---------------------------------------------------|-------------|-------------|-------|---------------|--------|---|---|---|---|---|---------------------------------------------------------------------------------|
|                                                   |             |             |       |               | S      | V | D | I | Z | C |                                                                                 |
| Secondary Memory Ref.<br>(Memory Operate) (Cont.) | LSR         |             |       |               |        |   |   |   |   |   | Logical shift right contents of memory location. Index through Register X only. |
|                                                   | addr        | 46 pp       | 2     | 5             | 0      |   |   |   | X | X | [addr]                                                                          |
|                                                   | addr,X      | 56 pp       | 2     | 6             | 0      |   |   |   | X | X | [addr+X]                                                                        |
|                                                   | addr16      | 4E pppq     | 3     | 6             | 0      |   |   |   | X | X | [addr16]                                                                        |
| Immediate                                         | addr16,X    | 5E pppq     | 3     | 7             | 0      |   |   |   | X | X | [addr16,X]                                                                      |
|                                                   | LDA data    | A9 pp       | 2     | 2             | X      |   |   |   | X |   | Load Accumulator with immediate data.<br>A←data                                 |
|                                                   | LDX data    | A2 pp       | 2     | 2             | X      |   |   |   | X |   | Load Index Register X with immediate data.<br>X←data                            |
|                                                   | LDY data    | A0 pp       | 2     | 2             | X      |   |   |   | X |   | Load Index Register Y with immediate data.<br>Y←data                            |



Table 3-4. A Summary of the 6502 Instruction Set (Continued)

| Type              | Instruction          | Object Code        | Bytes  | Clock Periods | Status |   |   |   |   |   | Operation Performed                                                                                                          |
|-------------------|----------------------|--------------------|--------|---------------|--------|---|---|---|---|---|------------------------------------------------------------------------------------------------------------------------------|
|                   |                      |                    |        |               | S      | V | D | I | Z | C |                                                                                                                              |
| Immediate Operate | ADC data             | 69 pp              | 2      | 2             | X      | X |   |   | X | X | Add immediate with Carry, to Accumulator. The Zero flag is not valid in Decimal Mode.<br>A←A+data+C                          |
|                   | AND data             | 29 pp              | 2      | 2             | X      |   |   |   | X |   | AND immediate with Accumulator.<br>A←A\data                                                                                  |
|                   | CMP data             | C9 pp              | 2      | 2             | X      |   |   |   | X | X | Compare immediate with Accumulator. Only the status flags are affected.<br>A\data                                            |
|                   | EOR data             | 49 pp              | 2      | 2             | X      |   |   |   | X |   | Exclusive-OR immediate with Accumulator.<br>A←A ∨ data                                                                       |
|                   | ORA data             | 09 pp              | 2      | 2             | X      |   |   |   | X |   | OR immediate with Accumulator.<br>A←A V data                                                                                 |
|                   | SBC data             | E9 pp              | 2      | 2             | X      | X |   |   | X | X | Subtract immediate, with borrow, from Accumulator.<br>A←A-data-C<br>(Note that Carry value is the complement of the borrow.) |
|                   | CPX data             | E0 pp              | 2      | 2             | X      |   |   |   | X | X | Compare immediate with Index Register X. Only the status flags are affected.<br>X\data                                       |
|                   | CPY data             | C0 pp              | 2      | 2             | X      |   |   |   | X | X | Compare immediate with Index Register Y. Only the status flags are affected.<br>Y\data                                       |
| Jump              | JMP label<br>(label) | 4C ppqq<br>6C ppqq | 3<br>3 | 3<br>5        |        |   |   |   |   |   | Jump to new location, using extended or indirect addressing.<br>PC←label or PC←[label]                                       |

Table 3-4. A Summary of the 6502 Instruction Set (Continued)

| Type                | Instruction | Object Code | Bytes | Clock Periods | Status |   |   |   |   |   | Operation Performed                                                                                                                                                                                                                                                                                                                  |
|---------------------|-------------|-------------|-------|---------------|--------|---|---|---|---|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                     |             |             |       |               | S      | V | D | I | Z | C |                                                                                                                                                                                                                                                                                                                                      |
| Branch on Condition | BCC disp    | 90 pp       | 2     | 2**           |        |   |   |   |   |   | Note the following for all Branch-on-Condition instructions:<br>If the condition is satisfied, the displacement is added to the Program Counter after the Program Counter has been incremented to point to the instruction following the Branch instruction.<br>Branch relative if Carry flag is cleared.<br>If C=0, then PC—PC+disp |
|                     | BCS disp    | 80 pp       | 2     | 2**           |        |   |   |   |   |   | Branch relative if Carry flag is set.<br>If C=1, then PC—PC+disp                                                                                                                                                                                                                                                                     |
|                     | BEQ disp    | F0 pp       | 2     | 2**           |        |   |   |   |   |   | Branch relative if result is equal to zero.<br>If Z=1, then PC—PC+disp                                                                                                                                                                                                                                                               |
|                     | BMI disp    | 30 pp       | 2     | 2**           |        |   |   |   |   |   | Branch relative if result is negative.<br>If S=1, then PC—PC+disp                                                                                                                                                                                                                                                                    |
|                     | BNE disp    | D0 pp       | 2     | 2**           |        |   |   |   |   |   | Branch relative if result is not zero.<br>If Z=0, then PC—PC+disp                                                                                                                                                                                                                                                                    |
|                     | BPL disp    | 10 pp       | 2     | 2**           |        |   |   |   |   |   | Branch relative if result is positive.<br>If S=0, then PC—PC+disp                                                                                                                                                                                                                                                                    |
|                     | BVC disp    | 50 pp       | 2     | 2**           |        |   |   |   |   |   | Branch relative if Overflow flag is cleared.<br>If V = 0, then PC—PC+disp                                                                                                                                                                                                                                                            |
|                     | BVS disp    | 70 pp       | 2     | 2**           |        |   |   |   |   |   | Branch relative if Overflow flag is set.<br>If V=1, then PC—PC+disp                                                                                                                                                                                                                                                                  |

\*\*Add one clock period if branch occurs to location in same page; add two clock periods if branch to another page occurs.

Table 3-4. A Summary of the 6502 Instruction Set (Continued)

| Type                       | Instruction | Object Code | Bytes | Clock Periods | Status |   |   |   |   |   | Operation Performed                                                                                                                                                                                                            |
|----------------------------|-------------|-------------|-------|---------------|--------|---|---|---|---|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                            |             |             |       |               | S      | V | D | I | Z | C |                                                                                                                                                                                                                                |
| Subroutine Call and Return | JSR label   | 20 ppqq     | 3     | 6             |        |   |   |   |   |   | Jump to subroutine beginning at address given in bytes 2 and 3 of the instruction. Note that the stored Program Counter points to the last byte of the JSR instruction.<br>[SP]—PC(HI)<br>[SP-1]—PC(LO)<br>SP—SP-2<br>PC—label |
|                            | RTS         | 60          | 1     | 6             |        |   |   |   |   |   | Return from subroutine, incrementing Program Counter to point to the instruction after the JSR which called the routine.<br>PC(LO)—[SP+1]<br>PC(HI)—[SP+2]<br>SP—SP+2<br>PC—PC+1                                               |
| Register-Register Move     | TAX         | AA          | 1     | 2             | X      |   |   |   | X |   | Move Accumulator contents to Index Register X.<br>X—A                                                                                                                                                                          |
|                            | TXA         | 8A          | 1     | 2             | X      |   |   |   | X |   | Move contents of Index Register X to Accumulator.<br>A—X                                                                                                                                                                       |
|                            | TAY         | A8          | 1     | 2             | X      |   |   |   | X |   | Move Accumulator contents to Index Register Y.<br>Y—A                                                                                                                                                                          |
|                            | TYA         | 98          | 1     | 2             | X      |   |   |   | X |   | Move contents of Index Register Y to Accumulator.<br>A—Y                                                                                                                                                                       |
|                            | TSX         | BA          | 1     | 2             | X      |   |   |   | X |   | Move contents of Stack Pointer to Index Register X.<br>X—SP                                                                                                                                                                    |
|                            | TXS         | 9A          | 1     | 2             |        |   |   |   |   |   | Move contents of Index Register X to Stack Pointer.<br>SP—X                                                                                                                                                                    |

Table 3-4. A Summary of the 6502 Instruction Set (Continued)

| Type             | Instruction | Object Code | Bytes | Clock Periods | Status |   |   |   |   |   | Operation Performed                                             |
|------------------|-------------|-------------|-------|---------------|--------|---|---|---|---|---|-----------------------------------------------------------------|
|                  |             |             |       |               | S      | V | D | I | Z | C |                                                                 |
| Register Operate | DEX         | CA          | 1     | 2             | X      |   |   |   | X |   | Decrement contents of Index Register X.<br>$X \leftarrow X - 1$ |
|                  | DEY         | 88          | 1     | 2             | X      |   |   |   | X |   | Decrement contents of Index Register Y.<br>$Y \leftarrow Y - 1$ |
|                  | INX         | E8          | 1     | 2             | X      |   |   |   | X |   | Increment contents of Index Register X.<br>$X \leftarrow X + 1$ |
|                  | INY         | C8          | 1     | 2             | X      |   |   |   | X |   | Increment contents of Index Register Y.<br>$Y \leftarrow Y + 1$ |
|                  | ROL A       | 2A          | 1     | 2             | X      |   |   |   | X | X | Rotate contents of Accumulator left through Carry.              |
|                  | ROR A       | 6A          | 1     | 2             | X      |   |   |   | X | X | Rotate contents of Accumulator right, through Carry.            |
|                  | ASL A       | 0A          | 1     | 2             | X      |   |   |   | X | X | Arithmetic shift left contents of Accumulator.                  |
|                  | LSR A       | 4A          | 1     | 2             | 0      |   |   |   | X | X | Logical shift right contents of Accumulator.                    |



Table 3-4. A Summary of the 6502 Instruction Set (Continued)

| Type      | Instruction | Object Code | Bytes | Clock Periods | Status |   |   |   |   |   | Operation Performed                                                                                                                                                                                                            |
|-----------|-------------|-------------|-------|---------------|--------|---|---|---|---|---|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|           |             |             |       |               | S      | V | D | I | Z | C |                                                                                                                                                                                                                                |
| Stack     | PHA         | 48          | 1     | 3             |        |   |   |   |   |   | Push Accumulator contents onto Stack.<br>[SP]—A<br>SP—SP—1                                                                                                                                                                     |
|           | PLA         | 68          | 1     | 4             | X      |   |   |   | X |   | Load Accumulator from top of Stack ("Pull").<br>A—[SP+1]<br>SP—SP+1                                                                                                                                                            |
|           | PHP         | 08          | 1     | 3             |        |   |   |   |   |   | Push Status register contents onto Stack.<br>[SP]—P<br>SP—SP—1                                                                                                                                                                 |
|           | PLP         | 28          | 1     | 4             | X      | X | X | X | X | X | Load Status register from top of Stack ("Pull").<br>P—[SP+1]<br>SP—SP+1                                                                                                                                                        |
| Interrupt | CLI         | 58          | 1     | 2             |        |   |   | 0 |   |   | Enable interrupts by clearing interrupt disable bit of Status register.<br>I—0                                                                                                                                                 |
|           | SEI         | 78          | 1     | 2             |        |   |   | 1 |   |   | Disable interrupts<br>I—1                                                                                                                                                                                                      |
|           | RTI         | 40          | 1     | 6             | X      | X | X | X | X | X | Return from interrupt; restore Status<br>P—[SP+1]<br>PC(LO)—[SP+2]<br>PC(HI)—[SP+3]<br>SP—SP+3<br>PC—PC+1                                                                                                                      |
|           | BRK         | 00          | 1     | 7             |        |   |   | 1 |   |   | Programmed interrupt. BRK cannot be disabled. The Program Counter is incremented twice before it is saved on the Stack.<br>[SP]—PC(HI)<br>[SP—1]—PC(LO)<br>[SP—2]—P<br>SP—SP—3<br>PC(HI)—[FFFF]<br>PC(LO)—[FFFE]<br>I—1<br>B—1 |

Table 3-4. A Summary of the 6502 Instruction Set (Continued)

| Type   | Instruction | Object Code | Bytes | Clock Periods | Status |   |   |   |   |   | Operation Performed        |
|--------|-------------|-------------|-------|---------------|--------|---|---|---|---|---|----------------------------|
|        |             |             |       |               | S      | V | D | I | Z | C |                            |
| Status | CLC         | 18          | 1     | 2             |        |   |   |   |   | 0 | Clear Carry flag<br>C→0    |
|        | SEC         | 38          | 1     | 2             |        |   |   |   |   | 1 | Set Carry flag<br>C→1      |
|        | CLD         | D8          | 1     | 2             |        |   | 0 |   |   |   | Clear Decimal Mode<br>D→0  |
|        | SED         | F8          | 1     | 2             |        |   | 1 |   |   |   | Set Decimal Mode<br>D→1    |
|        | CLV         | B8          | 1     | 2             | 0      |   |   |   |   |   | Clear Overflow flag<br>V→0 |
|        | NOP         | EA          | 1     | 2             |        |   |   |   |   |   | No Operation               |

Table 3-5. 6502 Instruction Object Codes in Numerical Order

| Object Code | Instruction |          | Object Code | Instruction |          |
|-------------|-------------|----------|-------------|-------------|----------|
| 00          | BRK         |          | 68          | PLA         |          |
| 01 pp       | ORA         | (addr,X) | 69 pp       | ADC         | data     |
| 05 pp       | ORA         | addr     | 6A          | ROR         | A        |
| 06 pp       | ASL         | addr     | 6C ppqq     | JMP         | (label)  |
| 08          | PHP         |          | 6D ppqq     | ADC         | addr16   |
| 09 pp       | ORA         | data     | 6E ppqq     | ROR         | addr16   |
| 0A          | ASL         | A        | 70 pp       | BVS         | disp     |
| 0D ppqq     | ORA         | addr16   | 71 pp       | ADC         | (addr),Y |
| 0E ppqq     | ASL         | addr16   | 75 pp       | ADC         | addr,X   |
| 10 pp       | BPL         | disp     | 76 pp       | ROR         | addr,X   |
| 11 pp       | ORA         | (addr),Y | 78          | SEI         |          |
| 15 pp       | ORA         | addr,X   | 79 ppqq     | ADC         | addr16,Y |
| 16 pp       | ASL         | addr,X   | 7D ppqq     | ADC         | addr16,X |
| 18          | CLC         |          | 7E ppqq     | ROR         | addr16,X |
| 19 ppqq     | ORA         | addr16,Y | 81 pp       | STA         | (addr),X |
| 1D ppqq     | ORA         | addr16,X | 84 pp       | STY         | addr     |
| 1E ppqq     | ASL         | addr16,X | 85 pp       | STA         | addr     |
| 20 ppqq     | JSR         | label    | 86 pp       | STX         | addr     |
| 21 pp       | AND         | (addr,X) | 88          | DEY         |          |
| 24 pp       | BIT         | addr     | 8A          | TXA         |          |
| 25 pp       | AND         | addr     | 8C ppqq     | STY         | addr16   |
| 26 pp       | ROL         | addr     | 8D ppqq     | STA         | addr16   |
| 28          | PLP         |          | 8E ppqq     | STX         | addr16   |
| 29 pp       | AND         | data     | 90 pp       | BCC         | disp     |
| 2A          | ROL         | A        | 91 pp       | STA         | (addr),Y |
| 2C ppqq     | BIT         | addr16   | 94 pp       | STY         | addr,X   |
| 2D ppqq     | AND         | addr16   | 95 pp       | STA         | addr,X   |
| 2E ppqq     | ROL         | addr16   | 96 pp       | STX         | addr,Y   |
| 30 pp       | BMI         | disp     | 98          | TYA         |          |
| 31 pp       | AND         | (addr),Y | 99 ppqq     | STA         | addr16,Y |
| 35 pp       | AND         | addr,X   | 9A          | TXS         |          |
| 36 pp       | ROL         | addr,X   | 9D ppqq     | STA         | addr16,X |
| 38          | SEC         |          | A0 pp       | LDY         | data     |
| 39 ppqq     | AND         | addr16,Y | A1 pp       | LDA         | (addr,X) |
| 3D ppqq     | AND         | addr16,X | A2 pp       | LDX         | data     |
| 3E ppqq     | ROL         | addr16,X | A4 pp       | LDY         | addr     |
| 40          | RTI         |          | A5 pp       | LDA         | addr     |
| 41 pp       | EOR         | (addr,X) | A6 pp       | LDX         | addr     |
| 45 pp       | EOR         | addr     | A8          | TAY         |          |
| 46 pp       | LSR         | addr     | A9 pp       | LDA         | data     |
| 48          | PHA         |          | AA          | TAX         |          |
| 49 pp       | EOR         | data     | AC ppqq     | LDY         | addr16   |
| 4A          | LSR         | A        | AD ppqq     | LDA         | addr16   |
| 4C ppqq     | JMP         | label    | AE ppqq     | LDX         | addr16   |
| 4D ppqq     | EOR         | addr16   | B0 pp       | BCS         | disp     |
| 4E ppqq     | LSR         | addr16   | B1 pp       | LDA         | (addr),Y |
| 50 pp       | BVC         | disp     | B4 pp       | LDY         | addr,X   |
| 51 pp       | EOR         | (addr),Y | B5 pp       | LDA         | addr,X   |
| 55 pp       | EOR         | addr,X   | B6 pp       | LDX         | addr,Y   |
| 56 pp       | LSR         | addr,X   | B8          | CLV         |          |
| 58          | CLI         |          | B9 ppqq     | LDA         | addr16,Y |
| 59 ppqq     | EOR         | addr16,Y | BA          | TSX         |          |
| 5D ppqq     | EOR         | addr16,X | BC ppqq     | LDY         | addr16,X |
| 5E ppqq     | LSR         | addr16,X | BD ppqq     | LDA         | addr16,X |
| 60          | RTS         |          | BE ppqq     | LDX         | addr16,Y |
| 61 pp       | ADC         | (addr,X) | C0 pp       | CPY         | data     |
| 65 pp       | ADC         | addr     | C1 pp       | CMP         | (addr,X) |
| 66 pp       | ROR         | addr     | C4 pp       | CPY         | addr     |

Table 3-5. 6502 Instruction Object Codes in Numerical Order (Continued)

| Object Code | Instruction |          | Object Code | Instruction |          |
|-------------|-------------|----------|-------------|-------------|----------|
| C5 pp       | CMP         | addr     | E4 pp       | CPX         | addr     |
| C6 pp       | DEC         | addr     | E5 pp       | SBC         | addr     |
| C8          | INY         |          | E6 pp       | INC         | addr     |
| C9 pp       | CMP         | data     | E8          | INX         |          |
| CA          | DEX         |          | E9 pp       | SBC         | data     |
| CC ppqq     | CPY         | addr16   | EA          | NOP         |          |
| CD ppqq     | CMP         | addr16   | EC ppqq     | CPX         | addr16   |
| CE ppqq     | DEC         | addr16   | ED ppqq     | SBC         | addr16   |
| D0 pp       | BNE         | disp     | EE ppqq     | INC         | addr16   |
| D1 pp       | CMP         | (addr),Y | F0 pp       | BEQ         | disp     |
| D5 pp       | CMP         | addr,X   | F1 pp       | SBC         | (addr),Y |
| D6 pp       | DEC         | addr,X   | F5 pp       | SBC         | addr,X   |
| D8          | CLD         |          | F6 pp       | INC         | addr,X   |
| D9 ppqq     | CMP         | addr16,Y | F8          | SED         |          |
| DD ppqq     | CMP         | addr16,X | F9 ppqq     | SBC         | addr16,Y |
| DE ppqq     | DEC         | addr16,X | FD ppqq     | SBC         | addr16,X |
| E0 pp       | CPX         | data     | FE ppqq     | INC         | addr16,X |
| E1 pp       | SBC         | (addr,X) |             |             |          |

The following symbols are used in the object codes in Table 3-6.

Address-mode Selection:

aaa

|     |                                  |
|-----|----------------------------------|
| 000 | pre-indexed indirect - (addr,X)  |
| 001 | direct - addr                    |
| 010 | immediate - data                 |
| 011 | extended direct - addr16         |
| 100 | post-indexed indirect - (addr),Y |
| 101 | base page indexed - addr,X       |
| 110 | absolute indexed - addr16,Y      |
| 111 | absolute indexed - addr16,X      |

bb

|    |                             |
|----|-----------------------------|
| 00 | direct - addr               |
| 01 | extended direct - addr16    |
| 10 | base page indexed - addr,X  |
| 11 | absolute indexed - addr16,X |

bbb

|     |                                              |
|-----|----------------------------------------------|
| 001 | direct - addr                                |
| 010 | accumulator - A                              |
| 011 | extended direct - addr16                     |
| 101 | base page indexed - addr,X; addr,Y in STX    |
| 111 | absolute indexed - addr16,X; addr16,Y in STX |

cc

|    |                          |
|----|--------------------------|
| 00 | immediate - data         |
| 01 | direct - addr            |
| 11 | extended direct - addr16 |

ddd

|     |                                                     |
|-----|-----------------------------------------------------|
| 000 | immediate - data                                    |
| 001 | direct - addr                                       |
| 011 | extended direct - addr16                            |
| 101 | base page indexed - addr,Y in LDX; addr,X in LDY    |
| 111 | absolute indexed - addr16,Y in LDX; addr16,X in LDY |

pp

the second byte of a two- or three-byte instruction

qq

the third byte of a three-byte instruction

x

one bit choosing the address mode:

|   |                          |
|---|--------------------------|
| 0 | direct - addr            |
| 1 | extended direct - addr16 |

y

one bit choosing the JMP address mode:

|   |                         |
|---|-------------------------|
| 0 | extended direct - label |
| 1 | indirect - (label)      |

Table 3-6. Summary of 6502 Object Codes with 6800 Mnemonics

| Mnemonic | Operand  | Object Code | Bytes | Clock Periods | MC6800 Instruction |
|----------|----------|-------------|-------|---------------|--------------------|
| ADC      |          | 011aaa01    |       |               |                    |
|          | data     | pp          | 2     | 2             | ADCA               |
|          | addr     | pp          | 2     | 3             | data8              |
|          | addr,X   | pp          | 2     | 4*            | addr8              |
|          | (addr,X) | pp          | 2     | 6             | index              |
|          | (addr),Y | pp          | 2     | 5*            |                    |
|          | addr16   | ppqq        | 3     | 4             | addr16             |
| AND      |          | 001aaa01    |       |               |                    |
|          | data     | pp          | 2     | 2             | ANDA               |
|          | addr     | pp          | 2     | 3             | data8              |
|          | addr,X   | pp          | 2     | 4             | addr8              |
|          | (addr,X) | pp          | 2     | 6             | index              |
|          | (addr),Y | pp          | 2     | 5*            |                    |
|          | addr16   | ppqq        | 3     | 4             | addr16             |
| ASL      |          | 000bbb10    |       |               |                    |
|          | A        | 000bbb10    | 1     | 2             | ASLA               |
|          | addr     | pp          | 1     | 5             |                    |
|          | addr,X   | pp          | 2     | 6             | ASL index          |
|          | addr16   | ppqq        | 3     | 6             | ASL addr16         |
| addr16,X |          | ppqq        | 3     | 7             |                    |
| BCC      | disp     | 90 pp       | 2     | 2**           | BCC disp           |
| BCS      | disp     | B0 pp       | 2     | 2**           | BCS disp           |
| BEQ      | disp     | F0 pp       | 2     | 2**           | BEQ disp           |
|          | 0010x100 |             |       |               |                    |
| BIT      | addr     | pp          | 2     | 3             | BITA               |
|          | addr16   | ppqq        | 3     | 4             | addr8<br>addr16    |
| BMI      | disp     | 30 pp       | 2     | 2**           | BMI disp           |
| BNE      | disp     | D0 pp       | 2     | 2**           | BNE disp           |
| BPL      | disp     | 10 pp       | 2     | 2**           | BPL disp           |
| BRK      |          | 00          | 1     | 7             | (SWI)              |
| BVC      | disp     | 50 pp       | 2     | 2**           | BVC disp           |
| BVS      | disp     | 70 pp       | 2     | 2**           | BVS disp           |
| CLC      |          | 18          | 1     | 2             | CLC                |
| CLD      |          | D8          | 1     | 2             |                    |
| CLI      |          | 58          | 1     | 2             | CLI                |
| CLV      |          | B8          | 1     | 2             | CLV                |

\*Add one clock period if page boundary is crossed.

\*\*Add one clock period if branch occurs to location in same page; add two clock periods if branch to another page occurs.

Table 3-6. Summary of 6502 Object Codes with 6800 Mnemonics (Continued)

| Mnemonic | Operand  | Object Code | Bytes | Clock Periods | MC6800 Instruction |
|----------|----------|-------------|-------|---------------|--------------------|
| CMP      | data     | 110aaa01    |       |               |                    |
|          | addr     | pp          | 2     | 2             |                    |
|          | addr,X   | pp          | 2     | 3             |                    |
|          | (addr,X) | pp          | 2     | 4             |                    |
|          | (addr,Y) | pp          | 2     | 6             |                    |
|          | addr16   | ppqq        | 3     | 5*            |                    |
|          | addr16,X | ppqq        | 3     | 4*            | addr16             |
| CPX      | addr16,Y | ppqq        | 3     | 4*            |                    |
|          |          | 1110cc00    |       |               |                    |
|          | data     | pp          | 2     | 2             | CPX                |
|          | addr     | pp          | 2     | 3             | data8              |
| CPY      | addr16   | ppqq        | 3     | 4             | addr8              |
|          |          | 1100cc00    |       |               | addr16             |
|          | data     | pp          | 2     | 2             |                    |
| DEC      | addr     | pp          | 2     | 3             |                    |
|          | addr,X   | pp          | 2     | 4             |                    |
|          | addr16   | ppqq        | 3     | 5             | DEC                |
| DEX      | addr16,X | ppqq        | 3     | 6             | index              |
|          |          | 110bb110    |       |               |                    |
|          |          | pp          | 2     | 6             |                    |
|          |          | pp          | 2     | 7             | addr16             |
| DEY      |          | CA          | 1     | 2             | DEX                |
|          |          | 88          | 1     | 2             |                    |
| EOR      |          | 010aaa01    |       |               |                    |
|          | data     | pp          | 2     | 2             | EORA               |
|          | addr     | pp          | 2     | 3             | data8              |
|          | addr,X   | pp          | 2     | 4             | addr8              |
|          | (addr,X) | pp          | 2     | 6             | index              |
|          | (addr,Y) | pp          | 2     | 5*            |                    |
|          | addr16   | ppqq        | 3     | 4             |                    |
|          | addr16,X | ppqq        | 3     | 4*            | addr16             |
|          | addr16,Y | ppqq        | 3     | 4*            |                    |
| INC      |          | 111bb110    |       |               |                    |
|          | addr     | pp          | 2     | 5             | INC                |
|          | addr,X   | pp          | 2     | 6             | index              |
|          | addr16   | ppqq        | 3     | 6             | addr16             |
| INX      | addr16,X | ppqq        | 3     | 7             |                    |
|          |          | E8          | 1     | 2             | INX                |
| INY      |          | C8          | 1     | 2             |                    |
| JMP      |          | 01y01100    |       |               |                    |
|          | label    | ppqq        | 3     | 3             | JMP                |
|          | (label)  | ppqq        | 3     | 5             | addr16             |
| JSR      | label    | 20 ppqq     | 3     | 6             | JSR addr16         |

\*Add one clock period if page boundary is crossed.

\*\*Add one clock period if branch occurs to location in same page; add two clock periods if branch to another page occurs.

Table 3-6. Summary of 6502 Object Codes with 6800 Mnemonics (Continued)

| Mnemonic | Operand  | Object Code | Bytes | Clock Periods | MC6800 Instruction |
|----------|----------|-------------|-------|---------------|--------------------|
| LDA      |          | 101aaa01    |       |               |                    |
|          | data     | pp          | 2     | 2             | LDAA               |
|          | addr     | pp          | 2     | 3             | data8              |
|          | addr,X   | pp          | 2     | 4             | addr8              |
|          | (addr,X) | pp          | 2     | 6             | index              |
|          | (addr),Y | pp          | 2     | 5*            |                    |
|          | addr16   | ppqq        | 3     | 4             |                    |
|          | addr16,X | ppqq        | 3     | 4*            | addr16             |
|          | addr16,Y | ppqq        | 3     | 4*            |                    |
| LDX      |          | 101ddd10    |       |               |                    |
|          | data     | pp          | 2     | 2             | LDX                |
|          | addr     | pp          | 2     | 3             | (data8)            |
|          | addr,Y   | pp          | 2     | 4             | addr8              |
|          | addr16   | ppqq        | 3     | 4             | (index)            |
|          | addr16,Y | ppqq        | 3     | 4*            | addr16             |
| LDY      |          | 101ddd00    |       |               |                    |
|          | data     | pp          | 2     | 2             |                    |
|          | addr     | pp          | 2     | 3             |                    |
|          | addr,X   | pp          | 2     | 4             |                    |
|          | addr16   | ppqq        | 3     | 4             |                    |
|          | addr16,X | ppqq        | 3     | 4*            |                    |
| LSR      | A        | 010bbb10    | 1     | 2             | LSRA               |
|          | addr     | pp          | 2     | 5             |                    |
|          | addr,X   | pp          | 2     | 6             | LSR index          |
|          | addr16   | ppqq        | 3     | 6             | LSR addr16         |
|          | addr16,X | ppqq        | 3     | 7             |                    |
| NOP      |          | EA          | 1     | 2             | NOP                |
| ORA      |          | 000aaaa1    |       |               |                    |
|          | data     | pp          | 2     | 2             | ORAA               |
|          | addr     | pp          | 2     | 3             | data8              |
|          | addr,X   | pp          | 2     | 4             | addr8              |
|          | (addr,X) | pp          | 2     | 6             | index              |
|          | (addr),Y | pp          | 2     | 5*            |                    |
|          | addr16   | ppqq        | 3     | 4             |                    |
|          | addr16,X | ppqq        | 3     | 4*            | addr16             |
|          | addr16,Y | ppqq        | 3     | 4*            |                    |
| PHA      |          | 48          | 1     | 3             | PSHA               |
| PHP      |          | 08          | 1     | 3             |                    |
| PLA      |          | 68          | 1     | 4             | PULA               |
| PLP      |          | 28          | 1     | 4             |                    |
| ROL      | A        | 001bbb10    | 1     | 2             | ROLA               |
|          | addr     | pp          | 2     | 5             |                    |
|          | addr,X   | pp          | 2     | 6             | ROL index          |
|          | addr16   | ppqq        | 3     | 6             | ROL addr16         |
|          | addr16,X | ppqq        | 3     | 7             |                    |

\*Add one clock period if page boundary is crossed.

\*\*Add one clock period if branch occurs to location in same page; add two clock periods if branch to another page occurs.

Table 3-6. Summary of 6502 Object Codes with 6800 Mnemonics (Continued)

| Mnemonic | Operand  | Object Code | Bytes | Clock Periods | MC6800 Instruction |
|----------|----------|-------------|-------|---------------|--------------------|
| ROR      | A        | 011bbb10    | 1     | 2             | RORA               |
|          | addr     | pp          | 2     | 5             |                    |
|          | addr,X   | pp          | 2     | 6             | ROR index          |
|          | addr16   | ppqq        | 3     | 6             | ROR addr16         |
|          | addr16,X | ppqq        | 3     | 7             |                    |
| RTI      |          | 40          | 1     | 6             | RTI                |
| RTS      |          | 60          | 1     | 6             | RTS                |
| SBC      |          | 111aaa01    |       |               | SBCA               |
|          | data     | pp          | 2     | 2             | data8              |
|          | addr     | pp          | 2     | 3             | addr8              |
|          | addr,X   | pp          | 2     | 4             | index              |
|          | (addr,X) | pp          | 2     | 6             |                    |
|          | (addr),Y | pp          | 2     | 5*            |                    |
|          | addr16   | ppqq        | 3     | 4             | addr16             |
|          | addr16,X | ppqq        | 3     | 4*            |                    |
|          | addr16,Y | ppqq        | 3     | 4*            |                    |
| SEC      |          | 38          | 1     | 2             | SEC                |
| SED      |          | F8          | 1     | 2             |                    |
| SEI      |          | 78          | 1     | 2             | SEI                |
| STA      |          | 100aaa01    |       |               | STAA               |
|          | addr     | pp          | 2     | 3             | addr8              |
|          | addr,X   | pp          | 2     | 4             | index              |
|          | (addr,X) | pp          | 2     | 6             |                    |
|          | (addr),Y | pp          | 2     | 6             |                    |
|          | addr16   | ppqq        | 3     | 4             | addr16             |
|          | addr16,X | ppqq        | 3     | 5             |                    |
|          | addr16,Y | ppqq        | 3     | 5             |                    |
| STX      |          | 100bb110    |       |               | STX                |
|          | addr     | pp          | 2     | 3             | addr8              |
|          | addr,Y   | pp          | 2     | 4             | (index)            |
| STY      | addr16   | ppqq        | 3     | 4             | addr16             |
|          |          | 100bb100    |       |               |                    |
|          | addr     | pp          | 2     | 3             |                    |
| TAX      | addr,X   | pp          | 2     | 4             |                    |
|          | addr16   | ppqq        | 3     | 4             |                    |
|          |          | AA          | 1     | 2             |                    |
| TAY      |          | A8          | 1     | 2             |                    |
| TSX      |          | BA          | 1     | 2             | TSX                |
| TXA      |          | 8A          | 1     | 2             |                    |
| TXS      |          | 9A          | 1     | 2             | TXS                |
| TYA      |          | 98          | 1     | 2             |                    |

\*Add one clock period if page boundary is crossed.

\*\*Add one clock period if branch occurs to location in same page; add two clock periods if branch to another page occurs.