## SEMICONDUCTORS

## 8-BIT MICROPROCESSING UNIT (MPU)

The MC6800 is a monolithic 8 -bit microprocessor forming the central control function for Motorola's M6800 family. Compatible with TTL, the MC6800, as with all M6800 system parts, requires only one +5.0 -volt power supply, and no external TTL devices for bus interface.

The MC6800 is capable of addressing 64 K bytes of memory with its 16 -bit address lines. The 8 -bit data bus is bidirectional as well as threestate, making direct memory addressing and multiprocessing applications realizable.

- 8-Bit Parallel Processing
- Bidirectional Data Bus
- 16-Bit Address Bus - 64K Bytes of Addressing
- 72 Instructions - Variable Length
- Seven Addressing Modes - Direct, Relative, Immediate, Indexed, Extended, Implied and Accumulator
- Variable Length Stack
- Vectored Restart
- Maskable Interrupt Vector
- Separate Non-Maskable Interrupt - Internal Registers Saved in Stack
- Six Internal Registers - Two Accumulators, Index Register, Program Counter, Stack Pointer and Condition Code Register
- Direct Memory Addressing (DMA) and Multiple Processor Capability
- Simplified Clocking Characteristics
- Clock Rates as High as 2.0 MHz
- Simple Bus Interface Without TTL
- Halt and Single Instruction Execution Capability

ORDERING INFORMATION

| Package Type | Frequency ( MHz ) | Temperature | Order Number |
| :---: | :---: | :---: | :---: |
| Ceramic L Suffix | 1.0 | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ | MC6800L |
|  | 1.0 | $-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$ | MC6800CL |
|  | 1.5 | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ | MC68A00L |
|  | 1.5 | $-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$ | MC68A00CL |
|  | 2.0 | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ | MC68B00L |
| Cerdip S Suffix | 1.0 | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ | MC6800S |
|  | 1.0 | $-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$ | MC6800CS |
|  | 1.5 | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ | MC68A00S |
|  | 1.5 | $-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$ | MC68A00CS |
|  | 2.0 | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ | MC68B00S |
| Plastic P Suffix | 1.0 | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ | MC6800P |
|  | 1.0 | $-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$ | MC6800CP |
|  | 1.5 | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ | MC68A00P |
|  | 1.5 | $-40^{\circ} \mathrm{C}$ to $85^{\circ} \mathrm{C}$ | MC68A00CP |
|  | 2.0 | $0^{\circ} \mathrm{C}$ to $70^{\circ} \mathrm{C}$ | MC68B00P |

MC6800

## MOS

(N-CHANNEL, SILICON-GATE, DEPLETION LOAD)

## MICROPROCESSOR




MAXIMUM RATINGS

| Rating | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| Supply Voltage | $V_{\mathrm{CC}}$ | -0.3 to +7.0 | V |
| Input Voltage | $\mathrm{V}_{\text {in }}$ | -0.3 to +7.0 | V |
| Operating Temperature Range <br> MC6800, MC68A00, MC68B00 <br> MC6800C, MC68A00C | $\mathrm{T}_{\mathrm{A}}$ | $\mathrm{T}_{\mathrm{L}}$ to $\mathrm{TH}_{\mathrm{H}}$ <br> 0 to +70 <br> -40 to +85 | ${ }^{\circ} \mathrm{C}$ |
| Storage Temperature Range | $\mathrm{T}_{\text {stg }}$ | -55 to +150 | ${ }^{\circ} \mathrm{C}$ |

## THERMAL RESISTANCE

| Rating | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| Plastic Package |  | 100 |  |
| Cerdip Package | $\theta_{\text {JA }}$ | 60 | ${ }^{\circ} \mathrm{C} / \mathrm{W}$ |
| Ceramic Package |  | 50 |  |

This device contains circuitry to protect the inputs against damage due to high static voltages or electrical fields; however, it is advised that normal precautions be taken to avoid application of any voltage higher than maximum-rated voltages to this highimpedance circuit. Reliability of operation is enhanced if unused inputs are tied to an appropriate logic voltage le.g., either VSS or $\mathrm{V}_{\mathrm{CC}}$.

## POWER CONSIDERATIONS

The average chip-junction temperature, $T J$, in ${ }^{\circ} \mathrm{C}$ can be obtained from:

$$
\begin{equation*}
T_{J}=T_{A}+\left(P_{D} \bullet \theta J A\right) \tag{1}
\end{equation*}
$$

Where:

$$
\begin{aligned}
& \mathrm{TA}_{\mathrm{A}} \equiv \text { Ambient Temperature, }{ }^{\circ} \mathrm{C} \\
& \theta \mathrm{JA} \equiv \text { Package Thermal Resistance, Junction-to-Ambient, }{ }^{\circ} \mathrm{C} / \mathrm{W} \\
& \mathrm{PD} \equiv \text { PINT }+ \text { PPORT } \\
& \text { PINT } \equiv I_{\mathrm{CC}} \times \text { VCC, Watts - Chip Internal Power } \\
& \text { PPORT } \equiv \text { Port Power Dissipation, Watts - User Determined }
\end{aligned}
$$

For most applications PPORT<<IINT and can be neglected. PPORT may become significant if the device is configured to drive Darlington bases or sink LED loads.

An approximate relationship between PD and $T J$ (if PPORT is neglected) is:

$$
\begin{equation*}
P_{D}=K \div\left(T J+273^{\circ} \mathrm{C}\right) \tag{2}
\end{equation*}
$$

Solving equations 1 and 2 for $K$ gives:

$$
\begin{equation*}
K=P_{D} \cdot\left(T_{A}+273^{\circ} \mathrm{C}\right)+\theta_{J A} \cdot P_{D}{ }^{2} \tag{3}
\end{equation*}
$$

Where $K$ is a constant pertaining to the particular part. $K$ can be determined from equation 3 by measuring $P_{D}$ (at equilibrium) for a known $T_{A}$. Using this value of $K$ the values of $P_{D}$ and $T_{J}$ can be obtained by solving equations (1) and (2) iteratively for any value of $T A$.

DC ELECTRICAL CHARACTERISTICS $\left(V_{C C}=5.0 \mathrm{Vdc}, \pm 5 \%, V_{S S}=0, T_{A}=T_{L}\right.$ to $T_{H}$ unless otherwise noted)

| Characteristic | . | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Input High Voltage | $\begin{gathered} \text { Logic } \\ \phi 1, \phi 2 \end{gathered}$ | $\begin{aligned} & \hline V_{\mathrm{IH}} \\ & V_{\mathrm{IHC}} \end{aligned}$ | $\begin{aligned} & v_{S S}+2.0 \\ & v_{\mathrm{CC}}-0.6 \end{aligned}$ | - | $\begin{gathered} V_{C C} \\ V_{C C}+0.3 \end{gathered}$ | V |
| Input Low Voltage | $\begin{array}{r} \hline \text { Logic } \\ \phi 1, \phi 2 \end{array}$ | $\begin{aligned} & V_{\mathrm{IL}} \\ & \mathrm{~V}_{\mathrm{ILC}} \end{aligned}$ | $\begin{aligned} & V_{S S}-0.3 \\ & V_{S S}-0.3 \end{aligned}$ | - | $\begin{aligned} & V_{S S}+0.8 \\ & V_{S S}+0.4 \end{aligned}$ | V |
| $\begin{aligned} & \text { Input Leakage Current } \\ & \left(V_{\text {in }}=0 \text { to } 5.25 \mathrm{~V}, V_{C C}=\right.\text { Max) } \\ & \left(V_{\text {in }}=0 \text { to } 5.25 \mathrm{~V}, V_{C C}=0 \vee \text { to } 5.25 \mathrm{~V}\right) \end{aligned}$ | $\begin{gathered} \text { Logic } \\ \phi 1, \phi 2 \end{gathered}$ | $l \mathrm{in}$ | - - - | 1.0 | $\begin{array}{r} 2.5 \\ 100 \\ \hline \end{array}$ | $\mu \mathrm{A}$ |
| $\begin{aligned} & \text { Hi-Z Input Leakage Current } \\ & \quad\left(V_{\text {in }}=0.4 \text { to } 2.4 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=\mathrm{Max}\right) \end{aligned}$ | $\begin{array}{r} \mathrm{DO}-\mathrm{D7} \\ \mathrm{AO}-\mathrm{A} 15, \mathrm{R} / \overline{\mathrm{W}} \end{array}$ | 12 | - |  | $\begin{gathered} 10 \\ 100 \end{gathered}$ | $\mu \mathrm{A}$ |
| $\begin{aligned} & \text { Output High Voltage } \\ & \text { (Load }=-205 \mu \mathrm{~A}, \mathrm{VCC}=\mathrm{Min} \text { ) } \\ & \text { (Load }=-145 \mu \mathrm{~A}, V C C=\mathrm{Min} \text { ) } \\ & \text { (1) Load }=-100 \mu \mathrm{~A}, V C C=\mathrm{Min} \text { ) } \end{aligned}$ | D0-D7 <br> AO-A15, R/W, VMA BA | VOH | $\begin{aligned} & v_{S S}+2.4 \\ & v_{S S}+2.4 \\ & v_{S S}+2.4 \end{aligned}$ | - | - | V |
| Output Low Voltage ('Load $=1.6 \mathrm{~mA}, \mathrm{~V}_{\mathrm{CC}}=\mathrm{Min}$ ) |  | VOL | - | - | VSS +0.4 | V |
| Internal Power Dissipation (Measured at $T_{A}=T_{L}$ ) |  | Pint | - | 0.5 | 1.0 | W |
| Capacitance $\left(V_{\text {in }}=0, T_{A}=25^{\circ} \mathrm{C}, f=1.0 \mathrm{MHz}\right)$ |  | $\mathrm{c}_{\mathrm{in}}$ <br> $\mathrm{C}_{\text {out }}$ | - | $\begin{aligned} & 25 \\ & 45 \\ & 10 \\ & 6.5 \end{aligned}$ | $\begin{gathered} 35 \\ 70 \\ 12.5 \\ 10 \\ 12 \end{gathered}$ | pF <br> pF |

MOTOROLA Semiconductor Products Inc.

CLOCK TIMING ${ }^{( } V_{C C}=5.0 \mathrm{~V}, \pm 5 \%, V_{S S}=0, T_{A}=T_{L}$ to $T_{H}$ unless otherwise noted)

| Characteristic | Symbol | Min | Typ | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| $\begin{array}{lr}\text { Frequency of Operation } & \text { MC6800 } \\ \\ \text { MC68A00 } \\ \text { MC68B00 }\end{array}$ | f | $\begin{aligned} & 0.1 \\ & 0.1 \\ & 0.1 \end{aligned}$ | - | $\begin{aligned} & 1.0 \\ & 1.5 \\ & 2.0 \end{aligned}$ | MHz |
| $\begin{array}{lr}\text { Cycle Time (Figure 1) } & \text { MC6800 } \\ \\ \text { MC68A00 } \\ \text { MC68B00 }\end{array}$ | ${ }^{\text {t }}$ cyc | $\begin{aligned} & 1.000 \\ & 0.666 \\ & 0.500 \end{aligned}$ | - | $\begin{aligned} & 10 \\ & 10 \\ & 10 \end{aligned}$ | ${ }^{\mu} \mathrm{S}$ |
| Clock Pulse Width $\phi 1, \phi 2-$ MC6800 <br> (Measured at $\left.V_{C C}-0.6 \mathrm{~V}\right)$ $\phi 1, \phi 2-$ MC68A00 <br>  $\phi 1, \phi 2-$ MC68B00 | $\mathrm{PW}_{\boldsymbol{\phi}} \mathrm{H}$ | $\begin{aligned} & 400 \\ & 230 \\ & 180 \\ & \hline \end{aligned}$ | - | $\begin{aligned} & 9500 \\ & 9500 \\ & 9500 \end{aligned}$ | ns |
| $\begin{array}{lr}\text { Total } \phi 1 \text { and } \phi 2 \text { Up Time } & \text { MC6800 } \\ & \text { MC68A00 } \\ \\ \text { MC68B00 }\end{array}$ | ${ }_{\text {tut }}$ | $\begin{aligned} & 900 \\ & 600 \\ & 440 \end{aligned}$ | - | - | ns |
| Rise and Fall Time (Measured between $\mathrm{V}_{\text {SS }}+0.4$ and $\mathrm{V}_{\text {CC }}-0.6$ ) | $t_{r}, t_{f}$ | - | - | 100 | ns |
| $\begin{aligned} & \text { Delay Time or Clock Separation (Figure 1) } \\ & \text { (Measured at } V_{O V}=V_{S S}+0.6 \vee @ \mathrm{t}_{\mathrm{r}}=\mathrm{t}_{\mathrm{f}} \leq 100 \mathrm{~ns} \text { ) } \\ & \text { (Measured at } \mathrm{V}_{\mathrm{OV}}=\mathrm{V}_{\mathrm{SS}}+1.0 \vee \mathrm{~V}_{\mathrm{t}}=\mathrm{t}_{\mathrm{f}} \leq 35 \mathrm{~ns} \text { ) } \\ & \hline \end{aligned}$ | ${ }_{\text {t }}$ | $\begin{aligned} & 0 \\ & 0 \end{aligned}$ | - | $\begin{aligned} & 9100 \\ & 9100 \end{aligned}$ | ns |

Figure 1 - CLOCK timing WAVEFORM


NOTES:

1. Voltage levels shown are $\mathrm{V}_{\mathrm{L}} \leq 0.4, \mathrm{~V}_{\mathrm{H}} \geq 2.4 \mathrm{~V}$, unless otherwise specified.
2. Measurement points shown are 0.8 V and 2.0 V , unless otherwise noted.

READ/WRITE TIMING (Reference Figures 2 through 6, 8, 9, 11, 12 and 13)

| Characteristic | Symbol | MC6800 |  |  | MC68A00 |  |  | MC68800 |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Typ | Max | Min | Typ | Max | Min | Typ | Max |  |
| $\begin{gathered} \hline \text { Address Delay } \\ \mathrm{C}=90 \mathrm{pF} \\ \mathrm{C}=30 \mathrm{pF} \end{gathered}$ | ${ }^{\text {A }}$ AD | - | - | $\begin{aligned} & 270 \\ & 250 \end{aligned}$ | - | - | $\begin{aligned} & 180 \\ & 165 \end{aligned}$ | - | - | $\begin{aligned} & 150 \\ & 135 \end{aligned}$ | ns |
| Peripheral Read Access Time $t_{a C C}=t_{u t}-\left(t_{A D}+t D S R\right)$ | tacc | 605 | - | - | 400 | - | - | 290 | - | - | ns |
| Data Setup Time (Read) | ${ }^{\text {t }}$ DSR | 100 | - | - | 60 | - | - | 40 | - | - | ns |
| Input Data Hold Time | th | 10 | - | - | 10 | - | - | 10 | - | - | ns |
| Output Data Hold Time | ${ }_{\text {t }}$ | 10 | 25 | - | 10 | 25 | - | 10 | 25 | - | ns |
| Address Hold Time (Address, R/W, VMA) | ${ }_{\text {ta }}$ | 30 | 50 | - | 30 | 50 | - | 30 | 50 | - | ns |
| Enable High Time for DBE Input | ${ }_{\text {teH }}$ | 450 | - | - | 280 | - | - | 220 | - | - | ns |
| Data Delay Time (Write) | tDDW | - | - | 225 | - | - | 200 | - | - | 160 | ns |
| Processor Controls |  |  |  |  |  |  |  |  |  |  |  |
| Processor Control Setup Time | tpes | 200 | - | - | 140 | - | - | 110 | - | - |  |
| Processor Control Rise and Fall Time | ${ }_{\text {tpCr, }}$ tpCf | - | - | 100 | - | - | 100 | - | - | 100 |  |
| Bus Available Delay | ${ }^{\text {I BA }}$ | - | - | 250 | - | - | 165 | - | - | 135 | ns |
| Hi-Z Enable | tTSE | 0 | - | 40 | 0 | - | 40 | 0 | - | 40 | ns |
| Hi-Z Delay | ${ }^{\text {tTSD }}$ | - | - | 270 | - | - | 270 | - | - | 220 |  |
| Data Bus Enable Down Time During $\phi 1$ Up Time | tDBE | 150 | - | - | 120 | - | - | 75 | - | - |  |
| Data Bus Enable Rise and Fall Times | ${ }^{\text {t }}$ DBEr, ${ }^{\text {, }}$ DBEf | - | - | 25 | - | - | 25 | - | - | 25 |  |




Date Not Valid

FIGURE 3 - WRITE IN MEMORY OR PERIPHERALS


## NOTES:

1. Voltage levels shown are $V_{L} \leq 0.4, V_{H} \geqq 2.4 \mathrm{~V}$, unless otherwise specified.
2. Measurement points shown are 0.8 V and 2.0 V , unless otherwise noted.

FIGURE 4 - TYPICAL DATA BUS OUTPUT DELAY versus CAPACITIVE LOADING (TDDW)


FIGURE 5 - TYPICAL READ/WRITE, VMA, AND ADDRESS OUTPUT DELAY versus CAPACITIVE LOADING (TAD)


FIGURE 6 - BUS TIMING TEST LOADS

$C=130 \mathrm{pF}$ for $\mathrm{DO}-\mathrm{DT}, \mathrm{E}$
$=90 \mathrm{pF}$ for $A O-A 15, R / \bar{W}$, and $V M A$ (Except tAD2)
$=30 \mathrm{pF}$ for $A 0-A 15, R \bar{W}$, and $V M A$
(taD2 only)
$=30 \mathrm{pF}$ for BA
$R=11.7 \mathrm{k} \Omega$ for $D 0-D 7$
$=16.5 \mathrm{k} \Omega$ for $A O-A 15, R / \bar{W}$, and $V M A$
$=24 \mathrm{k} \Omega$ for BA

## TEST CONDITIONS

The dynamic test load for the Data Bus is 130 pF and one standard TTL load as shown. The Address, $R / \bar{W}$, and VMA outputs are tested under two conditions to allow optimum operation in both buffered and unbuffered systems. The resistor ( $R$ ) is chosen to insure specified load currents during $V_{O H}$ measurement.

Notice that the Data Bus lines, the Address fines, the Interrupt Request line, and the DBE line are all specified and tested to guarantee 0.4 V of dynamic noise immunity at both " 1 " and " 0 " logic levels.

FIGURE 7 - EXPANDED BLOCK DIAGRAM


## MPU SIGNAL DESCRIPTION

Proper operation of the MPU requires that certain control and timing signals be provided to accomplish specific functions and that other signal lines be monitored to determine the state of the processor.

Clocks Phase One and Phase Two ( $\phi 1, \phi 2$ ) - Two pins are used for a two-phase non-overlapping clock that runs at the $\mathrm{V}_{\mathrm{CC}}$ voltage level.

Figure 1 shows the microprocessor clocks. The high level is specified at $V_{\text {IHC }}$ and the low level is specified at VILC. The allowable clock frequency is specified by $f$ (frequency). The minimum $\phi 1$ and $\phi 2$ high level pulse widths are specified by $\mathrm{PW}_{\phi \mathrm{H}}$ (pulse width high time). To guarantee the required access time for the peripherals, the clock up time, $t_{u t}$, is specified. Clock separation, $t_{d}$, is measured at a maximum voltage of VOV (overlap voltage). This allows for a multitude of clock variations at the system frequency rate.

Address Bus (A0-A15) - Sixteen pins are used for the address bus. The outputs are three-state bus drivers capable of driving one standard TTL load and 90 pF . When the output is turned off, it is essentially an open circuit. This permits the MPU to be used in DMA applications. Putting TSC in its high state forces the Address bus to go into the three-state mode.

Data Bus (D0-D7) - Eight pins are used for the data bus. It is bidirectional, transferring data to and from the memory and peripheral devices. It also has three-state output buffers capable of driving one standard TTL load and 130 pF . Data Bus is placed in the three-state mode when DBE is low.

Data Bus Enable (DBE) - This level sensitive input is the three-state control signal for the MPU data bus and will enable the bus drivers when in the high state. This input is TTL compatible; however in normal operation, it would be driven by the phase two clock. During an MPU read cycle, the data bus drivers will be disabled internally. When it is desired that another device control the data bus, such as in Direct Memory Access (DMA) applications, DBE should be held low.
If additional data setup or hold time is required on an MPU write, the DBE down time can be decreased, as shown in Figure $3(D B E \neq \phi 2)$. The minimum down time for $D B E$ is tDBE as shown. By skewing DBE with respect to $E$, data setup or hold time can be increased.

Bus Available (BA) - The Bus Available signal will normally be in the low state; when activated, it will go to the high state indicating that the microprocessor has stopped and that the address bus is available. This will occur if the HALT line is in the low state or the processor is in the WAIT state as a result of the execution of a WAIT instruction. At such time, all three-state output drivers will go to their off state and other outputs to their normally inactive level. The processor is removed from the WAIT state by the occurrence of a maskable (mask bit I $=0$ ) or nonmaskable interrupt. This output is capable of driving one standard TTL load and 30 pF . If TSC is in the high state, Bus Available will be low.

Read/Write (R/信) - This TTL compatible output signals the peripherals and memory devices wether the MPU is in a

Read (high) or Write (low) state. The normal standby state of this signal is Read (high). Three-State Control going high will turn Read/Write to the off (high impedance) state. Also, when the processor is halted, it will be in the off state. This output is capable of driving one standard TTL load and 90 pF .

RESET - The RESET input is used to reset and start the MPU from a power down condition resulting from a power failure or initial start-up of the processor. This level sensitive input can also be used to reinitialize the machine at any time after start-up.

If a high level is detected in this input, this will signal the MPU to begin the reset sequence. During the reset sequence, the contents of the last two locations (FFFE, FFFF) in memory will be loaded into the Program Counter to point to the beginning of the reset routine. During the reset routine, the interrupt mask bit is set and must be cleared under program control before the MPU can be interrupted by IRQ. While RESET is low lassuming a minimum of 8 clock cycles have occurred) the MPU output signals will be in the following states: $V M A=$ low, $B A=$ low, Data $B u s=$ high impedance, $\mathrm{R} / \bar{W}=$ high (read state), and the Address Bus will contain the reset address FFFE. Figure 8 illustrates a power up sequence using the RESET control line. After the power supply reaches 4.75 V , a minimum of eight clock cycles are required for the processor to stabilize in preparation for restarting. During these eight cycles, VMA will be in an indeterminate state so any devices that are enabled by VMA which could accept a false write during this time (such as battery-backed RAM) must be disabled until VMA is forced low after eight cycles. $\overline{\text { RESET can go high asynchronously }}$ with the system clock any time after the eighth cycle.
$\overline{\text { RESET }}$ timing is shown in Figure 8. The maximum rise and fall transition times are specified by tPCr and tPCf. If $\overline{R E S E T}$ is high at tPCS (processor control setup time), as shown in Figure 8, in any given cycle then the restart sequence will begin on the next cycle as shown. The RESET control line may also be used to reinitialize the MPU system at any time during its operation. This is accomplished by pulsing RESET low for the duration of a minimum of three complete $\phi 2$ cycles. The RESET pulse can be completely asynchronous with the MPU system clock and will be recognized during $\phi 2$ if setup time tPCS is met.

Interrupt Request ( $\overline{\mathrm{RQ}}$ ) - This level sensitive input requests that an interrupt sequence be generated within the machine. The processor will wait until it completes the current instruction that is being executed before it recognizes the request. At that time, if the interrupt mask bit in the Condition Code Register is not set, the machine will begin an interrupt sequence. The Index Register, Program Counter, Accumulators, and Condition Code Register are stored away on the stack. Next, the MPU will respond to the interrupt request by setting the interrupt mask bit high so that no further interrupts may occur. At the end of the cycle, a 16 -bit address will be loaded that points to a vectoring address which is located in memory locations FFF8 and FFF9. An address loaded at these locations causes the MPU to branch to an interrupt routine in memory. Interrupt timing is shown in Figure 9.

$\triangle 1 \ D]=$ indeterminate
FIGURE 9 - INTERRUPT TIMING


The $\overline{\text { HALT }}$ line must be in the high state for interrupts to be serviced. Interrupts will be latched internally while HALT is low.

The $\overline{\mathrm{IRQ}}$ has a high-impedance pullup device internal to the chip; however, a $3 \mathrm{k} \Omega$ external resistor to $\mathrm{V}_{\mathrm{CC}}$ should be used for wire-OR and optimum control of interrupts.

Non-Maskable Interrupt ( $\overline{\mathrm{NMI} \text { ) and Wait for Interrupt }}$ (WAI) - The MC6800 is capable of handling two types of interrupts: maskable ( $\overline{\mathrm{RQ}}$ ) as described earlier, and nonmaskable ( $\overline{\mathrm{NM}}$ ) which is an edge sensitive input. IRO is maskable by the interrupt mask in the condition code register while $\overline{N M I}$ is not maskable. The handling of these interrupts by the MPU is the same except that each has its own vector address. The behavior of the MPU when interrupted is shown in Figure 9 which details the MPU response to an interrupt while the MPU is executing the control program. The interrupt shown could be either $\overline{\mathrm{RO}}$ or $\overline{\mathrm{NMI}}$ and can be asynchronous with respect to $\phi 2$. The interrupt is shown going low at time tpCS in cycle \#1 which precedes the first cycle of an instruction (OP code fetch). This instruction is not executed but instead the Program Counter (PC), Index Register (IX), Accumulators (ACCX), and the Condition Code Register (CCR) are pushed onto the stack.

The Interrupt Mask bit is set to prevent further interrupts. The address of the interrupt service routine is then fetched from FFFC, FFFD for an NMI interrupt and from FFF8, FFF9 for an $\overline{\mathrm{RQ}}$ interrupt. Upon completion of the interrupt service routine, the execution of RTI will pull the PC, IX, ACCX, and CCR off the stack; the Interrupt Mask bit is restored to its condition prior to Interrupts (see Figure 10).

Figure 11 is a similar interrupt sequence, except in this case, a WAIT instruction has been executed in preparation for the interrupt. This technique speeds up the MPU's response to the interrupt because the stacking of the PC, IX, ACCX, and the CCR is already done. While the MPU is waiting for the interrupt, Bus Available will go high indicating the following states of the control lines: VMA is low, and the Address Bus, R//W and Data Bus are all in the high impedance state. After the interrupt occurs, it is serviced as previously described.

A 3-10 kS external resistor to VCC should be used for wireOR and optimum control of interrupts.

## MEMORY MAP FOR INTERRUPT VECTORS

| Vector |  | Description |
| :---: | :---: | :---: |
| MS | LS |  |
| FFFE | FFFF | Reset |
| FFFC | FFFD | Non-Maskable Interrupt |
| FFFA | FFFB | Software Interrupt |
| FFF8 | FFF9 | Interrupt Request |

Refer to Figure 10 for program flow for Interrupts.
Three-State Control (TSC) - When the level sensitive Three-State Control (TSC) line is a logic " 1 ", the Address Bus and the $R / \bar{W}$ line are placed in a high-impedance state. VMA and BA are forced low when TSC="1" to prevent false reads or writes on any device enabled by VMA. It is necessary to delay program execution while TSC is held high. This is done by insuring that no transitions of $\phi 1$ (or $\phi 2$ ) occur during this period. (Logic levels of the clocks are irrelevant so long as they do not change). Since the MPU is a dynamic device, the $\phi 1$ clock can be stopped for a maximum
time $\mathrm{PW}_{\phi H}$ without destroying data within the MPU. TSC then can be used in a short Direct Memory Access (DMA) application.
Figure 12 shows the effect of TSC on the MPU. TSC must have its transitions at tTSE (three-state enable) while holding $\phi 1$ high and $\phi 2$ low as shown. The Address Bus and $\mathrm{R} / \overline{\mathrm{W}}$ line will reach the high-impedance state at tTSD (three-state delay), with VMA being forced low. In this example, the Data Bus is also in the high-impedance state while $\phi 2$ is being heid low since $D B E=\phi 2$. At this point in time, a DMA transfer could occur on cycles \#3 and \#4. When TSC is returned low, the MPU Address and R/W lines return to the bus. Because it is too late in cycle \#5 to access memory, this cycle is dead and used for synchronization. Program execution resumes in cycle \#6.

Valid Memory Address (VMA) - This output indicates to peripheral devices that there is a valid address on the address bus. In normal operation, this signal should be utilized for enabling peripheral interfaces such as the PIA and ACIA. This signal is not three-state. One standard TTL load and 90 pF may be directly driven by this active high signal.
$\overline{\text { HALT }}$ - When this level sensitive input is in the low state, all activity in the machine will be halted. This input is level sensitive.
The $\overline{H A L T}$ iine provides an input to the MPU to allow control of program execution by an outside source. If HALT is high, the MPU will execute the instructions; if it is low, the MPU will go to a halted or idle mode. A response signal, Bus Available (BA) provides an indication of the current MPU status. When BA is low, the MPU is in the process of executing the control program; if BA is high, the MPU has halted and all internal activity has stopped.

When BA is high, the Address Bus, Data Bus, and R/W line will be in a high-impedance state, effectively removing the MPU from the system bus. VMA is forced low so that the floating system bus will not activate any device on the bus that is enabled by VMA.

While the MPU is halted, all program activity is stopped, and if either an $\overline{\mathrm{NMI}}$ or $\overline{\mathrm{RO}}$ interrupt occurs, it will be latched into the MPU and acted on as soon as the MPU is taken out of the halted mode. If a RESET command occurs while the MPU is halted, the following states occur: $V M A=$ low, $B A=$ low, Data Bus = high impedance, $R / \bar{W}=$ high (read state), and the Address Bus will contain address FFFE as long as $\overline{\text { RESET }}$ is low. As soon as the $\overline{\text { RESET }}$ line goes high, the MPU will go to locations FFFE and FFFF for the address of the reset routine.

Figure 13 shows the timing relationships involved when halting the MPU. The instruction illustrated is a one byte, 2 cycle instruction such as CLRA. When HALT goes low, the MPU will halt after completing execution of the current instruction. The transition of $\overline{\mathrm{HALT}}$ must occur tPCS before the trailing edge of $\phi 1$ of the last cycle of an instruction (point A of Figure 13). HALT must not go low any time later than the minmum tPCS specified.
The fetch of the OP code by the MPU is the first cycle of the instruction. If $\overline{H A L T}$ had not been low at Point $A$ but went low during $\phi 2$ of that cycle, the MPU would have halted after completion of the following instruction. BA will go high by time tBA (bus available delay time) after the last instruction cycle. At this point in time, VMA is low and $R / \bar{W}$, Address Bus, and the Data Bus are in the high-impedance state.

To debug programs it is advantageous to step through programs instruction by instruction. To do this, HALT must be brought high for one MPU cycle and then returned low as shown at point $B$ of Figure 13. Again, the transitions of HALT must occur tpCS before the trailing edge of $\phi 1$. BA will go low at tBA after the leading edge of the next $\phi 1$, indicating that the Address Bus, Data Bus, VMA and R/W
lines are back on the bus. A single byte, 2 cycle instruction such as LSR is used for this example also. During the first cycle, the instruction $Y$ is fetched from address $M+1$. $B A$ returns high at tBA on the last cycle of the instruction indicating the MPU is off the bus. If instruction $Y$ had been three cycles, the width of the BA low time would have been increased by one cycle.

FIGURE 10 - MPU FLOWCHART



FIGURE 13 - $\overline{\text { HALT AND SINGLE INSTRUCTION EXECUTION FOR SYSTEM DEBUG }}$


## MPU REGISTERS

The MPU has three 16 -bit registers and three 8 -bit registers available for use by the programmer (Figure 14).

Program Counter - The program counter is a two byte (16 bits) register that points to the current program address.

Stack Pointer - The stack ponter is a two byte register that contains the address of the next available location in an external push-down/pop-up stack. This stack is normally a random access Read/Write memory that may have any location (address) that is convenient. In those applications that require storage of information in the stack when power is lost, the stack must be nonvolatile.

Index Register - The index register is a two byte register that is used to store data or a sixteen bit memory address for the Indexed mode of memory addressing.

Accumulators - The MPU contains two 8-bit accumulators that are used to hold operands and results from an arithmetic logic unit (ALU).

Condition Code Register - The condition code register indicates the results of an Arithmetic Logic Unit operation: Negative (N), Zero (Z), Overflow (V), Carry from bit 7 (C), and half carry from bit $3(\mathrm{H})$. These bits of the Condition Code Register are used as testable conditions for the conditional branch instructions. Bit 4 is the interrupt mask bit (I). The unused bits of the Condition Code Register (b6 and b7) are ones.

FIGURE 14 - PROGRAMMING MODEL OF THE MICROPROCESSING UNIT


The MC6800 instructions are described in detail in the M6800 Programming Manual. This Section will provide a brief introduction and discuss their use in developing MC6800 control programs. The MC6800 has a set of 72 different executable source instructions. Included are binary and decimal arithmetic, logical, shift, rotate, load, store, conditional or unconditional branch, interrupt and stack manipulation instructions.

Each of the 72 executable instructions of the source language assembles into 1 to 3 bytes of machine code. The number of bytes depends on the particular instruction and on the addressing mode. (The addressing modes which are available for use with the various executive instructions are discussed later.)

The coding of the first (or only) byte corresponding to an executable instruction is sufficient to identify the instruction and the addressing mode. The hexadecimal equivalents of the binary codes, which result from the translation of the 72 instructions in all valid modes of addressing, are shown in Table 1. There are 197 valid machine codes, 59 of the 256 possible codes being unassigned.

When an instruction translates into two or three bytes of code, the second byte, or the second and third bytes contain(s) an operand, an address, or information from which an address is obtained during execution.

Microprocessor instructions are often divided into three general classifications: (1) memory reference, so called because they operate on specific memory locations; (2) operating instructions that function without needing a memory reference; (3) I/O instructions for transferring data between the microprocessor and peripheral devices.

In many instances, the MC6800 performs the same operation on both its internal accumulators and the external memory locations. In addition, the MC6800 interface adapters (PIA and ACIA) allow the MPU to treat peripheral devices exactly like other memory locations, hence, no l/O instructions as such are required. Because of these features, other classifications are more suitable for introducing the MC6800's instruction set: (1) Accumulator and memory operations; (2) Program control operations; (3) Condition Code Register operations.

TABLE 1 - HEXADECIMAL VALUES OF MACHINE CODES

| 00 | - |  |  | 40 | NEG | A |  | 80 | SUB | A | IMM | CO | SUB | B | IMM |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 01 | NOP |  |  | 41 |  |  |  | 81 | CMP | A | IMM | C1 | CMP | B | IMM |
| 02 |  |  |  | 42 | - |  |  | 82 | SBC | A | IMM | C2 | SBC | B | /MM |
| 03 | - |  |  | 43 | COM | A |  | 83 |  |  |  | C3 |  |  |  |
| 04 | - |  |  | 44 | LSR | A |  | 84 | AND | A | IMM | C4 | AND | 8 | IMM |
| 05 | $\cdot$ |  |  | 45 |  |  |  | 85 | BIT | A | IMM | C5 | BIT | B | IMM |
| 06 | TAP |  |  | 46 | ROR | A |  | 86 | LDA | A | IMM | C6 | LDA | B | MM |
| 07 | TPA |  |  | 47 | ASR | A |  | 87 |  |  |  | C7 |  |  |  |
| 08 | INX |  |  | 48 | ASL | A |  | 88 | EOR | A | IMM | C8 | EOA | 日 | IMM |
| 09 | DEX |  |  | 49 | ROL | A |  | 89 | ADC | A | IMM | C9 | ADC | 8 | IMM |
| OA | CLV |  |  | 4 A | DEC | A |  | 8A | ORA | A | IMM | ca | ORA | B | IMM |
| OB | SEV |  |  | 4 B |  |  |  | 8 B | ADD | A | IMM | CB | ADD | B | IMM |
| OC | CLC |  |  | 4 C | INC | A |  | 8 C | CPX | A | IMM | CC |  |  |  |
| OD | SEC |  |  | 4 D | TST | A |  | 8D | BSR |  | REE | CD | $\cdot$ |  |  |
| OE | CLI |  |  | 4 E |  |  |  | 8 E | LDS |  | MMM | CE | LDX |  | IMM |
| OF | SEI |  |  | 4 F | CLR | A |  | 8 F |  |  |  | CF |  |  |  |
| 10 | SBA |  |  | 50 | NEG | B |  | 90 | SUB | A | DIR | DO | SUB | B | DIR |
| 11 | CBA |  |  | 51 |  |  |  | 91 | CMP | A | DIA | D1 | CMP | B | DIR |
| 12 |  |  |  | 52 | * |  |  | 92 | SBC | A | Dir | D2 | SBC | B | DIR |
| 13 | - |  |  | 53 | COM | B |  | 93 |  |  |  | D3 |  |  |  |
| 14 | * |  |  | 54 | LSR | B |  | 94 | AND | A | DIR | D4 | AND | B | DIR |
| 15 |  |  |  | 55 |  |  |  | 95 | at | A | DIR | D5 | BIT | B | DIR |
| 16 | TAB |  |  | 56 | ROR | B |  | 96 | LDA | A | DIR | D6 | LDA | B | DIR |
| 17 | TBA |  |  | 57 | ASR | B |  | 97 | STA | A | DIR | D7 | STA | B | DIR |
| 18 | * |  |  | 58 | ASL | B |  | 98 | EOR | A | DIR | D8 | EOR | B | DIR |
| 19 | DAA |  |  | 59 | ROL | B |  | 98 | ADC | A | DIR | D9 | ADC | B | DIR |
| 1A |  |  |  | 5A | DEC | B |  | 9A | ORA | A | DIR | DA | ORA | B | DIR |
| 1B | ABA |  |  | 5B |  |  |  | 98 | ADD | A | DIR | DB | ADD | B | DIR |
| 1 C |  |  |  | 5 C | INC | 8 |  | 9 C | CPX |  | DIR | DC |  |  |  |
| 1 D | - |  |  | 5D | TST | $\theta$ |  | 9 D | + |  |  | DD | - |  |  |
| 15 |  |  |  | 5E |  |  |  | $9 E$ | LDS |  | DIR | DE | LDX |  | DIR |
| 1F | - |  |  | 5 F | CLR | B |  | 9 F | STS |  | DIR | DF | STX |  | DIR |
| 20 | BRA |  | REL | 60 | NEG |  | IND | AO | SUB | A | IND | E0 | SUB | B | IND |
| 21 |  |  |  | 61 |  |  |  | A1 | CMP | A | IND | E1 | CMP | B | IND |
| 22 | BHI |  | REL | 62 | - |  |  | A2 | SBC | A | IND | E2 | SBC | B | IND |
| 23 | BLS |  | REL | 63 | COM |  | IND | A3 |  |  |  | E3 | * |  |  |
| 24 | BCC |  | REL | 64 | LSR |  | IND | A4 | AND | A | IND | E4 | AND | B | ind |
| 25 | BCS |  | REL | 65 |  |  |  | A5 | BIT | A | IND | E5 | BiT | B | IND |
| 26 | BNE |  | REL | 66 | ROR |  | IND | A6 | LDA | A | IND | E6 | LDA | B | IND |
| 27 | BEQ |  | REL | 67 | ASR |  | IND | A7 | STA | A | IND | E7 | STA | B | IND |
| 28 | BVC |  | REL | 68 | ASL |  | IND | AB | EOR | A | IND | E8 | EOR | B | IND |
| 29 | BVS |  | REL | 69 | ROL |  | IND | A9 | ADC | A | IND | E9 | ADC | B | IND |
| 2A | BPL |  | REL | 6 A | DEC |  | IND | AA | ORA | A | IND | EA | ORA | B | IND |
| 2 B | BMI |  | REL | 6B |  |  |  | AB | ADD | A | IND | EB | ADD | B | IND |
| 2 C | BGE |  | REL | 6 C | INC |  | IND | $A C$ | CPX |  | ind | EC |  |  |  |
| 2 D | BLT |  | REL | 60 | TST |  | IND | $A D$ | JSR |  | IND | ED |  |  |  |
| 2 E | BGT |  | REL | $6 E$ | JMP |  | IND | AE | LDS |  | IND | EE | LDX |  | IND |
| 2 F | BLE |  | REL | 6F | CLR |  | IND | AF | STS |  | IND | EF | STX |  | IND |
| 30 | TSX |  |  | 70 | NEG |  | EXT | B0 | SUB | A | EXT | F0 | SUB | B | EXT |
| 31 | !NS |  |  | 71 |  |  |  | B1 | CMP | A | EXT | F1 | CMP | B | EXT |
| 32 | PUL | A |  | 72 | - |  |  | B2 | SBC | A | EXT | F2 | SBC | B | EXT |
| 33 | PUL | B |  | 73 | COM |  | EXT | B3 |  |  |  | F3 |  |  |  |
| 34 | DES |  |  | 74 | LSR |  | EXT | B4 | AND | A | EXT | F4 | AND | B | EXT |
| 35 | TXS |  |  | 75 |  |  |  | B5 | BIT | A | EXT | F5 | BIT | B | EXT |
| 36 | PSH | A |  | 76 | ROR |  | EXT | B6 | LDA | A | EXT | F6 | LDA | B | EXT |
| 37 | PSH | B |  | 77 | ASR |  | EXT | B7 | STA | A | EXT | F7 | STA | B | EXT |
| 38 |  |  |  | 78 | ASL |  | EXT | B8 | EOR | A | EXT | F8 | EOR | B | EXT |
| 39 | RTS |  |  | 79 | ROL |  | EXT | B9 | ADC | A | EXT | F9 | ADC | B | EXT |
| 3A | $\cdots$ |  |  | 7 A | DEC |  | EXT | BA | ORA | A | EXT | FA | ORA | B | EXT |
| 3B | RTI |  |  | 7 B |  |  |  | BB | ADD | A | EXT | FB | ADD | B | EXT |
| 3 C | - |  |  | 7 C | INC |  | EXT | BC | CPX |  | EXT | FC |  |  |  |
| 3D |  |  |  | 70 | TST. |  | EXT | BD | JSR |  | EXT | FD | * |  |  |
| 3E | WAI |  |  | $7 E$ | JMP |  | EXT | BE | LDS |  | EXT | FE | LDX |  | EXT |
| 3 F | SWI |  |  | 7 F | CLR |  | EXT | BF | STS |  | EXT | FF | STX |  | EXT |

Notes: 1. Addressing Modes:

| A | $=$ Accumulator A |
| :--- | :--- |
| B | $=$ Accumulator B |
| REL | $=$ Relative |
| IND | Indexed |
| IMM | $=$ Immediate |
| DIR | $=$ Direct |

[^0]TABLE 2 - ACCUMULATOR AND MEMORY OPERATIONS

| DPERATIDNS | MNEMONIC | ADDRESSING MODES |  |  |  |  |  |  |  |  |  |  |  |  |  |  | BODLEAN/ARITHMETIC DPERATIDN COND. CODE REG. |  |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | IMMED |  |  | DIRECT |  |  | INDEX |  |  | EXTND |  |  | IMPLIED |  |  | (All register labels refer to contents) | 5 | 4 | 3 | 2 | 1 | 0 |
|  |  | DP | $\sim$ | $=$ | OP | $\sim$ | $=$ | OP | $\sim$ | $=$ | OP | $\sim$ | $=$ | OP | - | $=$ |  | H | 1 | N | Z | v | C |
| Add | ADDA | 8B | 2 | 2 | 9B | 3 | 2 | $A B$ | 5 | 2 |  | 4 | 3 |  |  |  | $A+M \rightarrow A$ | $\uparrow$ | - | 1 | 1 | $\dagger$ | $\ddagger$ |
|  | ADDB | CB | 2 | 2 | DB | 3 | 2 | EB | 5 | 2 |  | 4 | 3 |  |  |  | $B+M \rightarrow B$ | $\uparrow$ | - | $\vdots$ | $\ddagger$ | $\dagger$ | $\ddagger$ |
| Add Acmlirs | ABA |  |  |  |  |  |  |  |  |  |  |  |  | 1B | 2 | 1 | $A+B \rightarrow A$ | 1 | - | : | 1 | $\pm$ | 1 |
| Add with Carry | ADCA | . 89 | 2 | 2 | 99 | 3 | 2 | A9 | 5 | 2 |  | 4 | 3 |  |  |  | $A+M+C \rightarrow A$ | $\ddagger$ | - | $\pm$ | $\uparrow$ | $\ddagger$ | $\pm$ |
|  | ADCB | Cg | 2 | 2 | D9 | 3 | 2 | E9 | 5 | 2 |  | 4 | 3 |  |  |  | $B+M+C \rightarrow B$ | $\dagger$ | - | $\pm$ | $\uparrow$ | $\ddagger$ | j |
| And | ANDA | 84 | 2 | 2 | 94 | 3 | 2 |  | 5 | 2 |  | 4 | 3 |  |  |  | $A \cdot M \sim A$ | - | - | t | $\uparrow$ | R | - |
|  | ANDB | C4 | 2 | 2 | 04 | 3 | 2 | E4 | 5 | 2 |  | 4 | 3 |  |  |  | $B-M \sim B$ | - | - | 1 | $\ddagger$ | R | - |
| Bit Test | BITA | 85 | 2 | 2 | 95 | 3 | 2 |  | 5 | 2 |  | 4 | 3 |  |  |  | A. M | - | - | $\ddagger$ | $\dagger$ | R | - |
|  | BITB | C5 | 2 | 2 | D5 | 3 | 2 | E5 | 5 | 2 |  | 4 | 3 |  |  |  | B. M | - | - | $\uparrow$ | $\uparrow$ | R | - |
| Clear | CLR |  |  |  |  |  |  |  | 7 | 2 |  | 6 | 3 |  |  |  | $00 \rightarrow \mathrm{M}$ | - | - | R | S | R | R |
|  | CLRA |  |  |  |  |  |  |  |  |  |  |  |  | 4 F | 2 | 1 | $00 \rightarrow A$ | - | - | R | S | R | R |
|  | CLRB |  |  |  |  |  |  |  |  |  |  |  |  | 5 F | 2 | 1 | $00 \rightarrow 8$ | - | - | R | S | R | R |
| Compare | CMPA | 81 | 2 | 2 | 91 | 3 | 2 | A1 | 5 | 2 | B1 | 4 | 3 |  |  |  | A - M | - | - | 1 | $\uparrow$ | : | $\ddagger$ |
|  | CMPB | 61 | 2 | 2 | D1 | 3 | 2 | E1 | 5 | 2 | F1 | 4 | 3 |  |  |  | $B-M$ | - | - | 1 | : |  | 1 |
| Compare Acmitrs | CBA |  |  |  |  |  |  |  |  |  |  |  |  | 11 | 2 | 1 | A - B | - | - | : | $\pm$ | $t$ | 1 |
| Complement, I's | COM |  |  |  |  |  |  | 63 | 7 | 2 | 73 | 6 | 3 |  |  |  | $\bar{M} \rightarrow M$ | - | - | 1 | $\because$ | R | S |
|  | COMA |  |  |  |  |  |  |  |  |  |  |  |  | 43 | 2 | 1 | $\bar{A} \rightarrow A$ | - | - | : | $\because$ | R | S |
|  | COMB |  |  |  |  |  |  |  |  |  |  |  |  | 53 | 2 | 1 | $\overline{\mathrm{B}} \rightarrow \mathrm{B}$ | - | - | : | : | 8 | S |
| Complement, 2's (Negate) | NEG |  |  |  |  |  |  | 60 | 7 | 2 | 70 | 6 | 3 |  |  |  | 00-M $\rightarrow \mathrm{M}$ | - | - | : | : | (1) | (2) |
|  | NEGA |  |  |  |  |  |  |  |  |  |  |  |  | 40 | 2 | 1 | $00-A \rightarrow A$ | - | - | : | $\bigcirc$ | (1) | (2) |
|  | NEGB |  |  |  |  |  |  |  |  |  |  |  |  | 50 | 2 | 1 | $00-B \rightarrow B$ | - | - | $\ddagger$ | $\bigcirc$ |  | (2) |
| Decimal Adjust, A | DAA |  |  |  |  |  |  |  |  |  |  |  |  | 19 | 2 | 1 | Converts Binary Add. of BCD Characters into $B C D$ Format | - | - | $!$ | $\checkmark$ | $\ddagger$ | (3) |
| Decrement | DEC |  |  |  |  |  |  | 64 | 7 | 2 | 7 A | 6 | 3 |  |  |  | $\mathrm{M}-1 \rightarrow \mathrm{M}$ | - | - | $\div$ | $\uparrow$ | 4 | - |
|  | DECA |  |  |  |  |  |  |  |  |  |  |  |  | 4A | 2 | 1 | $A-1 \rightarrow A$ | - | - | t | $\uparrow$ | 4 | - |
|  | DECB |  |  |  |  |  |  |  |  |  |  |  |  | 5A | 2 | 1 | $B-1 \rightarrow B$ | - | - | $\pm$ | 1 | 4 | - |
| Exclusive OR | EORA | 88 | 2 | 2 | 98 | 3 | 2 | A8 | 5 | 2 | B8 | 4 | 3 |  |  |  | $A ¢ M \rightarrow A$ | - | - | t | $\ddagger$ | R | - |
|  | EORB | C8 | 2 | 2 | D8 | 3 | 2 | E8 | 5 | 2 |  | 4 | 3 |  |  |  | $B \oplus \sim \cdot 8$ | - | - | I | $\uparrow$ | A | - |
| Increment | INC |  |  |  |  |  |  |  | 7 | 2 |  | 6 | 3 |  |  |  | M-1-M | - | - | $t$ | $\ddagger$ | (5) | - |
|  | INCA |  |  |  |  |  |  |  |  |  |  |  |  | 4 C | 2 | 1 | $A=1-A$ | - | - | $t$ | $\ddagger$ | (5) | - |
|  | INCB |  |  |  |  |  |  |  |  |  |  |  |  | 5 C | 2 | 1 | $B+1 \cdot 3$ | - | - | $t$ | $\ddagger$ | (5) | - |
| Load Acmitr | LDAA | 86 | 2 | 2 | 96 | 3 | 2 | A6 | 5 | 2 | B6 | 4 | 3 |  |  |  | in $A$ | - | - | $\ddagger$ | $\ddagger$ | $R$ | - |
|  | LDAB | C6 | 2 | 2 | D6 | 3 | 2 | E6 | 5 | 2 | F6 | 4 | 3 |  |  |  | $\cdots \cdots 8$ | - | - | $\ddagger$ | $\dagger$ | R | - |
| Or, Inclusive | ORAA | 8 A | 2 | 2 | 9A | 3 | 2 | AA | 5 | 2 |  | 4 | 3 |  |  |  | $A+i n \rightarrow A$ | - | - | $t$ | $\dagger$ | R | - |
|  | ORAB | CA | 2 | 2 | DA | 3 | 2 | EA | 5 | 2 | FA | 4 | 3 |  |  |  | $3+M \rightarrow B$ | - | - | 1 | $\uparrow$ | R | - |
| Push Data | PSHA |  |  |  |  |  |  |  |  |  |  |  |  | 36 | 4 | 1 | $A \rightarrow M_{S P}, S P-1 \rightarrow S P$ | - | - | - | - | - | - |
|  | PSHB |  |  |  |  |  |  |  |  |  |  |  |  | 37 | 4 | 1 | $B \rightarrow \mathrm{M}_{\text {SP }}, \mathrm{SP}-1 \rightarrow$ SP | - | - | - | - | - | - |
| Pull Datà | PULA |  |  |  |  |  |  |  |  |  |  |  |  | 32 | 4 | 1 | $\mathrm{SP}+1 \rightarrow \mathrm{SF}, \mathrm{M}_{\mathrm{SP}} \rightarrow \mathrm{A}$ | - | - | - | $\bullet$ | - | - |
|  | PULB |  |  |  |  |  |  |  |  |  |  |  |  | 33 | 4 | 1 | $S P+1 \rightarrow S P, M_{S P} \rightarrow B$ | - | - | - | - | - | - |
| Rotate Left | ROL |  |  |  |  |  |  | 69 | 7 | 2 | 79 | 6 | 3 |  |  |  | M - | - | - | $\pm$ | $\downarrow$ | (6) | 1 |
|  | ROLA |  |  |  |  |  |  |  |  |  |  |  |  | 49 | 2 | 1 | A $\square \square \square \square 1+12-$ | - | - | 1 | 1 | (6) | $\ddagger$ |
|  | ROLB |  |  |  |  |  |  |  |  |  |  |  |  | 59 | 2 | 1 | B $C \quad b 7-b 0$ | - | - | 1 | $\uparrow$ | ( ${ }^{\text {B }}$ | 1 |
| Rotate Right | ROR |  |  |  |  |  |  | 66 | 7 | 2 | 76 | 6 | 3 |  |  |  | M | - | - | 1 | $\dagger$ | (b) | 1 |
|  | RORA |  |  |  |  |  |  |  |  |  |  |  |  | 46 | 2 | 1 | A $\rightarrow \square \rightarrow \square \square 11$. | - | - | 1 | - | (b) | 1 |
|  | RORB |  |  |  |  |  |  |  |  |  |  |  |  | 56 | 2 | 1 | B $C$ b $\mathrm{C}^{\text {c }}$ - b0 | - | - | 1 | - | (6) | 1 |
| Shiit Left, Arithmetic | ASL |  |  |  |  |  |  | 88 | 7 | 2 | 78 | 6 | 3 |  |  |  | M - - | - | - | t | $\dagger$ | (6) | 1 |
|  | ASLA |  |  |  |  |  |  |  |  |  |  |  |  | 48 | 2 | 1 | A $\square^{\square} \rightarrow \square \square \square \square \square-0$ | - | - | $\pm$ | 1 | (6) | 1 |
|  | ASLB |  |  |  |  |  |  |  |  |  |  |  |  | 58 | 2 | 1 | B $\quad \mathrm{C}$ b7 ${ }^{\text {b }}$ | - | - | ; | $\ddagger$ | (b) | $t$ |
| Shift Right, Arithmetic | ASR |  |  |  |  |  |  | 61 | 7 | 2 | 77 | 6 | 3 |  |  |  | $\mathrm{M} \rightarrow \square \rightarrow$ | - | - | - | 1 | ( | 1 |
|  | ASRA |  |  |  |  |  |  |  |  |  |  |  |  | 47 | 2 | 1 | A\} - - 11111D $-\square$ | - | - | $t$ | $\ddagger$ | (6) | $\ddagger$ |
|  | ASR 3 |  |  |  |  |  |  |  |  |  |  |  |  | 57 | 2 | 1 | B b7 bo c | - | - | $t$ | 1 | (6) | 1 |
| Shitt Right, Logic | LSR |  |  |  |  |  |  | 64 | 7 | 2 | 74 | 6 | 3 |  |  |  | $\mathrm{M} \rightarrow$ | - | - | R | $\ddagger$ | (b) | $\pm$ |
|  | LSRA |  |  |  |  |  |  |  |  |  |  |  |  | 44 | 2 | 1 | A\} $0 \rightarrow \square \square \square \square \square \square 0$ | - | - | R | $\ddagger$ | (6) | $\ddagger$ |
|  | LSRB |  |  |  |  |  |  |  |  |  |  |  |  | 54 | 2 | 1 | B bl bo c | - | - | R | 7 | (6) | 1 |
| Store Acmitr. | STAA |  |  |  | 97 | 4 | 2 | A7 | 6 | 2 | B7 | 5 | 3 |  |  |  | $A \rightarrow M$ | - | - | 1 | $\ddagger$ | R | - |
|  | Stab |  |  |  | D7 | 4 | 2 | E7 | 6 | 2 |  | 5 | 3 |  |  |  | $B \rightarrow M$ | - | - | $\ddagger$ | $\ddagger$ | R | - |
| Subtract | Suba | 80 | 2 | 2 | 90 | 3 | 2 | AD | 5 | 2 |  | 4 | 3 |  |  |  | $A-M \rightarrow A$ | - | - | 1 | $\ddagger$ | $\pm$ | 1 |
|  | SUBB | CO | 2 | 2 | D0 | 3 | 2 | EO | 5 | 2 | F0 | 4 | 3 |  |  |  | $B-M \rightarrow B$ | - | - | 1 | $\ddagger$ | $\uparrow$ | 1 |
| Subtract Acmitrs. | SBA |  |  |  |  |  |  |  |  |  |  |  |  | 10 | 2 | 1 | $A-B \rightarrow A$ | - | - | 1 | $\ddagger$ | $\tau$ | 1 |
| Subtr with Carry | SBCA |  |  |  | 92 | 3 | 2 | A2 | 5 | 2 |  | 4 | 3 |  |  |  | $A-M \rightarrow C \rightarrow A$ | - | - | 1 | $\hat{*}$ | $t$ | 1 |
|  | Sbcb | C2 | 2 | 2 | D2 | 3 | 2 | E2 | 5 | 2 | F2 | 4 | 3 |  |  |  | $B-M-C \rightarrow B$ | - | - | 1 | $t$ | $t$ | 1 |
| Transfer Acmitrs | TAB |  |  |  |  |  |  |  |  |  |  |  |  | 16 | 2 | 1 | $A \rightarrow B$ | - | - | 1 | $\ddagger$ | R | - |
|  | TBA |  |  |  |  |  |  |  |  |  |  |  |  | 17 | 2 | 1 | $B \rightarrow A$ | - | - | 1 | $\hat{*}$ | R | - |
| Test, Zero ar Minus | TST |  |  |  |  |  |  | 60 | 7 | 2 | 70 | 6 | 3 |  |  |  | M-00 | - | - | 1 | : | R | R |
|  | TSTA |  |  |  |  |  |  |  |  |  |  |  |  | 40 | 2 | 1 | A - 00 | - | - | 1 | $\uparrow$ | R | R |
|  | TSTB |  |  |  |  |  |  |  |  |  |  |  |  | 50 | 2 | 1 | $B-00$ | - | - | 1 | 4 | R | R |
|  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  | H | 1 | N | 2 | V | C |

## LEGEND:

OP Operation Code (Hexadecimal)
Number of MPU Cycles:

* Number of Program Bytes
+ Arithmetic Plus;
Arithmetic Minus
Boolean AND;
MSP Contents of memory location pointed to be Stack Pointer
$+\quad$ Boolean Inclusive 0 R;
$\oplus$ Boolean Exclusive DR;
M Complement of $M$
$\rightarrow \quad$ Transfer Into:
$0 \quad$ Bit $=$ Zero;
00 Byte = Zero:
Byte $=$ Zer ;
condition code symbols:
Interrupt mask
Negative (sign bit)
Zero (byte)
Overflow, 2's complement
Carry frombit 7
Reset Always
Set Always
Test and set if true, cleared otherwise
Not Alfected

```
```

```
Half-carry from bit 3;
```

```
```

Half-carry from bit 3;

```
\(\begin{array}{ll}\text { I Interrupt mask } \\ \mathrm{N} & \text { Negative (sign bit) }\end{array}\)
Z Zero (byte)
C Carry frombit 7
\(S\) Set Always
```

$\ddagger$ Test and set it true, cleared otherwise $\quad 5$

```

CONDITION CODE REGISTER NDTES:
(Bit set if test is true and cleared otherwise)
\begin{tabular}{lll}
1 & (Bit V) & Test: Result \(=10000000\) ? \\
2 & (Bit C) & Test: Result \(=00000000\) ? \\
3 & (Bit C) & \begin{tabular}{l} 
Test: Decimal value of most significant BCD \\
Character greater than nine?
\end{tabular} \\
& & \begin{tabular}{l} 
(Not cleared if previously set.)
\end{tabular} \\
4 & (Bit V) & Test: Operand = 10000000 prior to execution? \\
5 & (Bit V) & Test: Operand \(=0111111\) prior to execution? \\
6 & (Bit V) & Test: Set equal to result of N@C after shift has occurred.
\end{tabular}
(Bit V)
(Bit C) Test: Result \(=00000000\) ? Test: Decimal value of most significant BCD Character greater than nine?

Test: Operand = 10000000 prior to execution?
Test: Operand = 01111111 prior to execution?
Test: Set equal to result of \(N \oplus C\) after shift has occurred.

\section*{PROGRAM CONTROL OPERATIONS}

Program Control operation can be subdivided into two categories: (1) Index Register/Stack Pointer instructions; (2) Jump and Branch operations.

\section*{Index Register/Stack Pointer Operations}

The instructions for direct operation on the MPU's index Register and Stack Pointer are summarized in Table 3. Decrement (DEX, DES), increment (INX, INS), load (LDX, LDS), and store (STX, STS) instructions are provided for both. The Compare instruction, CPX, can be used to compare the Index Register to a 16 -bit value and update the Condition Code Register accordingly.

The TSX instruction causes the Index Register to be loaded with the address of the last data byte put onto the "stack." The TXS instruction loads the Stack Pointer with a value equal to one less than the current contents of the Index Register. This causes the next byte to be pulled from the "stack" to come from the location indicated by the Index Register. The utility of these two instructions can be clarified by describing the "stack" concept relative to the M6800 system.

The "stack" can be thought of as a sequential list of data stored in the MPU's read/write memory. The Stack Pointer contains a 16 -bit memory address that is used to access the list from one end on a last-in-first-out (LIFO) basis in contrast to the random access mode used by the MPU's other addressing modes.

The MC6800 instruction set and interrupt structure allow extensive use of the stack concept for efficient handling of data movement, subroutines and interrupts. The instructions can be used to establish one or more "stacks" anywhere in read/write memory. Stack length is limited only by the amount of memory that is made available.

Operation of the Stack Pointer with the Push and Pull instructions is illustrated in Figures 15 and 16. The Push instruction (PSHA) causes the contents of the indicated accumulator ( \(A\) in this example) to be stored in memory at the location indicated by the Stack Pointer. The Stack Pointer is automatically decremented by one following the storage operation and is "pointing" to the next empty stack location. The Pull instruction (PULA or PULB) causes the last byte stacked to be loaded into the appropriate accumulator. The

Stack Pointer is automatically incremented by one just prior to the data transfer so that it will point to the last byte stacked rather than the next empty location. Note that the PULL instruction does not "remove" the data from memory; in the example, 1A is still in location ( \(m+1\) ) following execution of PULA. A subsequent PUSH instruction would overwrite that location with the new "pushed" data.

Execution of the Branch to Subroutine (BSR) and Jump to Subroutine (JSR) instructions cause a return address to be saved on the stack as shown in Figures 18 through 20. The stack is decremented after each byte of the return address is pushed onto the stack. For both of these instructions, the return address is the memory location following the bytes of code that correspond to the BSR and JSR instruction. The code required for BSR or JSR may be either two or three bytes, depending on whether the JSR is in the indexed (two bytes) or the extended (three bytes) addressing mode. Before it is stacked, the Program Counter is automatically incremented the correct number of times to be pointing at the location of the next instruction. The Return from Subroutine Instruction, RTS, causes the return address to be retrieved and loaded into the Program Counter as shown in Figure 21.

There are several operations that cause the status of the MPU to be saved on the stack. The Software Interrupt (SWI) and Wait for Interrupt (WAl) instructions as well as the maskable ( \(\overline{\mathrm{RO}}\) ) and non-maskable ( \(\overline{\mathrm{NM}})\) hardware interrupts ali cause the MPU's internal registers lexcept for the Stack Pointer itself) to be stacked as shown in Figure 23. MPU status is restored by the Return from Interrupt, RTI, as shown in Figure 22.

\section*{Jump and Branch Operation}

The Jump and Branch instructions are summarized in Table 4. These instructions are used to control the transfer or operation from one point to another in the control program.

The No Operation instruction, NOP, while included here, is a jump operation in a very limited sense. Its only effect is to increment the Program Counter by one. It is useful during program development as a "stand-in" for some other instruction that is to be determined during debug. It is also used for equalizing the execution time through alternate paths in a control program.

TABLE 3 - INDEX REGISTER AND STACK POINTER INSTRUCTIONS
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline \multirow[b]{3}{*}{POINTER OPERATIONS} & \multirow[b]{3}{*}{MNEMONIC} & \multicolumn{3}{|c|}{\multirow[b]{2}{*}{IMMED}} & \multicolumn{3}{|c|}{\multirow[b]{2}{*}{DIRECT}} & \multicolumn{3}{|c|}{\multirow[b]{2}{*}{INDEX}} & \multicolumn{3}{|c|}{\multirow[b]{2}{*}{EXTND}} & \multicolumn{3}{|l|}{\multirow[b]{2}{*}{IMPLIED}} & \multirow[b]{3}{*}{BOOLEAN/ARITHMETIC OPERATION} & \multicolumn{6}{|l|}{COND. CODE REG.} \\
\hline & & & & & & & & & & & & & & & & & & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline & & DP & \(\sim\) & \(\pm\) & OP & \(\sim\) & \(\pm\) & OP & \(\sim\) & \(\stackrel{\text { - }}{\text { - }}\) & DP & \(\sim\) & \(=\) & OP & \(\sim\) & \(=\) & & H & 1 & N & 2 & v & c \\
\hline Compare index Reg & CPX & 8C & 3 & 3 & 9 C & 4 & 2 & \(A C\) & 6 & 2 & EC & 5 & 3 & & & & \(X_{H}-M, X_{L}-(M+1)\) & - & - & (1) & & & - \\
\hline Decrement Index Reg & DEX & & & & & & & & & & & & & 09 & 4 & 1 & \(\mathrm{X}-1 \rightarrow \mathrm{x}\) & - & - & - & & - & - \\
\hline Decrement Stack Pntr & DES & & & & & & & & & & & & & 34 & 4 & 1 & SP-1 \(\mathrm{SP}^{\text {P }}\) & - & - & & & - & - \\
\hline Increment Index Reg & INX & & & & & & & & & & & & & 08 & 4 & 1 & \(\mathrm{X}+1 \rightarrow \mathrm{X}\) & - & - & - & & - & - \\
\hline Increment Stack Pntr & INS & & & & & & & & & & & & & 31 & 4 & 1 & SP + \(1 \rightarrow\) SP & - & - & - & - & - & - \\
\hline Load Index Reg & LDX & CE & 3 & 3 & DE & 4 & 2 & EE & 6 & 2 & FE & 5 & 3 & & & & \(\mathrm{M} \rightarrow \mathrm{X}_{\mathrm{H}} .(\mathrm{M}+1) \rightarrow \mathrm{X}_{L}\) & - & - & (3) & & R & - \\
\hline Load Stack Pntr & LDS & 8E & 3 & 3 & 9E & 4 & 2 & AE & 6 & 2 & BE & 5 & 3 & & & & \(\mathrm{M} \rightarrow \mathrm{SP}_{\mathrm{H}},(\mathrm{M}+1) \rightarrow S \mathrm{P}_{\text {L }}\) & - & - & (3) & & R & - \\
\hline Store Index Reg & STX & & & & DF & 5 & 2 & EF & 7 & 2 & FF & 6 & 3 & & & & \(X_{H} \rightarrow M, X_{L} \rightarrow(M+1)\) & - & - & (3) & & R & - \\
\hline Store Stack Pritr & STS & & & & 9 F & 5 & 2 & AF & 7 & 2 & BF & 6 & 3 & & & & \(\mathrm{SP}_{\mathrm{H}} \rightarrow \mathrm{M}, \mathrm{SP} \mathrm{S}_{\mathrm{L}} \rightarrow(\mathrm{M}+1)\) & - & - & (3) & & R & - \\
\hline Indx Reg \(\rightarrow\) Stack Pntr & TXS & & & & & & & & & & & & & 35 & 4 & 1 & \(\mathrm{X}-\mathrm{l} \rightarrow \mathrm{SP}\) & - & - & , & - & - & - \\
\hline Stack Pntr \(\rightarrow\) Indx Reg & TSX & & & & & & & & & & & & & 30 & 4 & 1 & SP \(+1 \rightarrow X\) & - & - & & & - & \\
\hline
\end{tabular}
(1) (Bit \(N\) ) Test: Sign bit of most significant (MS) byte of result \(=1\) ?
(2) (Bit V) Test: 2's complement overflow from subtraction of ms bytes?
(3) (Bit \(N\) ) Test: Resuit less than zero? (Bit \(15=1\) )


FIGURE 16 - STACK OPERATION, PULL INSTRUCTION


TABLE 4 - JUMP AND BRANCH INSTRUCTIONS
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline \multirow[b]{3}{*}{DPERATIONS} & \multirow[b]{3}{*}{MNEMDNIC} & & & & & & & & & & & & & \multicolumn{2}{|r|}{\multirow[b]{3}{*}{BRANCH TEST}} & \multicolumn{6}{|c|}{COND. CODE REG.} \\
\hline & & \multicolumn{3}{|l|}{RELATIVE} & \multicolumn{3}{|c|}{INDEX} & \multicolumn{3}{|c|}{EXTND} & \multicolumn{3}{|l|}{IMPLIED} & & & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline & & OP & \(\sim\) & \# & OP & \(\sim\) & \# & OP & \(\sim\) & \# & DP & \(\sim\) & \# & & & H & 1 & N & Z & \(V\) & C \\
\hline Branch Always & BRA & 20 & 4 & 2 & & & & & & & & & & & None & - & - & - & - & - & - \\
\hline Branch If Carry Clear & BCC & 24 & 4 & 2 & & & & & & & & & & & \(\mathrm{C}=0\) & - & - & - & - & - & - \\
\hline Branch If Carry Set & BCS & 25 & 4 & 2 & & & & & & & & & & & \(C=1\) & - & - & - & \[
\bullet
\] & - & - \\
\hline Branch lf = Zero & BEO & 27 & 4 & 2 & & & & & & & & & & & \(\mathrm{Z}=1\) & - & - & - & \[
\bullet
\] & - & - \\
\hline Branch If \(\geqslant\) Zero & BGE & 2 C & 4 & 2 & & & & & & & & & & & \(N \oplus V=0\) & - & - & - & - & - & - \\
\hline Branch If \(>\) Zero & BGT & 2 E & 4 & 2 & & & & & & & & & & & \(Z+(N \oplus V)=0\) & - & - & - & - & \[
\bullet
\] & - \\
\hline Branch If Higher & BHI & 22 & 4 & 2 & & & & & & & & & & & \(C+Z=0\) & - & - & \[
\bullet
\] & - & - & - \\
\hline Branch If \(\leqslant\) Zero & BLE & \(2 F\) & 4 & 2 & & & & & & & & & & & \(Z+(N \oplus V)=1\) & - & - & - & - & - & - \\
\hline Branch If Lower Or Same & BLS & 23 & 4 & 2 & & & & & & & & & & & \(C+Z=1\) & & - & - & - & \[
\bullet
\] & - \\
\hline Branch lf < Zero & BLT & 2 D & 4 & 2 & & & & & & & & & & & \(N \oplus V=1\) & & & - & - & - & - \\
\hline Branch If Minus & BMI & 2B & 4 & 2 & & & & & & & & & & & \(\mathrm{N}=1\) & & - & - & - & \[
\bullet
\] & - \\
\hline Branch It Not Equal Zero & BNE & 26 & 4 & 2 & & & & & & & & & & & \(Z=0\) & & \[
\bullet
\] & - & - & - & - \\
\hline Branch If Overflow Clear & BVC & 28 & 4 & 2 & & & & & & & & & & & \(V=0\) & & & - & \[
\bullet
\] & \[
\bullet
\] & - \\
\hline Branch It Overflow Set & BVS & 29 & 4 & 2 & & & & & & & & & & & \(V=1\) & & - & - & - & \[
\bullet
\] & - \\
\hline Branch If Plus & BPL & 2 A & 4 & 2 & & & & & & & & & & & \(\mathrm{N}=0\) & - & - & - & - & - & - \\
\hline Branch To Subroutine & BSR & 8 D & 8 & 2 & & & & & & & & & & ) & & - & - & \[
\bullet
\] & \[
\bullet
\] & \[
\bullet
\] & - \\
\hline Jump & JMP & & & & 6E & 4 & 2 & 7E & 3 & 3 & & & & \} & See Special Operations & - & - & - & \[
\bullet
\] & \[
\bullet
\] & - \\
\hline Jump To Subroutirie & JSR & & & & AD & 8 & 2 & BD & 9 & 3 & & & & ) & & - & - & - & - & - & - \\
\hline No Operation & NOP & & & & & & & & & & 01 & 2 & 1 & & Advances Prog. Contr. Only & - & - & & - & - & - \\
\hline Return From Interrupt & RTI & & & & & & & & & & 3 B & 10 & 1 & & & & & & & & \\
\hline Return From Subroutine & RTS & & & & & & & & & & 39 & 5 & 1 & 1 & & \[
\bullet
\] & - & - & - & - & - \\
\hline Sottware Interrupt & SWI & & & & & & & & & & 3 F & 12 & 1 & & See Special Operations & - & \[
\bullet
\] & \[
\bullet
\] & \[
\bullet
\] & - & - \\
\hline Wait for Interrupt* & WAI & & & & & & & & & & 3 E & 9 & 1 & 1 & & - & (2) & - & - & - & - \\
\hline
\end{tabular}
*WAI puts Address Bus, R/W, and Data Bus in the three-state made while VMA is held low.
(All) Load Condition Code Register from Stack. (See Special Operations)
(2) (Bit 1) Set when interrupt occurs. If previously set, a Non-Maskable interrupt is required to exit the wait state.

Execution of the Jump Instruction, JMP, and Branch Always, BRA, affects program flow as shown in Figure 17. When the MPU encounters the Jump (Indexed) instruction, it adds the offset to the value in the Index Register and uses the result as the address of the next instruction to be executed. In the extended addressing mode, the address of the next instruction to be executed is fetched from the two locations immediately following the JMP instruction. The Branch Always (BRA) instruction is similar to the JMP (extended) instruction except that the relative addressing mode applies and the branch is limited to the range within -125 or +127 bytes of the branch instruction itself. The opcode for the BRA instruction requires one less byte than JMP (extended) but takes one more cycle to execute.
The effect on program flow for the Jump to Subroutine (JSR) and Branch to Subroutine (BSR) is shown in Figures 18 through 20. Note that the Program Counter is properly incremented to be pointing at the correct return address before it is stacked. Operation of the Branch to Subroutine and Jump to Subroutine (extended) instruction is similar except for the range. The BSR instruction requires less opcode than JSR ( 2 bytes versus 3 bytes) and also executes one cy-
cle faster than JSR. The Return from Subroutine, RTS, is used as the end of a subroutine to return to the main program as indicated in Figure 21.

The effect of executing the Software Interrupt, SWI, and the Wait for Interrupt, WAI, and their relationship to the hardware interrupts is shown in Figure 22. SWI causes the MPU contents to be stacked and then fetches the starting address of the interrupt routine from the memory locations that respond to the addresses FFFA and FFFB. Note that as in the case of the subroutine instructions, the Program Counter is incremented to point at the correct return address before being stacked. The Return from Interrupt instruction, RTI, (Figure 22) is used at the end of an interrupt routine to restore control to the main program. The SWI instruction is useful for inserting break points in the control program, that is, it can be used to stop operation and put the MPU registers in memory where they can be examined. The WAI instruction is used to decrease the time required to service a hardware interrupt; it stacks the MPU contents and then waits for the interrupt to occur, effectively removing the stacking time from a hardware interrupt sequence.

FIGURE 17 - PROGRAM FLOW FOR JUMP AND BRANCH INSTRUCTIONS



FIGURE 19 - PROGRAM FLOW FOR JSR (EXTENDED)


FIGURE 21 - PROGRAM FLOW FOR RTS


FIGURE 22 - PROGRAM FLOW FOR RTI

(a) Before Execution

(b) After Execution

FIGURE 23 - PROGRAM FLOW FOR INTERRUPTS
NOTE: MS = Most Significant Address Byte;
LS = Least Significant Address Byte;

First Instr. Addr. Formed By Fetching 2.Bytes From Per. Mem.
Assign.

Hardware Interrupt or Non-Maskable Interrupt (NMI)

Main Program


Wait For interrup


Stack MPU Register Contents


Stack
\begin{tabular}{c|c}
\(m-5\) & Acmltr. B \\
\cline { 2 - 2 }-4 & Acmltr. A
\end{tabular}
\(m-3\)
\(m-2\)
m -
m
\begin{tabular}{|c|}
\hline \\
\hline
\end{tabular}
\begin{tabular}{|l}
\hline\(P\) \\
\hline\(P\) \\
\hline
\end{tabular}
\(P C(n+1) L\)
SWI


N

FIGURE 24 - CONDITIONAL BRANCH INSTRUCTIONS
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline BMI & : & \(\mathrm{N}=1\) & & BEQ & : & \(Z=1\) \\
\hline BPL & : & \(\mathrm{N}=\boldsymbol{\phi}\) & & BNE & : & \(\mathrm{Z}=\varnothing\) \\
\hline BVC & : & \(V=\phi\) & & BCC & : & \(\mathrm{C}=\boldsymbol{\phi}\) \\
\hline BVS & : & \(V=1\); & & BCS & : & \(C=1\) \\
\hline BHI & : & \(C+Z=\phi\) & ; & BLT & : & \(N \oplus \mathrm{~V}=1\) \\
\hline BLS & : & \(C+Z=1\) & ; & BGE & : & \(N \oplus \mathrm{~V}=\phi\) \\
\hline & & BLE & : & \multicolumn{2}{|l|}{\(Z+(N \oplus V)=1\)} & ; \\
\hline & & BGT & : & \(\mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})\) & \()=\phi\) & ; \\
\hline
\end{tabular}

The conditional branch instructions, Figure 24, consists of seven pairs of complementary instructions. They are used to test the results of the preceding operation and either continue with the next instruction in sequence (test fails) or cause a branch to another point in the program ltest succeeds).

Four of the pairs are used for simple tests of status bits \(N\), \(Z, V\), and \(C\) :
1. Branch on Minus (BMI) and Branch On Plus (BPL) tests the sign bit, \(N\), to determine if the previous result was negative or positive, respectively.
2. Branch On Equal (BEQ) and Branch On Not Equal (BNE) are used to test the zero status bit, \(Z\), to determine whether or not the result of the previous operation was equal to zero. These two instructions are useful following a Compare (CMP) instruction to test for equality between an accumulator and the operand. They are also used following the Bit Test (BIT) to determine whether or not the same bit positions are set in an accumulator and the operand.
3. Branch On Overflow Clear (BVC) and Branch On Overflow Set (BVS) tests the state of the \(V\) bit to determine if the previous operation caused an arithmetic overflow.
4. Branch On Carry Clear (BCC) and Branch On Carry Set ( \(B C S\) ) tests the state of the \(C\) bit to determine if the previous operation caused a carry to occur. BCC and BCS are useful
for testing relative magnitude when the values being tested are regarded as unsigned binary numbers, that is, the values are in the range 00 (lowest) to FF (highest). BCC following a comparison (CMP) will cause a branch if the (unsigned) value in the accumulator is higher than or the same as the value of the operand. Conversely, BCS will cause a branch if the accumulator value is lower than the operand.

The fifth complementary pair, Branch On Higher ( BH ) and Branch On Lower or Same (BLS) are, in a sense, complements to BCC and BCS . BHI tests for both C and \(\mathrm{Z}=0\); if used following a CMP, it will cause a branch if the value in the accumulator is higher than the operand. Conversely, BLS will cause a branch if the unsigned binary value in the accumulator is lower than or the same as the operand.
The remaining two pairs are useful in testing results of operations in which the values are regarded as signed two's complement numbers. This differs from the unsigned binary case in the following sense: in unsigned, the orientation is higher or lower; in signed two's complement, the comparison is between larger or smaller where the range of values is between -128 and +127 .

Branch On Less Than Zero (BLT) and Branch On Greater Than Or Equal Zero (BGE) test the status bits for \(N \oplus V=1\) and \(N \oplus V=0\), respectively. BLT will always cause a branch following an operation in which two negative numbers were added. In addition, it will cause a branch following a CMP in which the value in the accumulator was negative and the operand was positive. BLT will never cause a branch following a CMP in which the accumulator value was positive and the operand negative. BGE, the complement to BLT, will cause a branch following operations in which two positive values were added or in which the result was zero.

The last pair, Branch On Less Than Or Equal Zero (BLE) and Branch On Greater Than Zero (BGT) test the status bits for \(Z \oplus(N+V)=1\) and \(Z \oplus(N+V)=0\), respectively. The action of BLE is identical to that for BLT except that a branch will also occur if the result of the previous result was zero. Conversely, BGT is similar to BGE except that no branch will occur following a zero result.

\section*{CONDITION CODE REGISTER OPERATIONS}

The Condition Code Register (CCR) is a 6-bit register within the MPU that is useful in controlling program flow during system operation. The bits are defined in Figure 25.

The instructions shown in Table 5 are available to the user for direct manipulation of the CCR.

A CLI-WAI instruction sequence operated properly, with early MC6800 processors, only if the preceding instruction was odd (Least Significant Bit \(=1\) ). Similarly it was advisable
to precede any SEl instruction with an odd opcode - such as NOP. These precautions are not necessary for MC6800 processors indicating manufacture in November 1977 or later.

Systems which require an interrupt window to be opened under program control should use a CLI-NOP-SEl sequence rather than CLI-SEI.
figure 25 - CONDITION CODE REGISTER BIT dEFINITION
\begin{tabular}{|l|l|l|l|l|l|}
\hline \(\mathrm{b}_{5}\) & \(\mathrm{~b}_{4}\) & \(\mathrm{~b}_{3}\) & \(\mathrm{~b}_{2}\) & \(\mathrm{~b}_{1}\) & \(\mathrm{~b}_{0}\) \\
\hline H & I & N & z & V & C \\
\hline
\end{tabular}
\(\mathbf{H}=\) Half-carry; set whenever a carry from \(b_{3}\) to \(b_{4}\) of the result is generated by ADD, \(A B A, A D C\); cleared if no \(b_{3}\) to \(b_{4}\) carry; not affected by other instructions.

I = Interrupt Mask; set by hardware or software interrupt or SEI instruction; cleared by CLI instruction. (Normally not used in arithmetic operations.) Restored to a zero as a result of an RT1 instruction if \(I_{m}\) stored on the stacked is low.
\(N=\) Negative; set if high order bit ( \(\mathrm{b}_{7}\) ) of result is set; cleared otherwise.

Z = Zero; set if result \(=0\); cleared otherwise.
\(V=\) Overlow; set if there was arithmetic overflow as a result of the operation; cleared otherwise.

C = Carry; set if there was a carry from the most significant bit ( \(\mathrm{b}_{7}\) ) of the result; cleared otherwise.

TABLE 5 - CONDITION CODE REGISTER INSTRUCTIONS
\begin{tabular}{|c|c|c|c|c|c|c|c|c|c|c|c|}
\hline \multirow[b]{3}{*}{OPERATIONS} & \multirow[b]{3}{*}{MNEMONIC} & & & & \multirow[b]{3}{*}{BOOLEAN OPERATION} & \multicolumn{6}{|c|}{COND. CDDE REG.} \\
\hline & & \multicolumn{3}{|c|}{MPLIED} & & 5 & 4 & 3 & 2 & 1 & 0 \\
\hline & & OP & \(\sim\) & \(=\) & & H & I & N & Z & \(V\) & C \\
\hline Clear Carry & CLC & OC & 2 & 1 & \(0 \rightarrow\) C & - & - & - & - & - & R \\
\hline Clear Interrupt Mask & CLI & OE & 2 & 1 & \(0 \rightarrow 1\) & - & R & - & - & - & - \\
\hline Clear Overflow & CLV & OA & 2 & 1 & \(0 \rightarrow V\) & - & - & - & - & R & - \\
\hline Set Carry & SEC & OD & 2 & 1 & \(1 \rightarrow \mathrm{C}\) & - & - & - & - & - & S \\
\hline Set Interrupt Mask & SEI & OF & 2 & 1 & \(1 \rightarrow 1\) & - & S & - & - & \(\bullet\) & - \\
\hline Set Overflow & SEV & OB & 2 & 1 & \(1 \rightarrow V\) & - & - & - & - & S & - \\
\hline Acmltr \(A \rightarrow\) CCR & TAP & 06 & 2 & 1 & \(A \rightarrow C C R\) & & & & & & \\
\hline CCR \(\rightarrow\) Acmltr \(A\) & TPA & 07 & 2 & 1 & \(\mathrm{CCR} \rightarrow \mathrm{A}\) & - & - & - & - & - & \(\bullet\) \\
\hline
\end{tabular}
\[
\begin{aligned}
& R=\text { Reset } \\
& S=\text { Set } \\
& \text { - }=\text { Not affected } \\
& \text { (1) (ALL) Set according to the contents of Accumulator A. }
\end{aligned}
\]

\section*{ADDRESSING MODES}

The MPU operates on 8-bit binary numbers presented to it via the Data Bus. A given number (byte) may represent either data or an instruction to be executed, depending on where it is encountered in the control program. The M6800 has 72 unique instructions, however, it recognizes and takes action on 197 of the 256 possibilitis that can occur using an 8 -bit word length. This larger number of instructions results from the fact that many of the executive instructions have more than one addressing mode.
These addressing modes refer to the manner in which the program causes the MPU to obtain its instructions and data. The programmer must have a method for addressing the MPU's internal registers and all of the external memory locations.

Selection of the desired addressing mode is made by the user as the source statements are written. Translation into
appropriate opcode ther depends on the method used. If manual translation is used, the addressing mode is inherent in the opcode. For example, the immediate, Direct, Indexed, and Extended modes may all be used with the ADD instruction. The proper mode is determined by selecting (hexadecimal notation) \(8 B, 9 B, A B\), or \(B B\), respectively.
The source statement format includes adequate information for the selection if an assembler program is used to generate the opcode. For instance, the Immediate mode is selected by the Assembler whenever it encounters the "\#" symbol in the operand field. Similarly, an " \(X\) " in the operand field causes the Indexed mode to be selected. Only the Relative mode applies to the branch instructions, therefore, the mnemonic instruction itself is enough for the Assembler to determine addressing mode.

For the instructions that use both Direct and Extended modes, the Assembler selects the Direct mode if the operand value is in the range 0-255 and Extended otherwise. There are a number of instructions for which the Extended mode is valid but the Direct is not. For these instructions, the Assembler automatically selects the Extended mode even if the operand is in the \(0-255\) range. The addressing modes are summarized in Figure 26.

\section*{Inherent (Includes "Accumulator Addressing" Mode)}

The successive fields in a statement are normally separated by one or more spaces. An exception to this rule occurs for instructions that use dual addressing in the operand field and for instructions that must distinguish between the two accumulators. In these cases, \(A\) and \(B\) are
"operands" but the space between them and the operator may be omitted. This is commonly done, resulting in apparent four character mnemonics for those instructions.

The addition instruction, ADD, provides an example of dual addressing in the operand field:


The example used earlier for the test instruction, TST, also applies to the accumulators and uses the "accumulator addressing mode" to designate which of the two accumulators is being tested:

FIGURE 26 - ADDRESSING MODE SUMMARY
\begin{tabular}{|c|c|c|}
\hline Direct: & \(n\) & DO Instruction \\
\hline \multirow[t]{5}{*}{\begin{tabular}{l}
Example: SUBB Z \\
Addr. Range \(=0-255\)
\[
1
\]
\end{tabular}} & \(n+1\) & Z = Oprnd Address \\
\hline & \(n+2\) & Next Instr. \\
\hline & & - \\
\hline & & - \\
\hline & & - \\
\hline \multirow[t]{2}{*}{(K = One-Byte Oprnd)} & z & \(K=\) Operand \\
\hline & & OR \\
\hline \multirow[t]{2}{*}{(K = Two-Byte Oprnd)} & \(z\) & \(K_{H}=\) Operana \\
\hline & \(z+1\) & \(K_{L}=\) Operand \\
\hline
\end{tabular}

Immediate:
Example: LDAA \(\ddagger K\) (K = One-Byte Oprnd)
( \(K=\) Two-Byte Oprind) (CPX, LDX, and LDS)

(2) If Brnch Tst False, (3) If Brnch Tst True.


Extended:
Example: CMPA Z
Addr. Range:
256-65535
(K = One-Byte Oprnd)


```

Operator TSTB TEST CONTENTS OF ACCB
or
TSTA TEST CONTENTS OF ACCA

```

A number of the instructions either alone or together with an accumulator operand contain all of the address information that is required, that is, "inherent" in the instruction itself. For instance, the instruction \(A B A\) causes the MPU to add the contents of accmulators \(A\) and \(B\) together and place the result in accumulator \(A\). The instruction INCB, another example of "accumulator addressing," causes the contents of accumulator B to be increased by one. Similarly, INX, increment the Index Register, causes the contents of the Index Register to be increased by one.

Program flow for instructions of this type is illustrated in Figures 27 and 28. In these figures, the general case is shown on the left and a specific example is shown on the right. Numerical examples are in decimal notation. Instructions of this type require only one byte of opcode. Cycle-by-cycle operation of the inherent mode is shown in Table 6.

Immediate Addressing Mode - in the immediate addressing mode, the operand is the value that is to be operated on. For instance, the instruction
\begin{tabular}{ccc} 
Operator & Operand & Comment \\
LDAA & \(\# 25\) & LOAD 25 INTO ACCA
\end{tabular}
causes the MPU to "immediately load accumulator A with the value \(25^{\prime \prime}\); no further address reference is required. The Immediate mode is selected by preceding the operand value with the "\#" symbol. Program flow for this addressing mode is illustrated in Figure 29.

The operand format allows either properly defined symbols or numerical values. Except for the instructions \(C P X\), LDX, and LDS, the operand may be any value in the range 0 to 255. Since Compare Index Register (CPX), Load Index Register (LDX), and Load Stack Pointer (LDS), require 16-bit values, the immediate mode for these three instructions require two-byte operands. In the Immediate addressing
mode, the "address" of the operand is effectively the memory location immediately following the instruction itself. Table 7 shows the cycle-by-cycle operation for the immediate addressing mode.

Direct and Extended Addressing Modes - In the Direct and Extended modes of addressing, the operand field of the source statement is the address of the value that is to be operated on. The Direct and Extended modes differ only in the range of memory locations to which they can direct the MPU. Direct addressing generates a single 8 -bit operand and, hence, can address only memory locations 0 through 255; a two byte operand is generated for Extended addressing, enabling the MPU to reach the remaining memory locations, 256 through 65535. An example of Direct addressing and its effect on program flow is illustrated in Figure 30.
The MPU, after encountering the opcode for the instruction LDAA (Direct) at memory location 5004 (Program Counter \(=5004\) ), looks in the next location, 5005 , for the address of the operand. It then sets the program counter equal to the value found there (100 in the example) and fetches the operand, in this case a value to be loaded into accumulator A, from that location. For instructions requiring a two-byte operand such as LDX (Load the Index Register), the operand bytes would be retrieved from locations 100 and 101. Table 8 shows the cycle-by-cycle operation for the direct mode of addressing.

Extended addressing, Figure 31, is similar except that a two-byte address is obtained from locations 5007 and 5008 after the LDAB (Extended) opcode shows up in location 5006. Extended addressing can be thought of as the "standard" addressing mode, that is, it is a method of reaching any place in memory. Direct addressing, since only one address byte is required, provides a faster method of processing data and generates fewer bytes of control code. In most applications, the direct addressing range, memory locations \(0-255\), are reserved for RAM. They are used for data buffering and temporary storage of system variables, the area in which faster addressing is of most value. Cycle-by-cycle operation is shown in Table 9 for Extended Addressing.

FIGURE 27 - INHERENT ADDRESSING


FIGURE 28 - ACCUMULATOR ADDRESSING


Relative Address Mode - In both the Direct and Extended modes, the address obtained by the MPU is an absolute numerical address. The Relative addressing mode, implemented for the MPU's branch instructions, specifies a memory location relative to the Program Counter's current location. Branch instructions generate two bytes of machine code, one for the instruction opcode and one for the "relative" address (see Figure 32). Since it is desirable to be able to branch in either direction, the 8 -bit address byte is interpreted as a signed 7-bit value; the 8th bit of the operand is treated as a sign bit, " 0 " = plus and " 1 " = minus. The remaining seven bits represent the numerical value. This results in a relative addressing range of \(\pm 127\) with respect to the location of the branch instruction itself. However, the branch range is computed with respect to the next instruction that would be executed if the branch conditions are not satisfied. Since two bytes are generated, the next instruction is located at \(P C+2\). If \(D\) is defined as the address of the branch destination, the range is then:
\[
(P C+2)-127 \leq D \leq(P C+2)+127
\]
or
\[
P C-125 \leq D \leq P C+129
\]
that is, the destination of the branch instruction must be within -125 to +1.29 memory locations of the branch instruction itself. For transferring control beyond this range,
the unconditional jump (JMP), jump to subroutine (JSR), and return from subroutine (RTS) are used.
In Figure 32, when the MPU encounters the opcode for BEQ (Branch if result of last instruction was zero), it tests the Zero bit in the Condition Code Register. If that bit is " 0, " indicating a non-zero result, the MPU continues execution with the next instruction (in location 5010 in Figure 32). If the previous result was zero, the branch condition is satisfied and the MPU adds the offset, 15 in this case, to PC+2 and branches to location 5025 for the next instruction.

The branch instructions allow the programmer to efficiently direct the MPU to one point or another in the control program depending on the outcome of test results. Since the control program is normally in read-only memory and cannot be changed, the relative address used in execution of branch instructions is a constant numerical value. Cycle-by-cycle operation is shown in Table 10 for relative addressing.

Indexed Addressing Mode - With Indexed addressing, the numerical address is variable and depends on the current contents of the Index Register. A source statement such as

\section*{Operator STAA}

Operand X

\section*{Comment PUT A IN INDEXED LOCATION}
causes the MPU to store the contents of accumulator \(A\) in

TABLE 6 - INHERENT MODE CYCLE-BY-CYCLE OPERATION
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \begin{tabular}{c} 
Address Mode \\
and Instructions
\end{tabular} & Cycles & \begin{tabular}{c} 
Cycle \\
\(\#\)
\end{tabular} & \begin{tabular}{c} 
VMA \\
Line
\end{tabular} & Address Bus & \begin{tabular}{c}
\(R / \bar{W}\) \\
Line
\end{tabular} & Data Bus \\
\hline
\end{tabular}
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline \begin{tabular}{l}
ABA \\
ASL \\
ASR \\
CBA \\
CLC \\
CLI \\
CLR \\
CLV \\
COM
\end{tabular} & \begin{tabular}{l}
DAA SEC \\
DEC SEI \\
INC SEV \\
LSR TAB \\
NEG TAP \\
NOP TBA \\
ROL TPA \\
ROR TST \\
SBA
\end{tabular} & 2 & 1
2 & \[
\begin{aligned}
& 1 \\
& 1
\end{aligned}
\] & \begin{tabular}{l}
Op Code Address \\
Op Code Address +1
\end{tabular} & \[
\begin{aligned}
& 1 \\
& 1
\end{aligned}
\] & \begin{tabular}{l}
Op Code \\
Op Code of Next Instruction
\end{tabular} \\
\hline \begin{tabular}{l}
DES \\
DEX \\
INS \\
INX
\end{tabular} & & 4 & 1
2
3
4 & \[
\begin{aligned}
& 1 \\
& 1 \\
& 0 \\
& 0
\end{aligned}
\] & \begin{tabular}{l}
Op Code Address \\
Op Code Address + 1 \\
Previous Register Contents \\
New Register Contents
\end{tabular} & \[
\begin{aligned}
& 1 \\
& 1 \\
& 1 \\
& 1
\end{aligned}
\] & \begin{tabular}{l}
Op Code \\
Op Code of Next Instruction \\
Irrelevant Data (Note 1) \\
Irrelevant Data (Note 1)
\end{tabular} \\
\hline PSH & & 4 & \[
\begin{aligned}
& 1 \\
& 2 \\
& 3 \\
& 4 \\
& \hline
\end{aligned}
\] & \[
\begin{aligned}
& 1 \\
& 1 \\
& 1 \\
& 0 \\
& \hline
\end{aligned}
\] & \begin{tabular}{l}
Op Code Address \\
Op Code Address +1 \\
Stack Pointer \\
Stack Pointer - 1
\end{tabular} & \[
\begin{aligned}
& 1 \\
& 1 \\
& 0 \\
& 1 \\
& \hline
\end{aligned}
\] & \begin{tabular}{l}
Op Code \\
Op Code of Next Instruction \\
Accumulator Data \\
Accumulator Data
\end{tabular} \\
\hline PUL & & 4 & \[
\begin{aligned}
& 1 \\
& 2 \\
& 3 \\
& 4
\end{aligned}
\] & \[
\begin{aligned}
& 1 \\
& 1 \\
& 0 \\
& 1
\end{aligned}
\] & \begin{tabular}{l}
Op Code Address \\
Op Code Address + 1 \\
Stack Pointer \\
Stack Pointer + 1
\end{tabular} & \[
\begin{aligned}
& 1 \\
& 1 \\
& 1 \\
& 1
\end{aligned}
\] & \begin{tabular}{l}
Op Code \\
Op Code of Next Instruction Irrelevant Data (Note 1) Operand Data from Stack
\end{tabular} \\
\hline TSX & & 4 & \[
\begin{aligned}
& 1 \\
& 2 \\
& 3 \\
& 4
\end{aligned}
\] & \[
\begin{aligned}
& 1 \\
& 1 \\
& 0 \\
& 0
\end{aligned}
\] & \begin{tabular}{l}
Op Code Address \\
Op Code Address + 1 \\
Stack Pointer \\
New Index Register
\end{tabular} & \[
\begin{aligned}
& 1 \\
& 1 \\
& 1 \\
& 1
\end{aligned}
\] & \begin{tabular}{l}
Op Code \\
Op Code of Next Instruction \\
Irrelevant Data (Note 1) \\
Irrelevant Data (Note 1)
\end{tabular} \\
\hline TXS & & 4 & \[
\begin{aligned}
& 1 \\
& 2 \\
& 3 \\
& 4
\end{aligned}
\] & \[
\begin{aligned}
& 1 \\
& 1 \\
& 0 \\
& 0
\end{aligned}
\] & \begin{tabular}{l}
Op Code Address \\
Op Code Address + 1 \\
Index Register \\
New Stack Pointer
\end{tabular} & \[
\begin{aligned}
& 1 \\
& 1 \\
& 1 \\
& 1
\end{aligned}
\] & \begin{tabular}{l}
Op Code \\
Op Code of Next Instruction \\
Irrelevant Data \\
Irrelevant Data
\end{tabular} \\
\hline RTS & & 5 & 1
2
3
4 & 1
1
0
1 & \begin{tabular}{l}
Op Code Address \\
Op Code Address + 1 \\
Stack Pointer \\
Stack Pointer +1 \\
Stack Pointer +2
\end{tabular} & \[
\begin{aligned}
& 1 \\
& 1 \\
& 1 \\
& 1 \\
& 1
\end{aligned}
\] & \begin{tabular}{l}
Op Code \\
Irrelevant Data (Note 2) \\
Irrelevant Data (Note 1) \\
Address of Next Instruction (High Order Byte) \\
Address of Next Instruction (Low Order Byte)
\end{tabular} \\
\hline
\end{tabular}

TABLE 6 - INHERENT MODE CYCLE-BY-CYCLE OPERATION (CONTINUED)
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \begin{tabular}{c} 
Address Mode \\
and Instructions
\end{tabular} & Cycles & \begin{tabular}{c} 
Cycle \\
\(\#\)
\end{tabular} & \begin{tabular}{c} 
VMA \\
Line
\end{tabular} & Address Bus & \begin{tabular}{c} 
R/ \(/ \bar{W}\) \\
Line
\end{tabular} & Data Bus \\
\hline
\end{tabular}
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline WAI & 9 & \[
\begin{aligned}
& 1 \\
& 2 \\
& 3 \\
& 4 \\
& 5 \\
& 6 \\
& 7 \\
& 8 \\
& 9
\end{aligned}
\] & \[
1
\] & \begin{tabular}{l}
Op Code Address \\
Op Code Address +1 \\
Stack Pointer \\
Stack Pointer - 1 \\
Stack Pointer - 2 \\
Stack Pointer - 3 \\
Stack Pointer - 4 \\
Stack Pointer - 5 \\
Stack Pointer - 6 (Note 3)
\end{tabular} & \[
\begin{aligned}
& 1 \\
& 1 \\
& 0 \\
& 0 \\
& 0 \\
& 0 \\
& 0 \\
& 0 \\
& 1
\end{aligned}
\] & \begin{tabular}{l}
Op Code \\
Op Code of Next Instruction \\
Return Address (Low Order Byte) \\
Return Address (High Order Byte) \\
Index Register (Low Order Byte) \\
Index Register (High Order Byte) \\
Contents of Accumulator \(A\) \\
Contents of Accumulator B \\
Contents of Cond. Code Register
\end{tabular} \\
\hline RTI & 10 & \begin{tabular}{l}
1 \\
2 \\
3 \\
4 \\
5 \\
6 \\
7 \\
8 \\
9 \\
10
\end{tabular} & 1
1
0
1
1
1
1
1
1 & \begin{tabular}{l}
Op Code Address \\
Op Code Address + 1 \\
Stack Pointer \\
Stack Pointer +1 \\
Stack Pointer +2 \\
Stack Pointer +3 \\
Stack Pointer + 4 \\
Stack Pointer +5 \\
Stack Pointer +6 \\
Stack Pointer +7
\end{tabular} & 1
1
1
1
1
1
1
1
1
1 & \begin{tabular}{l}
Op Code \\
Irrelevant Data (Note 2) \\
Irrelevant Data (Note 1) \\
Contents of Cond. Code Register from Stack \\
Contents of Accumulator B from Stack \\
Contents of Accumulator A from Stack \\
Index Register from Stack (High Order Byte) \\
Index Register from Stack (Low Order Byte) \\
Next Instruction Address from Stack (High Order Byte) \\
Next Instruction Address from Stack (Low Order Byte)
\end{tabular} \\
\hline SWi & 12 &  & 1
1
1
1
1
1
1
1
1
0
1 & \begin{tabular}{l}
Op Code Address \\
Op Code Address + 1 \\
Stack Pointer \\
Stack Pointer - 1 \\
Stack Pointer - 2 \\
Stack Pointer - 3 \\
Stack Pointer - 4 \\
Stack Pointer - 5 \\
Stack Pointer - 6 \\
Stack Pointer - 7 \\
Vector Address FFFA (Hex) \\
Vector Address FFFB (Hex)
\end{tabular} & \[
\begin{aligned}
& 1 \\
& 1 \\
& 0 \\
& 0 \\
& 0 \\
& 0 \\
& 0 \\
& 0 \\
& 0 \\
& 1 \\
& 1 \\
& 1
\end{aligned}
\] & \begin{tabular}{l}
Op Code \\
Irrelevant Data (Note 1) \\
Return Address (Low Order Byte) \\
Return Address (High Order Byte) \\
Index Register (Low Order Byte) \\
Index Register (High Order Byte) \\
Contents of Accumulator \(A\) \\
Contents of Accumulator B \\
Contents of Cond. Code Register \\
Irrelevant Data (Note 1) \\
Address of Subroutine (High Order Byte) \\
Address of Subroutine (Low Order Byte)
\end{tabular} \\
\hline
\end{tabular}

Note 1. If device which is addressed during this cycle uses VMA, then the Data Bus will go to the high impedance three-state condition. Depending on bus capacitance, data from the previous cycle may be retained on the Data Bus.
Note 2. Data is ignored by the MPU.
Note 3. While the MPU is waiting for the interrupt, Bus Available will go high indicating the following states of the control lines: VMA is low; Address Bus, \(R / \bar{W}\), and Data Bus are all in the high impedance state.
the memory location specified by the contents of the Index Register (recall that the label " \(X\) " is reserved to designate the Index Register). Since there are instructions for manipulating \(X\) during program execution (LDX, INX, DEC, etc.), the Indexed addressing mode provides a dynamic "on the fly" way to modify program activity.

The operand field can also contain a numerical value that will be automatically added to \(X\) during execution. This format is illustrated in Figure 33.

When the MPU encounters the LDAB (Indexed) opcode in
location 5006, it looks in the next memory location for the value to be added to \(X\) ( 5 in the example) and calculates the required address by adding 5 to the present Index Register value of 400 . In the operand format, the offset may be represented by a label or a numerical value in the range \(0-255\) as in the example. In the earlier example, STAA \(X\), the operand is equivalent to \(0, X\), that is, the 0 may be omitted when the desired address is equal to \(X\). Table 11 shows the cycle-by-cycle operation for the Indexed Mode of Addressing.

FIGURE 29 - IMMEDIATE ADDRESSING MODE


FIGURE 30 - DIRECT ADDRESSING MODE


ADDR \(=0 \leqq 255\)
general flow

TABLE 7 - IMMEDIATE MODE CYCLE-BY-CYCLE OPERATION
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \begin{tabular}{c} 
Address Mode \\
and Instructions
\end{tabular} & Cycles & \begin{tabular}{c} 
Cycle \\
\(\#\)
\end{tabular} & \begin{tabular}{c} 
VMA \\
Line
\end{tabular} & \begin{tabular}{c} 
R/信 \\
Line
\end{tabular} & Address Bus & Data Bus \\
\hline
\end{tabular}
\begin{tabular}{|l|c|c|c|l|l|l|}
\hline ADC EOR & & 1 & 1 & Op Code Address \\
ADD LDA \\
AND ORA & 2 & 2 & 1 & Op Code Address +1 & 1 & \begin{tabular}{l} 
Op Code \\
BIT SBC
\end{tabular} \\
CMP SUB & & & & & 1 & Operand Data \\
\hline CPX & & 1 & 1 & Op Code Address & 1 & Op Code \\
LDS & 3 & 2 & 1 & Op Code Address +1 & 1 & Operand Data (High Order Bytel \\
LDX & & 3 & 1 & Op Code Address +2 & 1 & Operand Data (Low Order Byte) \\
\hline
\end{tabular}

TABLE 8 - DIRECT MODE CYCLE-BY-CYCLE OPERATION
\begin{tabular}{|c|c|c|c|c|c|c|c|}
\hline \begin{tabular}{c} 
Address Mode \\
and Instructions
\end{tabular} & Cycles & \begin{tabular}{c} 
Cycle \\
\(\#\)
\end{tabular} & \begin{tabular}{c} 
VMA \\
Line
\end{tabular} & Address Bus & \begin{tabular}{c} 
R/ \(\bar{W}\) \\
Line
\end{tabular} & Data Bus \\
\hline
\end{tabular}
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \begin{tabular}{ll}
\hline ADC & EOR \\
ADD & LDA \\
AND & ORA \\
BIT & SBC \\
CMP & SUB
\end{tabular} & 3 & \[
\begin{aligned}
& 1 \\
& 2 \\
& 3
\end{aligned}
\] & \[
\begin{aligned}
& 1 \\
& 1 \\
& 1
\end{aligned}
\] & Op Code Address Op Code Address + 1 Address of Operand & \[
\begin{aligned}
& 1 \\
& 1 \\
& 1
\end{aligned}
\] & \begin{tabular}{l}
Op Code \\
Address of Operand Operand Data
\end{tabular} \\
\hline \[
\begin{aligned}
& \text { CPX } \\
& \text { LDS } \\
& \text { LDX }
\end{aligned}
\] & 4 & \[
\begin{aligned}
& 1 \\
& 2 \\
& 3 \\
& 4
\end{aligned}
\] & \[
\begin{aligned}
& 1 \\
& 1 \\
& 1
\end{aligned}
\] & \begin{tabular}{l}
Op Code Address \\
Op Code Address + 1 \\
Address of Operand \\
Operand Address + 1
\end{tabular} & \begin{tabular}{l}
1 \\
1 \\
1
\end{tabular} & \begin{tabular}{l}
Op Code \\
Address of Operand \\
Operand Data (High Order Byte) \\
Operand Data (Low Order Byte)
\end{tabular} \\
\hline STA. & 4 & \[
\begin{aligned}
& 1 \\
& 2 \\
& 3 \\
& 4
\end{aligned}
\] & \[
\begin{aligned}
& 1 \\
& 1 \\
& 0 \\
& 1
\end{aligned}
\] & \begin{tabular}{l}
Op Code Address \\
Op Code Address +1 \\
Destination Address \\
Destination Address
\end{tabular} & \[
\begin{aligned}
& 1 \\
& 1 \\
& 1 \\
& 0
\end{aligned}
\] & \begin{tabular}{l}
Op Code \\
Destination Address \\
Irrelevant Data (Note 1) \\
Data from Accumulator
\end{tabular} \\
\hline \[
\begin{aligned}
& \text { STS } \\
& \text { STX }
\end{aligned}
\] & 5 & \[
\begin{aligned}
& 1 \\
& 2 \\
& 3 \\
& 4 \\
& 5
\end{aligned}
\] & 1
1
0
1
1 & \begin{tabular}{l}
Op Code Address \\
Op Code Address + 1 \\
Address of Operand \\
Address of Operand \\
Address of Operand +1
\end{tabular} & 1
1
1
0
0 & \begin{tabular}{l}
Op Code \\
Address of Operand \\
Irrelevant Data (Note 1) \\
Register Data (High Order Byte) \\
Register Data (Low Order Byte)
\end{tabular} \\
\hline
\end{tabular}

Note 1. If device which is address during this cycle uses VMA, then the Data Bus will go to the high impedance three-state condition. Depending on bus capacitance, data from the previous cycle may be retained on the Data Bus.

FIGURE 31 - EXTENDED ADDRESSING MODE


TABLE 9 - EXTENDED MODE CYCLE-BY-CYCLE
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline Address Mode and Instructions & Cycles & Cycle & VMA Line & Address Bus & \(R / \bar{W}\) Line & Data Bus \\
\hline \[
\begin{aligned}
& \text { STS } \\
& \text { STX }
\end{aligned}
\] & 6 & \[
\begin{aligned}
& 1 \\
& 2 \\
& 3 \\
& 4 \\
& 5 \\
& 6
\end{aligned}
\] & \[
\begin{aligned}
& 1 \\
& 1 \\
& 1 \\
& 0 \\
& 1 \\
& 1
\end{aligned}
\] & \begin{tabular}{l}
Op Code Address \\
Op Code Address + 1 \\
Op Code Address + 2 \\
Address of Operand \\
Address of Operand \\
Address of Operand +1
\end{tabular} & \[
\begin{aligned}
& 1 \\
& 1 \\
& 1 \\
& 1 \\
& 0 \\
& 0
\end{aligned}
\] & \begin{tabular}{l}
Op Code \\
Address of Operand (High Order Byte) \\
Address of Operand (Low Order Byte) \\
Irrelevant Data (Note 1) \\
Operand Data (High Order Byte) \\
Operand Data (Low Order Byte)
\end{tabular} \\
\hline JSR & 9 & \[
\begin{aligned}
& \hline 1 \\
& 2 \\
& 3 \\
& 4 \\
& 5 \\
& 6 \\
& 7 \\
& 8 \\
& 9
\end{aligned}
\] & \[
\begin{aligned}
& \hline 1 \\
& 1 \\
& 1 \\
& 1 \\
& 1 \\
& 1 \\
& 0 \\
& 0 \\
& 1
\end{aligned}
\] & \begin{tabular}{l}
Op Code Address \\
Op Code Address + 1 \\
Op Code Address +2 \\
Subroutine Starting Address \\
Stack Pointer \\
Stack Pointer - 1 \\
Stack Pointer -- 2 \\
Op Code Address + 2 \\
Op Code Address +2
\end{tabular} & \[
\begin{aligned}
& 1 \\
& 1 \\
& 1 \\
& 1 \\
& 0 \\
& 0 \\
& 1 \\
& 1 \\
& 1
\end{aligned}
\] & \begin{tabular}{l}
Op Code \\
Address of Subroutine (High Order Byte) \\
Address of Subroutine (Low Order Byte) \\
Op Code of Next Instruction \\
Return Address (Low Order Byte) \\
Return Address (High Order Byte) \\
Irrelevant Data (Note 1) \\
Irrelevant Data (Note 1 ) \\
Address of Subroutine (Low Order Byte)
\end{tabular} \\
\hline JMP & 3 & \[
\begin{aligned}
& \hline 1 \\
& 2 \\
& 3
\end{aligned}
\] & \[
1
\] & \begin{tabular}{l}
Op Code Address \\
Op Code Address + 1 \\
Op Code Address + 2
\end{tabular} & \[
1
\] & \begin{tabular}{l}
Op Code \\
Jump Address (High Order Byte) \\
Jump Address (Low Order Byte)
\end{tabular} \\
\hline \begin{tabular}{ll} 
& \\
\hline ADC & EOR \\
ADD & LDA \\
AND & ORA \\
BIT & SBC \\
CMP & SUB
\end{tabular} & 4 & \[
\begin{aligned}
& 1 \\
& 2 \\
& 3 \\
& 4
\end{aligned}
\] & \[
\begin{aligned}
& 1 \\
& 1 \\
& 1 \\
& 1
\end{aligned}
\] & \begin{tabular}{l}
Op Code Address \\
Op Code Address +1 \\
Op Code Address +2 \\
Address of Operand
\end{tabular} & \[
\begin{aligned}
& 1 \\
& 1 \\
& 1 \\
& 1
\end{aligned}
\] & \begin{tabular}{l}
Op Code \\
Address of Operand (High Order Byte) \\
Address of Operand (Low Order Byte) \\
Operand Data
\end{tabular} \\
\hline \[
\begin{aligned}
& \text { CPX } \\
& \text { LDS } \\
& \text { LDX }
\end{aligned}
\] & 5 & \[
\begin{aligned}
& 1 \\
& 2 \\
& 3 \\
& 4 \\
& 5
\end{aligned}
\] & \[
\begin{aligned}
& 1 \\
& 1 \\
& 1 \\
& 1 \\
& 1
\end{aligned}
\] & \begin{tabular}{l}
Op Code Address \\
Op Code Address +1 \\
Op Code Address +2 \\
Address of Operand \\
Address of Operand +1
\end{tabular} & \[
\begin{aligned}
& 1 \\
& 1 \\
& 1 \\
& 1 \\
& 1
\end{aligned}
\] & \begin{tabular}{l}
Op Code \\
Address of Operand (High Order Byte) \\
Address of Operand (Low Order Byte) \\
Operand Data (High Order Byte) \\
Operand Data (Low Order Byte)
\end{tabular} \\
\hline \[
\begin{aligned}
& \text { STA A } \\
& \text { STA B }
\end{aligned}
\] & 5 & \[
\begin{aligned}
& 1 \\
& 2 \\
& 3 \\
& 4 \\
& 5
\end{aligned}
\] & \[
\begin{aligned}
& 1 \\
& 1 \\
& 1 \\
& 0 \\
& 1
\end{aligned}
\] & \begin{tabular}{l}
Op Code Address \\
Op Code Address + ? \\
Op Code Address +2 \\
Operand Destination Address \\
Operand Destination Address
\end{tabular} & \[
\begin{aligned}
& 1 \\
& 1 \\
& 1 \\
& 1 \\
& 0
\end{aligned}
\] & \begin{tabular}{l}
Op Code \\
Destination Address (High Order Byte) \\
Destination Address (Low Order Byte) \\
Irrelevant Data (Note 1) \\
Data from Accumulator
\end{tabular} \\
\hline \begin{tabular}{ll} 
ASL & LSR \\
ASR & NEG \\
CLR & ROL \\
COM & ROR \\
DEC & TST \\
INC &
\end{tabular} & 6 & \[
\begin{aligned}
& 1 \\
& 2 \\
& 3 \\
& 4 \\
& 5 \\
& 6
\end{aligned}
\] & 1
1
1
1
0
\(1 / 0\)
(Note
2 ) & \begin{tabular}{l}
Op Code Address \\
Op Code Address +1 \\
Op Code Address +2 \\
Address of Operand \\
Address of Operand \\
Address of Operand
\end{tabular} & \[
\begin{aligned}
& \hline 1 \\
& 1 \\
& 1 \\
& 1 \\
& 1 \\
& 0
\end{aligned}
\] & \begin{tabular}{l}
Op Code \\
Address of Operand (High Order Byte) \\
Address of Operand (Low Order Byte) \\
Current Operand Data \\
Irrelevant Data (Note 1) \\
New Operand Data (Note 21
\end{tabular} \\
\hline
\end{tabular}

Note 1. If device which is addressed during this cycle uses VMA, then the Data Bus will go to the high impedance three-state condition. Depending on bus capacitance, data from the previous cycle may be retained on the Data Bus.
Note 2. For TST, VMA \(=0\) and Operand data does not change.

FIGURE 32 - RELATIVE ADDRESSING MODE


FIGURE 33 - INDEXED ADDRESSING MODE


TABLE 10 - RELATIVE MODE CYCLE-BY-CYCLE OPERATION
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline \begin{tabular}{c} 
Address Mode \\
and Instructions
\end{tabular} & Cycles & \begin{tabular}{c} 
Cycle \\
\(\#\)
\end{tabular} & \begin{tabular}{l} 
VMA \\
Line
\end{tabular} & Address Bus & \begin{tabular}{c} 
R/W \\
Line
\end{tabular} & Data Bus \\
\hline
\end{tabular}
\begin{tabular}{|c|c|c|c|c|c|c|c|c|}
\hline BCC & BH1 & BNE & \multirow{5}{*}{4} & 1 & 1 & Op Code Address & 1 & Op Code \\
\hline BCS & BLE & BPL & & 2 & 1 & Op Code Address +1 & 1 & Branch Offset \\
\hline BEQ & BLS & BRA & & 3 & 0 &  & 1 & Irrelevant Data (Note 1 ) \\
\hline BGE & BLT & BVC & & 3 & 0 & Op Code Address + 2 & 1 & Irrelevant Data (Note 1) \\
\hline BGT & BM1 & BVS & & 4 & 0 & Branch Address & 1 & Irrelevant Data (Note 1) \\
\hline \multirow[t]{8}{*}{BSR} & & & \multirow{8}{*}{8} & 1 & 1 & Op Code Address & 1 & Op Code \\
\hline & & & & 2 & 1 & Op Code Address + 1 & 1 & Branch Offset \\
\hline & & & & 3 & 0 & Return Address of Main Program & 1 & Irrelevant Data (Note 1) \\
\hline & & & & 4 & 1 & Stack Pointer & 0 & Return Address (Low Order Byte) \\
\hline & & & & 5 & 1 & Stack Pointer - 1 & 0 & Return Address (High Order Byte) \\
\hline & & & & 6 & 0 & Stack Pointer - 2 & 1 & Irrelevant Data (Note 1) \\
\hline & & & & 7 & 0 & Return Address of Main Program & 1 & Irrelevant Data (Note 11 \\
\hline & & & & 8 & 0 & Subroutine Address & 1 & Irrelevant Data (Note 1) \\
\hline
\end{tabular}

Note 1. If device which is addressed during this cycle uses VMA, then the Data Bus will go to the high impedance three-state condition. Depending on bus capacitance, data from the previous cycle may be retained on the Data Bus.

MOTOROLA Semiconductor Products Inc.

TABLE 11 - INDEXED MODE CYCLE-BY-CYCLE
\begin{tabular}{|c|c|c|c|c|c|c|}
\hline Address Mode and Instructions & Cycles & Cycle \# & VMA Line & Address Bus & \[
\begin{aligned}
& \hline R / \bar{W} \\
& \text { Line }
\end{aligned}
\] & Data Bus \\
\hline \multicolumn{7}{|l|}{INDEXED} \\
\hline JMP & 4 & \[
\begin{aligned}
& 1 \\
& 2 \\
& 3 \\
& 4
\end{aligned}
\] & \[
\begin{aligned}
& 1 \\
& 1 \\
& 0 \\
& 0
\end{aligned}
\] & \begin{tabular}{l}
Op Code Address \\
Op Code Address +1 \\
Index Register \\
Index Register Plus Offset (w/o Carry)
\end{tabular} & \[
\begin{aligned}
& 1 \\
& 1 \\
& 1 \\
& 1
\end{aligned}
\] & \begin{tabular}{l}
Op Code \\
Offset \\
Irrelevant Data (Note 1) \\
Irrelevant Data (Note 1)
\end{tabular} \\
\hline \begin{tabular}{ll} 
ADC & EOR \\
ADD & LDA \\
AND & ORA \\
BIT & SBC \\
CMP & SUB
\end{tabular} & 5 & \[
\begin{aligned}
& 1 \\
& 2 \\
& 3 \\
& 4 \\
& 5
\end{aligned}
\] & \[
\begin{aligned}
& 1 \\
& 1 \\
& 0 \\
& 0 \\
& 1
\end{aligned}
\] & \begin{tabular}{l}
Op Code Address \\
Op Code Address + 1 \\
Index Register \\
Index Register Plus Offset (w/o Carry) \\
Index Register Plus Offset
\end{tabular} &  & \begin{tabular}{l}
Op Code \\
Offset \\
Irrelevant Data (Note 1) \\
Irrelevant Data (Note 1) \\
Operand Data
\end{tabular} \\
\hline \[
\begin{aligned}
& \text { CPX } \\
& \text { LDS } \\
& \text { LDX }
\end{aligned}
\] & 6 & \[
\begin{aligned}
& 1 \\
& 2 \\
& 3 \\
& 4 \\
& 5 \\
& 6
\end{aligned}
\] & \[
\begin{aligned}
& 1 \\
& 1 \\
& 0 \\
& 0 \\
& 1 \\
& 1
\end{aligned}
\] & \begin{tabular}{l}
```

Op Code Address <br>
Op Code Address + 1 <br>
Index Register <br>
Index Register Plus Offset (w/o Carry) <br>
Index Register Plus Offset <br>
Index Register Plus Offset +1

```
\end{tabular} & \[
\begin{aligned}
& 1 \\
& 1 \\
& 1 \\
& 1 \\
& 1 \\
& 1
\end{aligned}
\] & \begin{tabular}{l}
Op Code \\
Offset \\
Irrelevant Data (Note 1) \\
Irrelevant Data (Note 1) \\
Operand Data (High Order Byte) \\
Operand Data (Low Order Byte)
\end{tabular} \\
\hline STA & 6 & \[
\begin{aligned}
& 1 \\
& 2 \\
& 3 \\
& 4 \\
& 5 \\
& 6
\end{aligned}
\] & \[
\begin{aligned}
& 1 \\
& 1 \\
& 0 \\
& 0 \\
& 0 \\
& 1
\end{aligned}
\] & \begin{tabular}{l}
Op Code Address \\
Op Code Address + 1 \\
Index Register \\
Index Register Plus Offset (w/o Carry) \\
Index Register Plus Offset \\
Index Register Plus Offset
\end{tabular} & \[
\begin{aligned}
& 1 \\
& 1 \\
& 1 \\
& 1 \\
& 1 \\
& 0 \\
& \hline
\end{aligned}
\] & \begin{tabular}{l}
Op Code \\
Offset \\
Irrelevant Data (Note 1) \\
Irrelevant Data (Note 1) \\
Irrelevant Data (Note 1) \\
Operand Data
\end{tabular} \\
\hline \begin{tabular}{ll} 
ASL & LSR \\
ASR & NEG \\
CLR & ROL \\
COM & ROR \\
DEC & TST \\
INC &
\end{tabular} & 7 & \[
\begin{aligned}
& 1 \\
& 2 \\
& 3 \\
& 4 \\
& 5 \\
& 6 \\
& 7
\end{aligned}
\] & \[
\begin{gathered}
\hline 1 \\
1 \\
0 \\
0 \\
1 \\
0 \\
1 / 0 \\
\text { (Note } \\
2 \text { ) } \\
\hline
\end{gathered}
\] & \begin{tabular}{l}
Op Code Address \\
Op Code Address +1 \\
Index Register \\
Index Register Plus Offset (w/o Carry) \\
Index Register Plus Offset \\
Index Register Plus Offset \\
Index Register Plus Offset
\end{tabular} & \[
\begin{aligned}
& 1 \\
& 1 \\
& 1 \\
& 1 \\
& 1 \\
& 1 \\
& 0
\end{aligned}
\] & \begin{tabular}{l}
Op Code \\
Offset \\
Irrelevant Data (Note 1) \\
Irrelevant Data (Note 1) \\
Current Operand Data \\
Irrelevant Data (Note 1) \\
New Operand Data (Note 2)
\end{tabular} \\
\hline \[
\begin{aligned}
& \text { STS } \\
& \text { STX }
\end{aligned}
\] & 7 & \[
\begin{aligned}
& 1 \\
& 2 \\
& 3 \\
& 4 \\
& 5 \\
& 6 \\
& 7
\end{aligned}
\] & \[
\begin{aligned}
& 1 \\
& 1 \\
& 0 \\
& 0 \\
& 0 \\
& 1 \\
& 1
\end{aligned}
\] & \begin{tabular}{l}
Op Code Address \\
Op Code Address + 1 \\
Index Register \\
Index Register Plus Offset (w/o Carry) \\
Index Register Plus Offset \\
Index Register Plus Offset \\
Index Register Plus Offset +1
\end{tabular} & \[
\begin{aligned}
& 1 \\
& 1 \\
& 1 \\
& 1 \\
& 1 \\
& 0 \\
& 0
\end{aligned}
\] & \begin{tabular}{l}
Op Code \\
Offset \\
Irrelevant Data (Note 1) \\
Irrelevant Data (Note 1) \\
Irrelevant Data (Note 1) \\
Operand Data (High Order Byte) \\
Operand Data (Low Order Byte)
\end{tabular} \\
\hline JSR & 8 & \[
\begin{aligned}
& 1 \\
& 2 \\
& 3 \\
& 4 \\
& 5 \\
& 6
\end{aligned}
\] & \[
\begin{aligned}
& 1 \\
& 1 \\
& 0 \\
& 1 \\
& 1 \\
& 0 \\
& 0 \\
& 0
\end{aligned}
\] & \begin{tabular}{l}
Op Code Address \\
Op Code Address +1 \\
Index Register \\
Stack Pointer \\
Stack Pointer - 1 \\
Stack Pointer - 2 \\
Index Register \\
Index Register Plus Offset (w/o Carry)
\end{tabular} & \[
\begin{aligned}
& 1 \\
& 1 \\
& 1 \\
& 0 \\
& 0 \\
& 1 \\
& 1 \\
& 1
\end{aligned}
\] & \begin{tabular}{l}
Op Code \\
Offset \\
Irrelevant Data (Note 1) \\
Return Address (Low Order Byte) \\
Return Address (High Order Byte) \\
Irrelevant Data (Note 1) \\
Irrelevant Data (Note 1) \\
Irrelevant Data (Note 1)
\end{tabular} \\
\hline
\end{tabular}

Note 1. If device which is addressed during this cycle uses VMA, then the Data Bus will go to the high impedance three-state condition. Depending on bus capacitance, data from the previous cycle may be retained on the Data Bus.
Note 2. For TST, VMA \(=0\) and Operand data does not change.

MOTOROLA Semiconductor Products Inc.

\section*{PACKAGE DIMENSIONS}


Motorola reserves the right to make changes to any products herein to improve reliability, function or design. Motorola does not assume any liability arising out of the application or use of any product or circuit described herein; neither does it convey any license under its patent rights nor the rights of others.```


[^0]:    2. Unassigned code indicated by ${ }^{\prime \prime *} *$.
