UM6502E

## Features

- UM6502E is the enhanced timing version of UM6502
- Single $5 \mathrm{~V} \pm 5 \%$ power supply
- N channel, silicon gate, depletion load technology
- 56 instructions
- Decimal and binary arithmetic
- Thirteen addressing modes
- True indexing capability
- Programmable stack pointer
- Variable length stack
- Interrupt capability
- Non-maskable interrupt


## General Description

The UM6502/UM6502E/UM6507/UM6512 microprocessors are totally software compatible with one another. These products provide a selection of addressable memory range, interrupt input options and on-chip clock oscillators and drivers. The UM6502/UM6502E/ UM6507 on-chip clock versions are aimed at high

- Bi-directional data bus
- Addressable memory range of up to 64 K bytes
- "Ready" input
- Direct memory access capability
- Bus compatible with MC6800
- Choice of external or on-board clocks
- $1 \mathrm{MHz}, 2 \mathrm{MHz}, 3 \mathrm{MHz}$ and 4 MHz versions
- On-chip clock options
- External single clock input
- Crystal time base input
- Pipeline architecture
performance, low cost applications where single phase inputs or crystals provide the time base. The UM6512 external clock version is geared for the multi-processor system applications where maximum timing control is mandatory. These products are bus compatible with the MC6800 product offering


## Pin Configurations




| Absolute Maximum Ratings* |  |
| :---: | :---: |
| Supply Voltage $\mathrm{V}_{\text {CC }}$ | -0.3 to +7.0 V |
| input Voltage $\mathrm{V}_{\text {in }}$ | -0.3 to +7.0V |
| Operating Temperature $T_{A}$ | 0 to $70^{\circ} \mathrm{C}$ |
| Storage Temperature $\mathrm{T}_{\text {STG }}$ | -55 to $+150^{\circ} \mathrm{C}$ |

## *Comments

Stresses above those listed under "Absolute Maximum Ratings" may cause permanent damage to the device. These are stress ratings only. Functional operation of this device at these or any other conditions above those indicated in the operational sections of this specification is not implied and exposure to absolute maximum rating conditions for extended periods may affect device reliability.
D.C. Electrical Characteristics $\left(V_{C C}=5.0 \mathrm{~V} \pm 5 \%, T_{A}=0-70^{\circ} \mathrm{C}\right)$
( $\phi_{1}, \phi_{2}$ applies to UM6512, $\phi_{0 \text { (in) }}$ applies to UM6502/UM6502E/UM6507)

| Symbol | Characteristics | Min. | Max. | Unit |
| :---: | :---: | :---: | :---: | :---: |
| $\mathrm{V}_{\text {IH }}$ | $\begin{aligned} & \text { Input High Voltage } \\ & \left.\begin{array}{l} \text { Logic and } \phi 0 \text { (in) for } \\ \text { UM6502/UM6502E/UM6507 } \end{array}\right\}\left\{\begin{array}{l} 1,2,3 \mathrm{MHz} \\ 4 \mathrm{MHz} \\ \left.\begin{array}{l} \text { and } \phi_{2} \text { only for } \\ \text { UM6512 } \end{array}\right\} \quad \text { All Speeds } \end{array}\right. \end{aligned}$ | $\begin{gathered} +2.0 \\ +3.3 \\ v_{C C}-0.5 \end{gathered}$ | $\begin{gathered} V_{C C} \\ V_{C C} \\ V_{C C}+0.25 \end{gathered}$ | $\begin{aligned} & V \\ & V \\ & V \end{aligned}$ |
| $V_{\text {IL }}$ | Input Low Voltage  <br> Logic, $\phi_{0}$ (in) (UM6502/UM6502E/UM6507) <br> $\phi_{1}, \phi_{2}$ (UM6512) | $\begin{aligned} & -0.3 \\ & -0.3 \end{aligned}$ | $\begin{aligned} & +0.8 \\ & +0.2 \end{aligned}$ | V |
| $I_{\text {IL }}$ | Input Loading $\begin{gathered} \left(V_{\text {in }}=0 \mathrm{~V}, \mathrm{~V}_{C C}=5.25 \mathrm{~V}\right) \\ \text { RDY. S.O. } \end{gathered}$ | -10 | -300 | $\mu \mathrm{A}$ |
| $\mathrm{I}_{\text {in }}$ | Input Leakage Current $\begin{aligned} & \left(\mathrm{V}_{\text {in }}=0 \text { to } 5.25 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=0\right) \\ & \text { Logic }(\text { Excl. RDY. S.O.) } \\ & \phi_{1}, \phi_{2} \\ & \phi_{0(\text { in })} \end{aligned} \quad \text { (UM6512) } \quad \text { (UM6502/UM6502E/UM6507) }$ | - | $\begin{gathered} 2.5 \\ 100 \\ 10.0 \end{gathered}$ | $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ <br> $\mu \mathrm{A}$ |
| ITSI | Three-State (Off State) Input Current $\begin{aligned} & \left(\mathrm{V}_{\text {in }}=0.4 \text { to } 2.4 \mathrm{~V}, \mathrm{~V}_{\mathrm{CC}}=5.25 \mathrm{~V}\right) \\ & \text { DBO-DB7 } \end{aligned}$ | - | $\pm 10$ | $\mu \mathrm{A}$ |
| VOH | ```Output High Voltage (\|}\mp@subsup{|}{\mathrm{ OAD }}{}=-100\mu\textrm{Adc},\mp@subsup{V}{CC}{}=4.75\textrm{V}) 1, 2 MH SYNC, DBO-DB7, AB0-AB15, R\overline{W}``` | 2.4 | - | V |
| $\mathrm{V}_{\mathrm{OL}}$ | Output Low Voltage $\begin{aligned} & \left(I_{\text {LOAD }}=1.6 \mathrm{mAdc}, \mathrm{~V}_{\mathrm{CC}}=4.75 \mathrm{~V}\right) \quad 1.2 \mathrm{MHz} \\ & \text { SYNC, DBO-DB7, ABO-AB15, RM } \end{aligned}$ | - | 0.4 | V |
| $P_{D}$ | Power Dissipation <br> 1 MHz and 2 MHz ( $\mathrm{V}_{\mathrm{CC}}=5.25 \mathrm{~V}$ ) | - | 700 | mW |
| C $C_{\text {in }}$ <br> $C_{\text {out }}$ <br> $\mathrm{C}_{\phi_{0}}(\mathrm{in})$ <br> C ${ }^{\circ} 1$ <br> $\mathrm{C} \phi_{2}$ | $\begin{aligned} & \text { Capacitance } \\ & \left(V_{\text {in }}=0, T_{A}=25^{\circ} \mathrm{C}, f=1 \mathrm{MHz}\right) \\ & \overline{\mathrm{RES}, \overline{\mathrm{NMI}}, \mathrm{RDY}, \overline{\mathrm{RQ}}, \mathrm{~S} . \mathrm{O} ., \mathrm{DBE}} \\ & \text { DBO-DB7 } \\ & \begin{array}{ll} \mathrm{ABO}-\mathrm{AB} 15, R \bar{W}, \mathrm{SYNC} \\ \phi_{0}(\text { in }) & \text { (UM6502/UM6502E/UM6507) } \\ \phi_{1} & \text { (UM6512) } \\ \phi_{2} & \text { (UM5512) } \end{array} \end{aligned}$ | - - - - | $\begin{aligned} & 10 \\ & 15 \\ & 12 \\ & 15 \\ & 50 \\ & 80 \end{aligned}$ | pF |

## Block Diagram



Notes: 1. Clock generator is not included on UM6512.
2. Addressing capability and control options vary with each product.


Dynamic Operating Characteristics $\left(V_{C C}=5.0 \pm 5 \%, T_{A}=0^{\circ}\right.$ to $\left.70^{\circ} \mathrm{C}\right)$

| Parameter | Symbal | 1 MHz |  | 2 MHz |  | 3 MHz |  | 4 MHz |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| UM6502E |  |  |  |  |  |  |  |  |  |  |
| Cycle Time | ${ }^{T} \mathrm{CYC}$ | 1.00 | 40 | 0.50 | 40 | 0.33 | 40 | 0.25 | 40 | $\mu \mathrm{s}$ |
| $\phi_{0}($ IN $)$ Low Time ${ }^{(2)}$ | $T L \phi_{0}$ | 480 | - | 240 | - | 160 | - | 110 | - | ns |
| $\phi_{0}$ (IN) High Time ${ }^{(2)}$ | TH $\Phi_{0}$ | 460 | - | 240 | - | 160 | - | 115 | - | ns |
| $\phi_{0}$ Neg to $\phi_{1}$ Pos Delay ${ }^{(5)}$ | ${ }^{\text {c }} 01+$ | 10 | 70 | - | 50 | - | 45 | - | 35 | ns |
| $\phi_{0}$ Neg to $\phi_{2}$ Neg Delay ${ }^{(5)}$ | ${ }^{\text {º2- }}$ | 5 | 65 | - | 45 | - | 40 | - | 35 | ns |
| $\phi_{0}$ Pos to $\phi_{1}$ Neg Delay ${ }^{(5)}$ | $\mathrm{T}^{\text {01- }}$ | 5 | 65 | - | 45 | - | 40 | - | 30 | ns |
| $\phi_{0}$ Pos to $\phi_{2}$ Pos Delay ${ }^{(5)}$ | ${ }^{T} 02+$ | 15 | 75 | - | 45 | - | 45 | - | 35 | ns |
| $\phi_{0}(1 N)$ Rise and Fall Time ${ }^{(1)}$ | $\mathrm{T}_{\text {RO }} \cdot \mathrm{T}_{\text {FO }}$ | 0 | 30 | - | 20 | - | 15 | - | 10 | ns |
| $\phi_{1}$ (OUT). Pulse Width | $\mathrm{T}_{\text {PWH }}{ }_{\text {, }} \mathrm{T}_{\text {, }}$ | $T_{L \phi_{0}}-20$ | ${ }^{T}$ L¢ ${ }_{\text {o }}$ | ${ }^{T} L \phi_{0}-20$ | $T_{L \varphi_{0}}$ |  | $T_{L \varphi_{0}}$ | ${ }^{\top}{\operatorname{L\Phi } \Phi_{0}} \cdot 20$ | ${ }^{T} L \varphi_{0}$ | ns |
| $\phi_{2}$ (OUT). Pulse Width | $\mathrm{T}_{\text {PWH } \text { ¢ }_{2}}$ | $T_{L \phi_{0}} \cdot 40$ | $T_{L \phi_{0}} \cdot 10$ | $T_{L \varphi_{0}} 40$ | $T_{L \phi_{0}} 40$ | $T_{L \phi_{0}}{ }^{40}$ | $T_{L \phi_{0}} 40$ | $T_{L \phi_{0}} 40$ | $T_{L \phi_{0}}{ }^{-10}$ | ns |
| Delay Between $\phi_{1}$ and $\Phi_{2}$ | $T_{D}$ | 5 | - | 5 | - | 5 | - | 5 | - | ns |
| $\phi_{1}$ and $\phi_{2}$ Rise and Fall Times ${ }^{(1,3)}$ | $T_{R} \cdot{ }^{T} /{ }_{\text {F }}$ | - | 25 | - | 25 | - | 15 | - | 15 | ns |
| UM6502E |  |  |  |  |  |  |  |  |  |  |
| R/W Setup Time | $T_{\text {RWS }}$ | - | 125 | - | 100 | - | 75 | - | 60 | ns |
| R/W Hold Time | $T_{\text {RWW }}$ | 30 | - | 30 | - | 15 | - | 15 | - | ns |
| Address Setup Time | ${ }^{T}$ ADS | - | 125 | - | 100 | - | 75 | - | 70 | ns |
| Address Hold Time | ${ }^{T}$ ADH | 30 | - | 30 | - | 15 | - | 15 | - | ns |
| Read Access Time | ${ }^{\text {A }}$ ACC | - | 1000.225 | - | 500-150 | - | 330-115 | - | 250.105 | ns |
| Fead Data Setup Time | ToSU | 100 | - | 50 | - | 40 | - | 35 | - | ns |
| Read Data Hold Time | $T_{\text {HR }}$ | 10 | - | 10 | - | 10 | - | 10 | - | ns |
| Write Data Setup Time | $T_{\text {MDS }}$ | 20 | 175 | - | 100 | - | 75 | - | 60 | ns |
| Write Data Hold Time | $T_{\text {HW }}$ | 60 | - | 60 | - | 30 | - | 30 | - | ns |
| Sync Setup Time | ${ }^{T}$ SYS | - | 125 | - | 100 | - | 75 | - | 60 | ns |
| Sync Hold Time | $\mathrm{T}_{\text {SYH }}$ | 30 | - | 30 | - | 15 | - | 15 | - | ns |
| RDY Setup Time ${ }^{(4)}$ | $\mathrm{T}_{\text {RS }}$ | 200 | - | 150 | - | 120 | - | 120 | - | ns |
| UM6512 |  |  |  |  |  |  |  |  |  |  |
| Cycle Time | ${ }^{T}$ CYC | 1.00 | 40 | 0.50 | 40 | 0.33 | 40 | 0.25 | 40 | $\mu \mathrm{s}$ |
| $\phi_{1}$ Pulse Width | ${ }^{\text {T PWH } \phi_{1}}$ | 430 | - | 215 | - | 150 | - |  |  | ns |
| $\Phi_{2}$ Pulse Width | $\mathrm{T}_{\text {PWH } \text { ¢ }_{2}}$ | 470 | - | 235 | - | 160 | - |  |  | ns |
| Delay Between $\Phi_{2}$ and $\Phi_{2}$ | ${ }^{T}$ D | 0 | - | 0 | - | 0 | - |  |  | ns |
| $\phi_{1}$ and $\phi_{2}$ Rise and Fall Times ${ }^{(1)}$ | $\mathrm{T}_{\mathrm{R}} \cdot{ }^{\text {T }} \mathrm{F}$ | 0 | 25 | 0 | 20 | 0 | 15 |  |  | ns |


| Parameter | Symbal | 1 MHz |  | 2 MHz |  | 3 MHz |  | 4 MHz |  | Units |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min. | Max. | Min. | Max. | Min. | Max. | Min. | Max. |  |
| UM6502/UM6507 |  |  |  |  |  |  |  |  |  |  |
| Cycle Time | ${ }^{\text {T CYC }}$ | 1.00 | 40 | 0.50 | 40 | 0.33 | 40 | 0.25 | 40 | $\mu \mathrm{S}$ |
| $\phi_{1}($ IN $)$ Low Time ${ }^{(2)}$ | $T_{L \varphi_{0}}$ | 480 | - | 240 | - | 160 | - | 110 | - | ns |
| $\phi_{0}($ IN $)$ High Time ${ }^{(2)}$ | $T^{T} \phi_{0}$ | 460 | - | 240 | - | 160 | - | 115 | - | ns |
| $\phi_{0}$ Neg to $\phi_{1}$ Pos Delay ${ }^{(5)}$ | $\mathrm{T}_{01+}$ | 10 | 70 | 10 | 70 | 10 | 70 | 10 | 70 | ns |
| $\phi_{0}$ Neg to $\phi_{2}$ Neg Delay ${ }^{(5)}$ | T02- | 5 | 65 | 5 | 65 | 5 | 65 | 5 | 65 | ns |
| $\phi_{0}$ Pos to $\phi_{1}$ Neg Delay ${ }^{(5)}$ | T01- | 5 | 65 | 5 | 65 | 5 | 65 | 5 | 65 | ns |
| $\phi_{0}$ Pos to $\phi_{2}$ Pos Delay (5) | ${ }^{T} 02+$ | 15 | 75 | 15 | 75 | 15 | 75 | 15 | 75 | ns |
| $\phi_{0}(I N)$ Rise and Fail Time ${ }^{(1)}$ | $\mathrm{T}_{\text {RO, }}{ }^{\text {T FO }}$ | 0 | 30 | 0 | 20 | 0 | 15 | 0 | 10 | ns |
| $\phi_{1}$ (OUT), Pulse Width | $T^{\text {PWWH }}{ }_{1}{ }_{1}$ | $T_{L \phi_{0}}-20$ | $T_{L \phi_{0}}$ | $T^{T} L \phi_{0}-20$ | $T_{L \phi_{0}}$ | $T_{L \varphi_{0}} \cdot 20$ | $T_{L \phi_{0}}$ | $T_{L \Phi_{n}}{ }^{-20}$ | $T_{L} \phi_{0}$ | ns |
| $\phi_{2}$ (OUT). Pulse Width | $\mathrm{T}_{\mathrm{PWH}} \Phi_{2}$ | $T_{L \phi_{0}}-40$ | $T_{L \phi_{0}}-10$ | $T_{L \phi_{0}} \cdot 40$ | $T_{L \phi_{0}}-40$ | $T_{L \phi_{0}} \cdot 40$ | $T_{L \phi_{0}}{ }^{-10}$ | $T_{L \phi_{0}}{ }^{-40}$ | $T_{L \phi_{0}}{ }^{-10}$ | ns |
| Delay Between $\phi_{1}$ and $\phi_{2}$ | ${ }^{\text {T }}$ | 5 | - | 5 | - | 5 | T ${ }^{\text {d }}$ | 5 |  | ns |
| $\phi_{1}$ and $\Phi_{2}$ Rise and Fall Times(1, 3) | $T_{R}, T_{F}$ | - | 25 | - | 25 | - | 15 | - | 15 | ns |
| UM6502/UM6507/UM6512 |  |  |  |  |  |  |  |  |  |  |
| RMW Setup Time | $T_{\text {RWS }}$ | - | 225 | - | 140 | - | 110 | - | 90 | ns |
| RNW Hold Time | $T_{\text {RWW }}$ | 30 | - | 30 | - | 15 | - | 10 | - | ns |
| Address Setup Time | TADS | - | 225 | - | 140 | - | 110 | - | 90 | ns |
| Address Hold Time | TADH | 30 | - | 30 | - | 15 | - | 10 | - | ns |
| Read Access Time | ${ }^{\text {T ACC }}$ | - | 650 | - | 310 | - | 170 | - | 110 | ns |
| Read Data Setup Time | ${ }^{\text {T DSU }}$ | 100 | - | 50 | - | 50 | - | 50 | - | ns |
| Read Data Hold Time | $T_{\text {HR }}$ | 10 | - | 10 | - | 10 | - | 10 | - | ns |
| Write Data Setup Time | TMDS | 20 | 175 | 20 | 100 | 20 | 75 | - | 70 | ns |
| Write Data Hold Time | THW | 60 | 150 | 60 | 150 | 30 | 130 | 20 | - | ns |
| Sync Setup Time | ${ }^{\text {TSYS }}$ | - | 350 | - | 175 | - | 100 | - | 90 | ns |
| Sync Hold Time | TSYH | 30 | - | 30 | - | 15 | - | 15 | - | ns |
| RDY Setup Time ${ }^{(4)}$ | ${ }^{T}$ RS | 200 | - | 200 | - | 150 | - | 120 | - | ns |

## Notes:

. Measured between 10\% and 90\% points.
2. Measured at $50 \%$ points.
3. Load $=1$ TTL load +30 pF .

RDY must never switch states within $T_{\text {RS }}$ to end of $\phi_{2}$
5. Load $=100 \mathrm{pF}$.
6. The 2 MHz devices are identified by an " $A$ " suffix
7. The 3 MHz devices are identified by an " $B$ " suffix.
8. The 4 MHz devices are identified by an " $C$ " suffix.

## Timing Diagram Note:

Because the clock generation for the UM6502/UM6502E/ UM6507 and UM6512 is different, the two clock timing sections are referenced to the main timing diagram by three reference lines marked REF ' $A$ ', REF ' $B$ ' and REF ' $C$ '. Reference between the two sets of clock timings is without meaning. Timing parameters referring to these lines and scale variations in the diagrams are of no consequence.

## PIN FUNCTIONS

Clocks ( $\phi_{1}, \phi_{2}$ )
The UM6512 requires a two phase non-overlapping clock that runs at the $V_{C C}$ voltage level.
The UM6502/UM6502E/UM6507 clocks are supplied with an internal clock generator. The frequency of these clocks is externally controlled. Clock generator circuits are shown elsewhere in this data sheet

## Address Bus (AB0-AB15)

(See sections on each microprocessor for respective address lines on those devices.)
These outputs are TTL compatible, capable of driving one standard TTL load and 130 pF.

## Data Bus (DB0-DB7)

Eight pins are used for the data bus. This is a bidirectional bus, transferring data to and from the device and peripherals. The outputs are three-state buffers. capable of driving one standard TTL load and 130 pF .

## Data Bus Enable (DBE)

This TTL compatible input allows external control of the three-state data output buffers and will enable the microprocessor bus driver when in the high state. In normal operation DBE would be driven by the phase two $\left(\phi_{2}\right)$ clock, thus allowing data output from microprocessor only during $\phi_{2}$. During the read cycle, the data bus drivers are internally disabled, becoming essentially an open circuit. To disable data bus drivers externally, DBE should be held low. This signal is available on the UM6512 only.

## Reedy (RDY)

This input signal allows the user to halt the microprocessor on all cycles except write cycles. A negative transition to the low state during or coincident with phase one, $\left(\phi_{1}\right)$ will halt the microprocessor with the output address lines reflecting the current address being fetched. This condition will remain through a subsequent phase two ( $\phi_{2}$ ) in which the Ready signal is low. This feature allows microprocessor interfacing with low speed PROMS as well as fast (max. 2 cycle) Direct Memory Access (DMA). If ready is low during a write cycle, it is ignored until the following read operation. Ready transitions must not be permitted during $\boldsymbol{\phi}_{\mathbf{2}}$ time.

## Interrupt Request (IRO)

This TTL level input requests that an interrupt sequence begin within the microprocessor. The microprocessor will complete the current instruction being executed before recognizing the request. At the time, the interrupt mask bit in the Status Code Register will be examined. If the interrupt mask flag is not set, the microprocessor will begin an interrupt sequence. The Program Counter and Processor Status Register are stored in the stack. The microprocessor will then set the interrupt mask flag high so that no futher interrupts may occur. At the end of this cycle, the program counter low will be loaded from address FFFE, and program counter high from location FFFF, therefore transferring program control to the memory vector located at these addresses. The RDY signal must be in the high state for any interrupt to be recognized. A $3 K \Omega$
external resistor should be used for proper wire-OR operation.

## Non-Maskable Interrupt ( $\overline{\text { NMI) }}$

A negative going transition on this input requests that a non-maskable interrupt sequence be generated within the microprocessor.
$\overline{\mathrm{NMI}}$ is an unconditional interrupt. Following com. pletion of the current instruction, the sequence of operations defined for IRO will be performed, reqardless of the state interrupt mask flag. The vector addresses loaded into the program counter, low and high, are locations FFFA and FFFB respectively, thereby transferring program control to the memory vector located at these addresses. The instructions loaded at these locations cause the microprocessor to branch to a non-maskable interrupt routine in memory.
$\overline{\mathrm{NMI}}$ also requires an external $3 \mathrm{~K} \Omega$ resistor to $\mathrm{V}_{\mathrm{CC}}$ for proper wire-OR operations.
Inputs $\overline{\mathrm{RO}}$ and $\overline{\mathrm{NMI}}$ are hardware interrupts lines that are sampled during $\phi_{2}$ (phase 2) and will begin the appropriate interrupt routine on the $\phi_{1}$ (phase 1) following the completion of the current instruction.

## Set Overflow Flag (S. O.)

A NEGATIVE going edge on this input sets the overflow bit in the Status Code Register. This signal is sampled on the trailing edge of $\phi_{1}$.

## SYNC

This output line is provided to identify those cycles in which the microprocessor is doing an OP CODE fetch. The SYNC line goes high during $\phi_{1}$ of an OP CODE fetch and stays high for the remainder of that cycle If the RDY line is pulled low during the $\phi_{1}$ clock pulse in which SYNC went high, the processor will stop in its current state and will remain in the state until the RDY line goes high. In this manner, the SYNC signal can be used to control RDY to cause single instruction execution.

## Reset (RES)

This input is used to reset or start the microprocessor from a power down condition. During the time that this line is held low, writing to or from the microprocessor is inhibited. When a positive edge is detected on the input, the microprocessor will immediately begin the reset sequence.
After a system initialization time of six clock cycles, the mask interrupt flag will be set and the microprocessor will load the program counter from the memory vector locations FFFC and FFFD. This is the start location for program control.
After $V_{C C}$ reaches 4.75 volts in a power up routine, reset must be held low for at least two clock cycles. At this time the $R / \bar{W}$ and SYNC signal will become valid. When the reset signal goes high following these two clock cycles, the microprocessor will proceed with the normal reset procedure detailed above.

## Read/Write ( $\mathrm{R} / \overline{\mathbf{W}}$ )

This output signal is used to control the direction of data transfers between the processor and other circuits on the data bus. A high level on $R / \bar{W}$ signifies data into the processor; a low is for the data transfer out of the processor.

## PROGRAMMING CHARACTERISTICS

## INSTRUCTION SET - ALPHABETIC SEQUENCE

| ADC' | Add Memory to Accumulator with Carry | LDA | Load Accumulator with Memory |
| :--- | :--- | :--- | :--- |
| AND | "AND" Memory with Accumulator | LDX | Load Index X with Memory |
| ASL | Shift left One Bit (Memory or Accumulator) | LDY | Load Index Y with Memory |
| BCC | Branch on Carry Clear | LSR | Shift One Bit Right (Memory or Accumulator) |
| BCS | Branch on Carry Set | NOP | No Operation |
| BEQ | Branch on Result Zero | ORA | "OR" Memory with Accumulator |
| BIT | Test Bits in Memory with Accumulator | PHA | Push Accumulator on Stack |
| BMI | Branch on Result Minus | PHP | Push Processor Status on Stack |
| BNE | Branch on Result not Zero | PLA | Pull Accumulator from Stack |
| BPL | Branch on Result Plus | PLP | Pull Processor Status from Stack |
| BNK | Force Break | ROL | Rotate One Bit Left (Memory or Accumulator) |
| BVC | Branch on Overflow Clear | ROR | Rotate One Bit Right (Memory or Accumu- |
| BVS | Branch on Overflow Set |  | lator) |
| CLC | Clear Carry Flag | RTI | Return from Interrupt |
| CLD | Clear Decimal Mode | RTS | Return from Subroutine |
| CLI | Clear Interrupt Disable Bit | SBC | Subtract Memory from Accumulator |
| CLV | Clear Overflow Flag |  | with Borrow |
| CMP | Compare Memory and Accumulator | SEC | Set Carry Flag |
| CPX | Compare Memory and Index X | SED | Set Decimal Mode |
| CPY | Compare Memory and Index $Y$ | SEI | Set Interrupt Disable Status |
| DEC | Decrement Memory by One | STA | Store Accumulator in Memory |
| DEX | Decrement Index X by One | STX | Store Index X in Memory |
| DEY | Decrement Index Y by One | STY | Store Index Y in Memory |
| EOR | "Exclusive-or" Memory with Accumulator | TAX | Transfer Accumulator to Index X |
| INC | Increment Memory by One | TAY | Transfer Accumulator to Index Y |
| INX | Increment Index X by One | TSX | Transfer Stack Pointer to Index $X$ |
| INY | Increment Index Y by One | TXA | Transfer Index X to Accumulator |
| JMP | Jump to New Location | TXS | Transfer Index $X$ to Stack Pointer |
| JSR | Jump to New Location Saving Return Address | TYA | Transfer Index Y to Accumulator |

## ADDRESSING MODES

## Accumulator Addressing

This form of addressing is represented with a one byte instruction, implying an operation on the accumulator.

## Immediate Addressing

In immediate addressing, the operand is contained in the second byte of the instruction, with no further memory addressing required.

## Absolute Addressing

In absolute addressing, the second byte of the instruction specifies the eight low order bits of the effective address while the third byte specifies the eight high order bits. Thus, the absolute addressing mode allows access to the entire 65 K bytes of addressable memory.

## Zero Page Addressing

The zero page instructions allow for shorter code and execution times by only fetching the second byte of the
instruction and assuming a zero high address byte. careful use of the zero page can result in significant increase in code efficiency.

## Indexed Zero Page Addressing - ( $\mathbf{X}, \mathbf{Y}$ indexing)

This form of addressing is used in conjunction with the index register and is referred to as "Zero Page, " $X$ " or "Zero Page, Y." The effective address is calculated by adding the second byte to the contents of the index register. Since this is a form of "Zero Page" addressing, the content of the second byte references a location in page zero. Additionally due to the "Zero Page" addressing nature of this mode, no carry is added to the high order 8 bits of memory and crossing of page boundaries does not occur.

## Indexed Absolute Addressing - ( $\mathbf{X}, \mathbf{Y}$ indexing)

This form of addressing is used in conjunction with $X$ and $Y$ index registers and is referred to as "Absolute,
$X$." and "Absolute, $Y$." The effective address is formed by adding the contents of X or Y to the address contained in the second and third bytes of the instruction. This mode allows the index register to contain the index or count value and the instruction to contain the base address. This type of indexing allows any location referencing and the index to modify multiple fields resulting in reduced coding and execution time.

## Implied Addressing

In the implied addressing mode, the address containing the operand is implicitly stated in the operation code of the instruction.

## Relative Addressing

Relative addressing is used only with branch instructions and establishes a destination for the conditional branch.

The second byte of the instruction becomes the operand which is an "Offset" added to the contents of the lower eight bits of the program counter when the counter is set at the next instruction. The range of the offset is- 128 to +127 bytes from the next instruction.

## Indexed Indirect Addressing

In indexed indirect addressing (referred to as [Indirect, $X]$ ). the second byte of the instruction is added to the contents of the X index register, discarding the carry.

## PROGRAMMING CHARACTERISTICS

## PROGRAMMING MODEL

The result of this addition points to a memory location on page zero whose content is the low order eight bits of the effective address. The next memory location in page zero contains the high order eight bits of the effective address. Both memory locations specifying the high and low order bytes of the effective address must be in page zero

## Indirect Indexed Addressing

In indirect indexed addressing (referred to as [Indirect]. Y), the second byte of the instruction points to a memory location in page zero. The content of this memory location is added to the contents of the Y index register, the result being the low order eight bits of the effective address. The carry from this addition is added to the contents of the next page zero memory location, the result being the high order eight bits of the effective address.

## Absolute Indirect

The second byte of the instruction contains the low order eight bits of a memory location. The high order eight bits of that memory location is contained in the third byte of the instruction. The content of the fully specified memory location is the low order byte of the effective address. The next memory location contains the high order byte of the effective address which is loaded into the sixteen bits of the program counter.

[^0]

## Clock Generation Circuits* "Crystals used are CTS Knight MP Series or equivalents. (Series Mode)



| Crystal <br> Frequency | Output Frequency |  |
| :---: | :---: | :---: |
|  | $\div \mathbf{2}$ | $\div \mathbf{4}$ |
| 3.579545 MHz | 1.7897 MHz | 0.894886 MHz |
| 4.194304 MHz | 2.097152 MHz | 1.048576 MHz |



Ordering Information

| $\mathbf{1} \mathbf{M H z}$ | $\mathbf{2 ~ M H z}$ | $\mathbf{3} \mathbf{M H z}$ | $\mathbf{4} \mathbf{M H z}$ |
| :---: | :---: | :---: | :---: |
| UM6502 | UM6502A | UM6502B | UM6502C |
| UM6502E | UM6502AE | UM6502BE | UM6502CE |
| UM6507 | - | - | - |
| UM6512 | UM6512A | UM6512B | UM6512C |


| Part <br> Number | Clocks | Pins | IRO | NMI | RYD | Addressing |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| UM6502 | On-Chip | 40 | $\checkmark$ | $\checkmark$ | $\checkmark$ | $64 K$ |
| UM6502E | On-Chip | 40 | $\checkmark$ | $\checkmark$ | $\checkmark$ | $64 K$ |
| UM6507 | On-Chip | 28 | $\checkmark$ | $\checkmark$ | $\checkmark$ | $8 K$ |
| UM6512 | External | 40 | $\checkmark$ | $\checkmark$ | $\checkmark$ | $64 K$ |

## Instruction Set

| INSTRUCTIONS |  |  |  | IMMEטIATE |  |  | ABSO- <br> LUTE |  |  | $\begin{aligned} & \text { ZERO. } \\ & \text { PAGE } \end{aligned}$ |  |  | ACCUM |  |  | IMPLIED |  |  | (IND. X) |  |  | (IND. Y) |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| MN | EMO | NIC | OPERATION | OP | n | \# | OP | $n$ | \# | OP | $n$ | \# | OP | n | \# | OP | $n$ | \# | OP | n | \# | OP | n | \# |
| A <br> A <br> A <br> B <br> B | $\begin{aligned} & \mathrm{D} \\ & \mathrm{~N} \\ & \mathrm{~S} \\ & \mathrm{C} \\ & \mathrm{C} \end{aligned}$ | $\begin{aligned} & \mathrm{C} \\ & \mathrm{D} \\ & \mathrm{~L} \\ & \mathrm{C} \\ & \mathrm{~S} \end{aligned}$ | $\begin{aligned} & A+M+C \rightarrow A \quad \text { (4) } \\ & A \wedge M \rightarrow A \\ & C \leftarrow \mid 7 \quad 0 \\ & \text { BRANCHON } \leftarrow=0 \\ & \text { BRANCH ON } C=1 \end{aligned}$ | $\begin{aligned} & 69 \\ & 29 \end{aligned}$ | 2 | 2 | $\begin{aligned} & 6 \mathrm{D} \\ & 2 \mathrm{D} \\ & 0 \mathrm{E} \end{aligned}$ | $\begin{aligned} & 4 \\ & 4 \\ & 6 \end{aligned}$ | $\begin{aligned} & 3 \\ & 3 \\ & 3 \end{aligned}$ | $\begin{aligned} & 65 \\ & 25 \\ & 06 \end{aligned}$ | 3 3 5 | $\begin{aligned} & 2 \\ & 2 \\ & 2 \end{aligned}$ | OA | 2 | 1 |  |  |  | $\begin{aligned} & 61 \\ & 21 \end{aligned}$ | $\begin{aligned} & 6 \\ & 6 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & 71 \\ & 31 \end{aligned}$ | $\begin{aligned} & 5 \\ & 5 \end{aligned}$ | 2 |
| $\begin{aligned} & \mathrm{B} \\ & \mathrm{~B} \\ & \mathrm{~B} \\ & \mathrm{~B} \\ & \mathrm{~B} \end{aligned}$ | $\begin{aligned} & \mathrm{E} \\ & 1 \\ & \mathrm{M} \\ & \mathrm{~N} \\ & \mathrm{P} \end{aligned}$ | $\begin{gathered} \mathrm{Q} \\ \mathrm{~T} \\ \mathrm{I} \\ \mathrm{E} \\ \mathrm{~L} \end{gathered}$ | $\begin{aligned} & \text { BRANCH ON Z }=1 \text { (2) } \\ & \text { A^M } \\ & \text { BRANCH ON N }=1 \\ & \text { BRANCH ON } Z=0 \\ & \text { BRANCH ON } 21 \\ & \text { BRAN } \end{aligned}$ |  |  |  | 2 C | 4 | 3 | 24 | 3 | 2 |  |  |  |  |  |  |  |  |  |  |  |  |
| $\begin{aligned} & \mathrm{B} \\ & \mathrm{~B} \\ & \mathrm{~B} \\ & \mathrm{C} \\ & \mathrm{C} \end{aligned}$ | $\begin{aligned} & R \\ & V \\ & V \\ & L \\ & L \end{aligned}$ | $\begin{aligned} & \mathrm{K} \\ & \mathrm{C} \\ & \mathrm{~S} \\ & \mathrm{C} \\ & \mathrm{D} \end{aligned}$ | BREAK <br> BRANCH ON V = 0 (2) <br> BRANCH ON V = 1 (2) $\begin{aligned} & 0 \rightarrow C \\ & 0 \rightarrow D \end{aligned}$ |  |  |  |  |  |  |  |  |  |  |  |  | $\begin{array}{\|l} 00 \\ 18 \\ 08 \end{array}$ | $\begin{aligned} & 7 \\ & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ |  |  |  |  |  |  |
| C C C C C | $\begin{aligned} & L \\ & L \\ & M \\ & P \\ & P \end{aligned}$ | $\begin{aligned} & \mathrm{I} \\ & \mathrm{~V} \\ & \mathrm{P} \\ & \mathrm{X} \\ & \mathrm{Y} \end{aligned}$ | $\begin{aligned} & O \rightarrow 1 \\ & O \rightarrow V \\ & A-M \\ & X=M \\ & Y-M \end{aligned}$ | $\begin{aligned} & \mathrm{CO} \\ & \mathrm{EO} \\ & \mathrm{CO} \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & \mathrm{CD} \\ & \mathrm{EC} \\ & \mathrm{CC} \end{aligned}$ | $\begin{aligned} & 4 \\ & 4 \\ & 4 \end{aligned}$ | $\begin{aligned} & 3 \\ & 3 \\ & 3 \end{aligned}$ | $\begin{aligned} & \text { C5 } \\ & \text { E4 } \\ & \text { C4 } \end{aligned}$ | $\begin{aligned} & 3 \\ & 3 \\ & 3 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \\ & 2 \end{aligned}$ |  |  |  | $\begin{array}{\|l} 58 \\ 88 \end{array}$ | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | C1 | 6 | 2 | D1 | 5 | 2 |
| $\begin{align*} & D  \tag{1}\\ & D \\ & D \\ & E \\ & 1 \end{align*}$ | $\begin{aligned} & \mathrm{E} \\ & \mathrm{E} \\ & \mathrm{E} \\ & \mathrm{O} \\ & \mathrm{~N} \end{aligned}$ | $\begin{aligned} & \mathrm{C} \\ & \mathrm{X} \\ & \mathrm{Y} \\ & \mathrm{R} \\ & \mathrm{C} \end{aligned}$ | $\begin{aligned} & M-1 \rightarrow M \\ & X-1 \rightarrow X \\ & Y-1 \rightarrow Y \\ & A V M \rightarrow A \\ & M+1 \rightarrow M \end{aligned}$ | 49 | 2 | 2 | $\begin{aligned} & \text { CE } \\ & 4 D \\ & E E \end{aligned}$ | $6$ $\begin{aligned} & 4 \\ & 6 \end{aligned}$ | $3$ $\begin{aligned} & 3 \\ & 3 \end{aligned}$ | $\begin{aligned} & \text { C6 } \\ & \\ & 45 \\ & \text { E6 } \end{aligned}$ | $\begin{aligned} & 5 \\ & 3 \\ & 5 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \\ & 2 \end{aligned}$ |  |  |  | $\begin{array}{\|l\|} \hline \text { CA } \\ 88 \end{array}$ | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | 41 | 6 | 2 | -51 | 5 | 2 |
| I I J J L | $\begin{aligned} & N \\ & N \\ & M \\ & S \\ & \mathrm{~S} \end{aligned}$ | $\begin{aligned} & X \\ & X \\ & P \\ & P \\ & R \\ & A \end{aligned}$ | $\begin{aligned} & x+1 \rightarrow X \\ & Y+1 \rightarrow Y \end{aligned}$ <br> JUMP TO NEW LOC <br> JUMP SUB <br> $M \rightarrow A$ | A9 | 2 | 2 | $\begin{aligned} & 4 C \\ & 20 \\ & A D \end{aligned}$ | $\begin{aligned} & 3 \\ & 6 \\ & 4 \end{aligned}$ | $\begin{aligned} & 3 \\ & 3 \\ & 3 \end{aligned}$ | A5 | 3 | 2 |  |  |  | $\begin{array}{\|l} \mathrm{E} 8 \\ \mathrm{C} \end{array}$ | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | $1$ | A1 | 6 | 2 | 81 | 5 | 2 |
| $\begin{align*} & L  \tag{1}\\ & L \\ & L \\ & N \\ & O \end{align*}$ | $\begin{align*} & D  \tag{1}\\ & D \\ & S \\ & \text { O } \\ & \text { R } \end{align*}$ | $\begin{aligned} & \mathrm{X} \\ & \mathrm{Y} \\ & \mathrm{R} \\ & \mathrm{P} \\ & \mathrm{~A} \end{aligned}$ | $\begin{aligned} & M \rightarrow X \\ & M \rightarrow Y \\ & O \rightarrow Y O C \\ & N O O P E R A T I O N \\ & A \vee M \rightarrow A \end{aligned}$ | $\begin{aligned} & \text { A2 } \\ & \text { AO } \\ & 09 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & A E \\ & A C \\ & 4 E \\ & O D \end{aligned}$ | $\begin{aligned} & 4 \\ & 4 \\ & 6 \\ & 4 \end{aligned}$ | $\begin{aligned} & 3 \\ & 3 \\ & 3 \\ & 3 \end{aligned}$ | $\begin{aligned} & A 6 \\ & A 4 \\ & 46 \\ & 05 \end{aligned}$ | $\begin{aligned} & 3 \\ & 3 \\ & 5 \\ & 3 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \\ & 2 \\ & 2 \end{aligned}$ | 4 A | 2 | 1 | EA | 2 | 1 | 01 | 6 | 2 | 11 | 5 | 2 |
| P <br>  <br> $P$ <br> $P$ <br> $P$ | $\begin{aligned} & H \\ & H \\ & L \\ & L \\ & \mathbf{L} \end{aligned}$ | $\begin{aligned} & A \\ & P \\ & \mathbf{A} \\ & \mathbf{P} \\ & \mathbf{L} \end{aligned}$ |  |  |  |  | 2E | 6 | 3 | 26 | 5 | 2 | 2A | 2 | 1 | $\begin{aligned} & 48 \\ & 08 \\ & 68 \\ & 28 \end{aligned}$ | $\begin{aligned} & 3 \\ & 3 \\ & 4 \\ & 4 \end{aligned}$ | $\begin{aligned} & 1 \\ & 2 \\ & 1 \\ & 1 \end{aligned}$ |  |  |  |  |  |  |
| $\begin{align*} & \hline R  \tag{1}\\ & R \\ & R \\ & S \\ & S \\ & S \end{align*}$ | $\begin{aligned} & \mathrm{O} \\ & \mathrm{~T} \\ & \mathrm{~T} \\ & \mathrm{~B} \\ & \mathrm{E} \\ & \mathrm{E} \end{aligned}$ | $\begin{aligned} & \text { R } \\ & 1 \\ & S \\ & C \\ & C \\ & D \end{aligned}$ | पृत $\rightarrow 18 \longrightarrow 71 \rightarrow$ <br> RTRN INT <br> RTRN SUB $\begin{aligned} & A-M-C \rightarrow A \\ & 1 \rightarrow C \\ & 1 \rightarrow D \end{aligned}$ | E9 | 2 | 2 | 6E <br> ED | 6 <br> 4 | 3 <br> 3 | $\begin{gathered} 66 \\ \text { E5 } \end{gathered}$ | $\begin{aligned} & 5 \\ & 3 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | 6A | 2 | 1 | 40 60 38 F8 | 6 6 2 2 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | E 1 | 6 | 2 | F1 | 5 | 2 |
| $\begin{aligned} & \mathrm{S} \\ & \mathrm{~S} \\ & \mathrm{~S} \\ & \mathrm{~S} \\ & \mathrm{~T} \end{aligned}$ | $\begin{aligned} & \text { E } \\ & \mathrm{T} \\ & \mathrm{~T} \\ & \mathrm{~T} \\ & \mathbf{A} \end{aligned}$ | $\begin{aligned} & \text { I } \\ & \text { A } \\ & \text { X } \\ & \text { Y } \\ & \text { X } \end{aligned}$ | $\begin{aligned} & Y \rightarrow 1 \\ & A \rightarrow M \\ & X \rightarrow M \\ & Y \rightarrow M \\ & A \rightarrow X \end{aligned}$ |  |  |  | $\begin{aligned} & 8 D \\ & 8 E \\ & 8 C \end{aligned}$ | 4 4 4 | 3 3 3 | $\begin{aligned} & 85 \\ & 86 \\ & 84 \end{aligned}$ | $\begin{aligned} & 3 \\ & 3 \\ & 3 \end{aligned}$ | $\begin{aligned} & 2 \\ & 2 \\ & 2 \end{aligned}$ |  |  |  | $78$ <br> AA | $\begin{aligned} & 2 \\ & 2 \end{aligned}$ | 1 <br> 1 | 81 | 6 | 2 | 91 | 6 | 2 |
| $T$ $T$ $T$ $T$ $T$ | $\begin{aligned} & A \\ & S \\ & X \\ & X \\ & X \end{aligned}$ | $\begin{aligned} & Y \\ & X \\ & A \\ & \text { A } \\ & \text { A } \end{aligned}$ | $\begin{aligned} & A \rightarrow Y \\ & S \rightarrow X \\ & X \rightarrow A \\ & X \rightarrow S \\ & Y \rightarrow A \end{aligned}$ |  |  |  |  |  |  |  |  |  |  |  |  | $\begin{aligned} & \text { A8 } \\ & \text { BA } \\ & \text { BA } \\ & \text { 9A } \\ & 98 \end{aligned}$ | $\begin{aligned} & 2 \\ & \frac{2}{2} \\ & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ |  |  |  |  |  |  |
| (1) ADD 1 TO N IF PAGE BOUNDARY IS CROSSED <br> (2) ADD 1 TO N IF BRANCH OCCURS TO SAME PAGE ADD 2 TO N IF BRANCH OCCURS TO DIFFERENT PAGE <br> (3) CARRY NOT = BORROW <br> (4) IF IN DECIMAL MODE Z FLAG IS INVALID ACCUMULATOR MUST BE CHECKED FOR ZERO RESULT |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |  |




[^0]:    -     * 

