3501 ED BLUESTEIN BLVD., AUSTIN, TEXAS 78721 # MC146805E2 # **Advance Information** #### 8-BIT MICROPROCESSOR UNIT The MC146805E2 Microprocessor Unit (MPU) belongs to the M6805 Family of Microcomputers. This 8-bit fully static and expandable microprocessor contains a CPU, on-chip RAM, I/O, and TIMER. It is a low-power, low-cost processor designed for low-end to mid-range applications in the consumer, automotive, industrial, and communications markets where very low power consumption constitutes an important factor. The following are the major features of the MC146805E2 MPU: #### HARDWARE FEATURES - Typical Full Speed Operating Power of 35 mW @ 5 V - Typical WAIT Mode Power of 5 mW - Typical STOP Mode Power of 25 μW - 112 Bytes of On-Chip RAM - 16 Bidirectional I/O Lines - Internal 8-Bit Timer with Software Programmable 7-Bit Prescaler - External Timer Input - Full External and Timer Interrupts - Multiplexed Address/Data Bus - Master Reset and Power-On Reset - Capable of Addressing Up to 8K Bytes of External Memory - Single 3- to 6-Volt Supply - On-Chip Oscillator - 40-Pin Dual-In-Line Package - Chip Carrier Also Available #### **SOFTWARE FEATURES** - Similar to the MC6800. - Efficient Use of Program Space - Versatile Interrupt Handling - True Bit Manipulation - Addressing Modes with Indexed Addressing for Tables - Efficient Instruction Set - Memory Mapped I/O - Two Power Saving Standby Modes #### GENERIC INFORMATION | Package<br>Type | Frequency<br>(MHz) | Temperature | Generic Number | |-----------------------|--------------------|---------------|----------------| | Ceramic | 1.0 | 0°C to 70°C | MC146805E2L | | L Suffix | 1.0 | -40°C to 85°C | MC146805E2CL | | Cerdip | 1.0 | 0°C to 70°C | MC146805E2S | | S Suffix | 1.0 | -40°C to 85°C | MC146805E2CS | | Plastic | 1.0 | 0°C to 70°C | MC146805E2P | | P Suffix | 1.0 | 40°C to 85°C | MC146805E2CP | | Leadless Chip Carrier | 1.0 | 0°C to 70°C | MC146805E2Z | | Z Suffix | 1.0 | -40°C to 85°C | MC146805E2CZ | # **CMOS** (HIGH PERFORMANCE SILICON GATE) 8-BIT MICROPROCESSOR #### PIN ASSIGNMENT (1) 40 TV<sub>DD</sub> RESET 1 (2) (40) 39 DOSC1 ĪRQ 1 2 (3) (39) 38 OSC2 LI**[**]3 (4) (38) 37 TIMER DS 1 4 (5) $R/\overline{W}$ d 5 (6) (37) 36 PB0 AS**[**6 (7) (36) 35 PB1 PA7 7 (8) (35) 34 **1**PB2 (34) 33 **h**PB3 PA6 6 8 (9) (33) 32 PB4 PA5**[** 9 (10) PA4**[** 10 (11) (32) 31 PB5 (31) 30 TPB6 PA3**[** 11 (12) PA2 1 12 (13) (30) 29 PB7 (29) 28 **B**0 PA1 13 (14) (28) 27 DB1 PA0 14 (15) (27) 26 **1**B2 A12[15 (16) A11**d**16 (17) (26) 25 B3 A10117 (18) (25) 24 **B**4 (24) 23 **1**B5 A9 1 18 (19) (23) 22 B6 A8 19 (20) V<sub>SS</sub>**I** 20 (21) (22) 21 **B**B7 Pin numbers in parentheses represent equivalent Z suffix chip carrier pins. ## MAXIMUM RATINGS (voltages referenced to VSS) | Ratings | Symbol | Value | Unit | |----------------------------------------------------------|------------------|-----------------------------------------------------------|------| | Supply Voltage | V <sub>DD</sub> | -0.3 to +8.0 | ٧ | | All Input Voltages Except OSC1 | V <sub>in</sub> | V <sub>SS</sub> = 0.5 to V <sub>DD</sub> + 0.5 | V | | Current Drain Per Pin Excluding VDD and VSS | 1 | 10 | mA , | | Operating Temperature Range<br>MC146805E2<br>MC146805E2C | ТА | T <sub>L</sub> to T <sub>H</sub><br>0 to 70<br>– 40 to 85 | °¢ | | Storage Temperature Range | T <sub>stg</sub> | - 55 to + 150 | °C | #### **THERMAL CHARACTERISTICS** | Characteristics | Symbol | Value | Unit | |----------------------------------------------------------|-------------|------------------------|------| | Thermal Resistance Plastic Cerdip Ceramic . Chip-Carrier | <b>θ</b> JA | 100<br>60<br>50<br>TBD | °C/W | This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields; however, it is advised that normal precautions be taken to avoid application of any voltage higher than maximum rated voltages to this high impedance circuit. For proper operation it is recommended that $V_{in}$ and $V_{out}$ be constrained to the range $V_{SS} \leq (V_{in} \text{ or } V_{out}) \leq V_{DD}$ . Reliability of operation is enhanced if unused inputs are tied to an appropriate logic voltage level (e.g., either $V_{SS}$ or $V_{DD}$ ). #### FIGURE 1 — MICROPROCESSOR BLOCK DIAGRAM ## DC ELECTRICAL CHARACTERISTICS @ 3.0 V (VDD = 3.0 Vdc, VSS = 0, TA = TL to TH, unless otherwise noted) | Characteristics | Symbol | Min | Max | Unit | |------------------------------------------------------------------------------------------------|--------|----------------|--------|----------------| | Output Voltage (I <sub>LOad</sub> ≤10.0 μA) | VOL | _ | 0.1 | T <sub>V</sub> | | | ∨он | $V_{DD} = 0.1$ | ⟨₹ ⟨⟨⟩ | | | Total Supply Current ( $C_L = 50 \text{ pF} - \text{No dc Loads}, t_{CYC} = 5 \mu s$ ) | | | 6 | | | Run ( $V_{IL} = 0.2 \text{ V}$ , $V_{IH} = V_{DD} - 0.2 \text{ V}$ ) | IDD | - 1 | 1.3 | mA | | Wait (Test Conditions - See Note Below) | lDD | | 200 | μA | | Stop (Test Conditions — See Note Below) | IDD | < <u>-</u> | 100 | μА | | Output High Voltage | | | | | | $(I_{Load} = 0.25 \text{ mA}) \text{ A8-A12, B0-B7, DS, AS, R/}\overline{W}$ | Voh | 2.7 | _ | V | | (I <sub>Load</sub> = 0.1 mA) PA0-PA7, PB0-PB7 | VøH | 2.7 | _ | V | | Output Low Voltage | | | | 1 | | $(I_{Load} = 0.25 \text{ mA}) \text{ A8-A12}, B0-B7, PB0-PB7, DS, AS, R/\overline{W}, PA0-PA7$ | Vol | _ | 0.3 | V | | Input High Voltage | | | | | | PAO-PA7, PBO-PB7, BO-B7 | VIH | 2.1 | - | V | | TIMER, IRQ, RESET | VIH | 2.5 | _ | V | | OSC1 | VIH | 2.1 | _ | V | | Input Low Voltage (All Inputs) | VIL | _ | 0.5 | V | | Frequency of Operation | | | | 1 - | | Crystal | fosc | - | 1.0 | MHz | | External Clock | fosc | dc | 1.0 | MHz | | Input Current | | | | | | RESET, IRQ, TIMER, OSC1 | lin | _ | ± 1 | μA | | Hi-Z Output Leakage | 1 | | | | | PA0-PA7, PB0-PB7, B0-B7 | ITSL | _ | ± 10 | μΑ | | Capacitance | | | | | | RESET, IRQ, TIMER | Cin | _ | 8.0 | pF | | Capacitance . | | | | | | DS, AS, R/W, A8-A12, PA0-PA7, PB0-PB7, B0-B7 | Cout | _ | 12.0 | pF | | | | | | | NOTE: Test conditions for Quiescent Current Values are: Port A and B programmed as inputs. V<sub>IL</sub> = 0.2 V for PA0-PA7, PB0-PB7, and B0-B7. V<sub>IH</sub> = V<sub>DD</sub> = 0.2 V for RESET, IRQ, and TIMER OSC1 input is a squared from V<sub>SS</sub> + 0.2 V to V<sub>DD</sub> = 0.2 V. OSC2 output load (including tester) is 35 pF maximum. Wait mode IDD is affected linearly by this capacitance. # **DC ELECTRICAL CHARACTERISTICS @ 5.0 V** ( $V_{DD}$ =5.0 Vdc $\pm$ 10%, $V_{SS}$ =0, $T_A$ = $T_L$ to $T_H$ , unless otherwise noted) | Characteristics | Symbol | Min | Max | Unit | |---------------------------------------------------------------------------------------------------|--------------------------------------------------|-----------------------|------|--------------------------------------------------| | Output Voltage (I <sub>Load</sub> ≤ 10.0 µA) | VOL | _ | 0.1 | V | | | Voн | $V_{DD} = 0.1$ | 49 | <b>D</b> | | Total Supply Current (C <sub>L</sub> = 130 pF - On Bus, C <sub>L</sub> = 50 pF - On Ports, | l | | | | | No dc Loads, $t_{CVC} = 1.0 \mu s$ , $V_{IL} = 0.2 \text{ V}$ , $V_{IH} = V_{DD} - 0.2 \text{ V}$ | | Man | 10 | Ι. | | Wait (Test Conditions See Note Below) | l <sub>DD</sub> | | 1.5 | mA | | Stop (Test Conditions — See Note Below) | סטי<br>DD | | 200 | mA | | Output High Voltage | - טטי | | 200 | μΑ | | (I <sub>Load</sub> = 1.6 mA) A8-A12, B0-B7, DS, AS, R/W | Voh | 4.1 | _ | V | | (I <sub>Load</sub> = 0.36 mA) PA0-PA7, PB0-PB7 | Уон | 4.1 | _ | Ϊ́ | | Output Low Voltage | | | | Ė | | (I <sub>Load</sub> = 1.6 mA) A8-A12, B0-B7, PA0-PA7, PB0-PB7, DS, AS, R/W | VOL | _ | 0.4 | l v | | Input High Voltage | | | | <del> </del> | | PAO-PA7, PBO-PB7, BO-B7 | VIH | V <sub>DD</sub> - 2.0 | _ | V | | TIMER, IRQ, RESET | VIH | V <sub>DD</sub> = 0.8 | _ | V | | OSC1 | VIH | V <sub>DD</sub> – 1.5 | | V | | Input Low Voltage (All Inputs) | VIL | | 0.8 | l v | | Frequency of Operation | <del> </del> | | | <u> </u> | | Crystal | fosc | _ | 5.0 | MHz | | External Clock | fosc | dc | 5.0 | MHz | | Input Current | 1 000 | | | + | | RESET, IRO, TIMER, OSC1 | lin | - | ±1 | μА | | Hi-Z Output Leakage | <del> "</del> | | | <u> </u> | | PAO-PA7, PBO-PB7, BO-B7 | ITSI | _ | ± 10 | μА | | Capacitance | <del> </del> | | | <del> _ ,</del> | | RESET, IRO, TIMER | Cin | _ | 8.0 | pF | | Capacitance | <del> "'-</del> | | | <del> -</del> | | DS, AS, R/W, A8-A12, PA0-PA7, PB0-PB7, B0-B7 | Cout | _ | 12.0 | pF | NOTE: Test conditions for Quiescent Current Values are: Port A and B programmed as inputs. VIL = 0.2 V for PAO PA7, PB0-PB7, and B0-B7. VIH = VDD - 0.2 V for RESET, IRQ, and TIMER. OSC1 input is a squarewave from VSS+0.2 V to VDD - 0.2 V. OSC2 output load (including tester) is 35 pF maximum. Wait mode (Ipp) is affected linearly by this capacitance. TABLE 1 — CONTROL TIMING ( $V_{SS} = 0$ , $T_A = T_L$ to $T_H$ ) | | | _ | D=3.0 V<br>C=1 MHz | | V <sub>DD</sub> = | | | | |------------------------------------------------------------|--------------------|------|--------------------|------------|-------------------|--------------|-----|-------------------| | Characteristics | Symbol | Min | Тур | Max | Min | Тур | Max | Unit | | I/O Port Timing — Input Setup Time (Figure 3) | tPVASL | 500 | | | 250 | | | ns | | Input Hold Time (Figure 3) | tASLPX | 100 | | _ | 100 | | | ns | | Output Delay Time (Figure 3) | tASLPV | | | 0 | | _ | 0 | ns | | Interrupt Setup Time (Figure 6) | tILASL | 2 | _ | - | 0.4 | - 4 | | μS | | Crystal Oscillator Startup Time (Figure 5) | toxov | _ | 30 | 300 | | 15 | 100 | ms | | Wait Recovery Startup Time (Figure 7) | tIVASH | | | 10 | | $\leftarrow$ | 2 | μS | | Stop Recovery Startup Time (Crystal Oscillator) (Figure 8) | tILASH | _ | 30 | 300 | | 15 | 100 | ms | | Required Interrupt Release (Figure 6) | <sup>†</sup> DSLIH | | _ | 5 | - | _ | 1.0 | μS | | Timer Pulse Width (Figure 7) | tTH, tTL | 0.5 | _ | - | 0.5 | - | | t <sub>cyc</sub> | | Reset Pulse Width (Figure 5) | t <sub>RL</sub> | 5.5 | | - 3000 | 1.5 | _ | _ | μS | | Timer Period (Figure 7) | tTLTL | 1.0 | | | 1.0 | | | t <sub>cyc_</sub> | | Interrupt Pulse Width Low (Figure 16) | tiliH | 1.0 | | < | 1.0 | | _ | t <sub>cyc</sub> | | Interrupt Pulse Period (Figure 16) | tilil | * | - / | - | * | _ | _ | t <sub>cyc</sub> | | Oscillator Cycle Period (1/5 of t <sub>Cyc</sub> ) | tOLOL | 1000 | Ì | <i>)</i> – | 200 | | _ | ns | | OSC1 Pulse Width High | tOH | 350 | 4/ | | 75 | | | ns | | OSC1 Pulse Width Low | tOL | 350 | | | 75 | _ | | ns | <sup>\*</sup>The minimum period t<sub>|L|L</sub> should not be less than the number of t<sub>CVC</sub> cycles it takes to execute the interrupt service routine plus 20 t<sub>CVC</sub> cycles. # FIGURE 2 - EQUIVALENT TEST LOADS # $\begin{aligned} & \textbf{FIGURE 3 - I/O PORT TIMING} \\ (V_{Low} = 0.8 \text{ V}, V_{High} = V_{DD} - 2.0 \text{ V}, V_{DD} = 5.0 \pm 10\% \\ & T_{A} = T_{L} \text{ to } T_{H}, C_{L} \text{ on Port} = 50 \text{ pF, } f_{OSC} = 5 \text{ MHz}) \end{aligned}$ \* The address strobe of the first cycle of the next instruction. **TABLE 2** — BUS TIMING ( $T_A = T_L \text{ to } T_H$ , $V_{SS} = 0 \text{ V}$ ) See Figure 4 | Num | Characteristics | Symbol | V <sub>DD</sub> | 1 MHz<br>= 3.0 V<br>= Load | f <sub>osc</sub> =<br>V <sub>DD</sub> =5.0<br>1<br>and 130 | Unit | | |-----|--------------------------------------|---------------------------------|-----------------|----------------------------|------------------------------------------------------------|------|---------------| | | | | Min | Max | Min | Max | | | 1 | Cycle Time | t <sub>cyc</sub> | 5000 | dc | 1000 | dc | ns | | 2 | Pulse Width, DS Low | PWEL | 2800 | _ | 560 | | ns | | 3 | Pulse Width, DS High | PWEH | 1800 | _ | 375 | _ | ns | | 4 | Clock Transition | t <sub>r</sub> , t <sub>f</sub> | _ | 100 | _ | 30 | ns | | 8 | R/W Hold | tRWH | 10 | _ | 10 | _ | ns | | 9_ | Non-Muxed Address Hold | tAH | 800 | _ | 100 | _ | ns | | 11 | R/W Delay from DS Fall | tAD | _ | 500 | | 300 | ns | | 16 | Non-Muxed Address Delay from AS Rise | tADH | 0 | 200 | 0 | 100 | ns | | 17 | MPU Read Data Setup | tDSR | 200 | | 115 | | ns | | 18 | Read Data Hold | tDHR | 0 | 800 | 0 | 160 | ns | | 19 | MPU Data Delay, Write | tDDW | | 0 | <del></del> - | 120 | $\overline{}$ | | 21 | Write Data Hold | tDHW | 800 | | 55 | | ns | | 23 | Muxed Address Delay from AS Rise | tBHD | 0 | 250 | 0 | 120 | ns | | 24 | Muxed Address Valid to AS Fall | tASL | 600 | | 55 | | ns | | 25 | Muxed Address Hold | | 250 | 750 | | 100 | ns | | 26 | Delay DS Fall to AS Rise | tAHL tags | 800 | | 60 | 180 | ns | | 27 | Pulse Width, AS High | PWASH | | | 160 | | ns | | 28 | Delay, AS Fall to DS Rise | 1 | 850 | | 175 | | ns | | | , , | tASED | 800 | _ | 160 | _ | ns | #### **FUNCTIONAL PIN DESCRIPTION** #### V<sub>DD</sub> AND V<sub>SS</sub> VDD and VSS provide power to the chip. VDD provides power and VSS is ground. #### **TRQ** (MASKABLE INTERRUPT REQUEST) $\overline{IRQ}$ is both a level-sensitive and edge-sensitive input which can be used to request an interrupt sequence. The MPU completes the current instruction before it responds to the request. If $\overline{IRQ}$ is low and the interrupt mask bit (I bit) in the condition code register is clear, the MPU begins an interrupt sequence at the end of the current instruction. The interrupt circuit recognizes both a "wire ORed" level as well as pulses on the $\overline{IRQ}$ line (see Interrupt section for more details). $\overline{IRQ}$ requires an external resistor to $V_{DD}$ for "wire OR" operation. #### RESET The RESET input is not required for start-up but can be used to reset the MPU internal state and provide an orderly software start-up procedure. Refer to the Reset section for a detailed description. #### **TIMER** The TIMER input is used for clocking the on-chip timer. Refer to Timer section for a detailed description. #### AS (ADDRESS STROBE) Address strobe (AS) is an output strobe used to indicate the presence of an address on the 8-bit multiplexed bus. The AS line is used to demultiplex the eight least significant address bits from the data bus. A latch controlled by address strobe should capture addresses on the negative edge. This output is capable of driving one standard TTL load and 130 pF and is available at $f_{\rm OSC}\div 5$ when the MPU is not in the WAIT or STOP states. #### DS (DATA STROBE) This output is used to transfer data to or from a peripheral or memory. DS occurs anytime the MPU does a data read or write. DS also occurs when the MPU does a data transfer to or from the MPU internal memory. Refer to Table 2 and Figure 4 for timing characteristics. This output is capable of driving one standard TTL load and 130 pF. DS is a continuous signal at $f_{\rm OSC} \div 5$ when the MPU is not in the WAIT or STOP state. Some bus cycles are redundant reads of opcode bytes. #### R/W (READ/WRITE) The R/ $\overline{W}$ output is used to indicate the direction of data transfer for both internal memory and I/O registers, and external peripheral devices and memories. This output is used to indicate to a selected peripheral whether the MPU is going to read or write data on the next data strobe (R/ $\overline{W}$ low = processor write; R/ $\overline{W}$ high = processor read). The R/ $\overline{W}$ output is capable of driving one standard TTL load and 130 pF. The normal standby state is read (high). #### A8-A12 (HIGH ORDER ADDRESS LINES) The A8-A12 output lines constitute the higher order non-multiplexed addresses. Each output line is capable of driving one standard TTL load and 130 pF. #### **B0-B7 (ADDRESS/DATA BUS)** The B0-B7 bidirectional lines constitute the lower order addresses and data. These lines are multiplexed, with address present at address strobe time and data present at data strobe time. When in the data mode, these lines are bidirectional, transferring data to and from memory and peripheral devices as indicated by the $R/\overline{W}$ pin. As outputs in either the data or address modes, these lines are capable of driving one standard TTL load and 130 pF. #### OSC1, OSC2 The MC146805E2 provides for two types of oscillator inputs — crystal circuit or external clock. The two oscillator pins are used to interface to a crystal circuit, as shown in Figure 5. If an external clock is used, it must be connected to OSC1. The input at these pins is divided by five to form the cycle rate seen on the AS and DS pins. The frequency range is specified by fosc. The OSC1 to bus transitions relationships are provided in Figure 9 for system designs using oscillators slower than 5 MHz. CRYSTAL — The circuit shown in Figure 5 is recommended when using a crystal. The internal oscillator is designed to interface with an AT-cut parallel resonant quartz crystal resonator in the frequency range specified for fosc in the electrical characteristics table. An external CMOS oscillator is recommended when crystals outside the specified ranges are to be used. The crystal and components should be mounted as close as possible to the input pins to minimize output distortion and start-up stabilization time. **EXTERNAL CLOCK** — An external clock should be applied to the OSC1 input with the OSC2 input not connected, as shown in Figure 10. #### LI (LOAD INSTRUCTION) This output is used to indicate that a fetch of the next opcode is in progress. LI remains low during an external or timer interrupt. The LI output is used only for certain debugging and test systems. For normal operations this pin is not connected. The LI output is capable of driving two standard LSTTL loads and 50 pF. This signal overlaps data strobe. #### PA0-PA7 These eight pins constitute input/output port A. Each line is individually programmed to be either an input or output under software control via its data direction register as shown in Figure 11(b). An I/O pin is programmed as an output when the corresponding DDR bit is set to a "1", and as an input when it is set to a "0". In the output mode the bits are latched and appear on the corresponding output pins. An MPU read of the port bits programmed as outputs reflects the last value written to that location. When programmed as an input, the input data bit(s) are not latched. An MPU read of the port bits programmed as inputs reflects the current status of the corresponding input pins. The I/O port timing is shown in Figure 3. See typical I/O port circuitry in Figure 11. During a power-on reset or external reset, all lines are configured as inputs (zero in data direction register). The output port register is not initialized by reset. The TTL compatible three-state output buffers are capable of driving one standard TTL load and 50 pF. The DDR is a read/write register. FIGURE 10 - EXTERNAL CLOCK CONNECTION #### PBO-PB7 These eight pins interface with input/output port B. Refer to PA0-PA7 description for details of operation. #### **MEMORY ADDRESSING** The MC146805E2 is capable of addressing 8192 bytes of memory and I/O registers. The address space is divided into internal memory space and external memory space, as shown in Figure 12. The internal memory space is located within the first 128 bytes of memory (first half of page zero) and is comprised of the I/O port locations, timer locations, and 112 bytes of RAM. The MPU can read from or write to any of these locations. A program write to on-chip locations is repeated on the external bus to permit off-chip memory to duplicate the content of on-chip memory. Program reads to on-chip locations also appear on the external bus, but the MPU accepts data only from the addressed on-chip location. Any read data appearing on the input bus is ignored. The stack pointer is used to address data stored on the stack. Data is stored on the stack during interrupts and subroutine calls. At power-up, the stack pointer is set to \$007F and it is decremented as data is pushed onto the stack. When data is removed from the stack, the stack pointer is incremented. A maximum of 64 bytes of RAM is available for stack usage. Since most programs use only a small part of the allotted stack locations for interrupts and/or subroutine stacking purposes, the unused bytes are usable for program data storage. All memory locations above location \$007F are part of the external memory map. In addition, ten locations in the I/O portion of the lower 128 bytes of memory space, as shown in **MOTOROLA** Semiconductor Products Inc. TABLE 3 - I/O PIN FUNCTIONS | R/W | DDR | I/O Pin Functions | |-----|-----|---------------------------------------------------------------------------| | 0 | 0 | The I/O pin is in input mode. Data is written into the output data latch. | | 0 | 1 | Data is written into the output data latch and output to the I/O pin. | | 1 | 0 | The state of the I/O pin is read. | | 1 | 1 | The I/O pin is in an output mode. The output data latch is read. | Figure 12, are part of the external memory map. All of the external memory space is user definable except the highest 10 locations. Locations \$1FF6 to \$1FFF of the external address space are reserved for interrupt and reset vectors (see Figure 12). #### **REGISTERS** The MC146805E2 contains five registers as shown in the programming model in Figure 13. The interrupt stacking order is shown in Figure 14. #### **ACCUMULATOR (A)** This accumulator is an 8-bit general purpose register used to hold operands and results of arithmetic calculations and data manipulations. #### **INDEX REGISTER (X)** The X register is an 8-bit register which is used during the indexed modes of addressing. It provides an 8-bit value which is used to create an effective address. The index register is also used for data manipulations with the readmodify-write type of instructions and as a temporary storage register when not performing addressing operations. #### PROGRAM COUNTER (PC) The program counter is a 13-bit register that contains the address of the next instruction to be executed by the processor. FIGURE 12 - MPU ADDRESS MAP NOTE: Since the stack pointer decrements during pushes, the PCL is stacked first, followed by PCH, etc. Pulling from the stack is in the reverse order. #### STACK POINTER (SP) The stack pointer is a 13-bit register containing the address of the next free location on the stack. When accessing memory, the seven most significant bits are permanently set to 0000001. They are appended to the six least significant register bits to produce an address within the range of \$007F to \$0040. The stack area of RAM is used to store the return address on subroutine calls and the machine state during interrupts. During external or power-on reset, and during a "reset stack pointer" instruction, the stack pointer is set to its upper limit (\$007F). Nested interrupts and/or subroutines may use up to 64 (decimal) locations, beyond which the stack pointer "wraps around" and points to its upper limit, thereby losing the previously stored information. A subroutine call occupies two RAM bytes on the stack, while an interrupt uses five bytes. #### **CONDITION CODE REGISTER (CC)** The condition code register is a 5-bit register in which each bit is used to indicate the results of the instruction just executed. These bits can be individually tested by a program and specific action taken as a result of their state. Each of the five bits is explained below. HALF CARRY BIT (H) - The H bit is set to a one when a carry occurs between bits 3 and 4 of the ALU during an ADD or ADC instruction. The H bit is useful in binary coded decimal addition subroutines. **INTERRUPT MASK BIT (I)** — When the I bit is set, both the external interrupt and the timer interrupt are disabled. Clearing this bit enables the above interrupts. If an interrupt occurs while the I bit is set, the interrupt is latched and will be processed when the I bit is next cleared. **NEGATIVE BIT (N)** — When set, this bit indicates that the result of the last arithmetic, logical, or data manipulation was negative (bit 7 in the result is a logical one). **ZERO BIT (Z)** — When set, this bit indicates that the result of the last arithmetic, logical, or data manipulation was zero. **CARRY BIT (C)** — The C bit is set when a carry or a borrow out of the ALU occurs during an arithmetic instruction. The C bit is also modified during bit test, shift, rotate, and branch types of instruction. #### RESETS The MC146805E2 has two reset modes: an active low external reset pin (RESET) and a power-on reset function; refer to Figure 5. MOTOROLA Semiconductor Products Inc. #### RESET (PIN #1) The RESET input pin is used to reset the MPU and provide an orderly software start-up procedure. When using the external reset mode, the RESET pin must stay low for a minimum of one tRL. The RESET pin is provided with a Schmitt trigger to improve its noise immunity capability. #### **POWER-ON RESET** The power-on reset occurs when a positive transition is detected on VDD. The power-on reset is used strictly for power turn-on conditions and should not be used to detect any drops in the power supply voltage. There is no provision for a power-down reset. The power-on circuitry provides for a 1920 t<sub>CyC</sub> delay from the time of the first oscillator operation. If the external reset pin is low at the end of the 1920 t<sub>CyC</sub> time out, the processor remains in the reset condition. Either of the two types of reset conditions causes the following to occur: - Timer control register interrupt request bit (bit 7) is cleared to a "0". - Timer control register interrupt mask bit (bit 6) is set to a "1". - All data direction register bits are cleared to a "0" (inputs). - Stack pointer is set to \$007F. - The address bus is forced to the reset vector (\$1FFE, \$1FFF). - Condition code register interrupt mask bit (I) is set to a "1". - STOP and WAIT latches are reset. - External interrupt latch is reset. All other functions, such as other registers (including output ports), the timer, etc., are not cleared by the reset conditions. #### **INTERRUPTS** The MC146805E2 may be interrupted by one of three different methods: either one of two maskable hardware interrupts (external input or timer) or a non-maskable software interrupt (SWI). Systems often require that normal processing be interrupted so that some external event may be serviced. Interrupts cause the processor registers to be saved on the stack and the interrupt mask set to prevent additional interrupts. The RTI instruction causes the register contents to be recovered from the stack and a return to normal processing. The stacking order is shown in Figure 14. Unlike RESET, hardware interrupts do not cause the current instruction excution to be halted, but are considered pending until the current instruction execution is complete. When the current instruction is complete, the processor checks all pending hardware interrupts and if unmasked, proceeds with interrupt processing; otherwise, the next instruction is fetched and executed. Note that masked interrupts are latched for later interrupt service. If both an external interrupt and a timer interrupt are pending at the end of an instruction execution, the external interrupt is serviced first. The SWI is executed as any other instruction. Refer to Figure 15 for the interrupt and instruction processing sequence. #### TIMER INTERRUPT If the timer mask bit (TCR6) is cleared, then each time the timer decrements to zero (transitions from \$01 to \$00) an interrupt request is generated. The actual processor interrupt is generated only if the interrupt mask bit of the condition code register is also cleared. When the interrupt is recognized, the current state of the machine is pushed onto the stack and the I bit in the condition code register is set. This masks further interrupts until the present one is serviced. The processor now vectors to the timer interrupt service routine. The address for this service routine is specified by the contents of \$1FF8 and \$1FF9 unless the processor is in a WAIT mode, in which case users of mask versions BP4XX-XX and AW9XXXX should refer to the appendix for additional information regarding exceptions to this function. The contents of \$1FF6 and \$1FF7 specify the service routine. Also, software must be used to clear the timer interrupt request bit (TCR7). At the end of the timer interrupt service routine, the software normally executes an RTI instruction which restores the machine state and starts executing the interrupted program. #### **EXTERNAL INTERRUPT** If the interrupt mask bit of the condition code register is cleared and the external interrupt pin IRQ is "low," then the external interrupt occurs. The action of the external interrupt is identical to the timer interrupt with the exception that the service routine address is specified by the contents of \$1FFA and \$1FFB. The interrupt logic recognizes both a "wire ORed" level and pulses on the external interrupt line. Figure 16 shows both a functional diagram and timing for the interrupt line. The timing diagram shows two different treatments of the interrupt line (IRQ) to the processor. The first configuration shows many interrupt lines "wire ORed" to form the interrupts at the processor. Thus, if after servicing an interrupt the IRQ remains low, then the next interrupt is recognized. The second method is single pulses on the interrupt line spaced far enough apart to be serviced. Users of mask versions BP4XXXX and AW9XXXX should refer to the appendix regarding exceptions to this function. The minimum time between pulses is a function of the length of the interrupt service routine. Once a pulse ocurs, the next pulse should not occur until the MPU software has exited the routine (an RTI occurs). This time (t<sub>ILIL</sub>) is obtained by adding 20 instruction cycles (one cycle $t_{CYC} = 5/f_{OSC}$ ) to the total number of cycles it takes to complete the service routine including the RTI instruction; refer to Figure 6. ## SOFTWARE INTERRUPT (SWI) The software interrupt is an executable instruction. The action of the SWI instruction is similar to the hardware interrupts. The SWI is executed regardless of the state of the interrupt mask in the condition code register. The service routine address is specified by the contents of memory locations \$1FFC and \$1FFD. See Figure 15 for interrupt and instruction processing flowchart. #### STOP The STOP instruction places the MC146805E2 in a low power consumption mode. In the STOP function the internal oscillator is turned off, causing all internal processing and the timer to be halted; refer to Figure 17. The DS and AS lines go to a low state and the $R/\overline{W}$ line goes to a high state. #### FIGURE 16 - EXTERNAL INTERRUPT #### (a) Interrupt Functional Diagram # (b) Interrupt Mode Diagram #### Wire ORed Condition If after servicing an interrupt the IRQ remains low, then the next interrupt is recognized. #### Pulse Condition The minimum pulse width (t<sub>ILIH</sub>) is one t<sub>CyC</sub>. The period t<sub>|L|L</sub> should not be less than the number of t<sub>CyC</sub> cycles it takes to execute the interrupt service routine plus 20 t<sub>CyC</sub> cycles. The multiplexed address/data bus goes to the data input state (as shown in Figure 8). The high order address lines remain at the address of the next instruction. The MPU remains in the STOP mode until an external interrupt or reset occurs. During the STOP mode, timer control register (TCR) bits 6 and 7 are altered to remove any pending timer interrupt requests and to disable any further timer interrupts. External interrupts are enabled in the condition code register. All other registers and memory remain unaltered. All I/O lines remain unchanged. FIGURE 17 - STOP FUNCTION FLOWCHART #### WAIT The WAIT instruction places the MC146805E2 in a low power consumption mode, but the WAIT mode consumes somewhat more power than the STOP mode; refer to Table 1. In the WAIT function, the internal clock is disabled from all internal circuitry except the timer circuit; refer to Figure 18. Thus, all internal processing is halted except the timer which is allowed to count in a normal sequence. The $R/\overline{W}$ line goes to a high state, the multiplexed address/data bus goes to the data input state, and the DS and AS lines go to the low state (as shown in Figure 7). The high order address lines remain at the address of the next instruction. The MPU remains in this state until an external interrupt, timer interrupt, or a reset occurs. During the WAIT mode, the I bit in the condition code register is cleared to enable interrupts. All other registers, memory, and I/O lines remain in their last state. The timer may be enabled to allow a periodic exit from the WAIT mode. If an external and a timer interrupt occur at the same time, the external interrupt is serviced first, then, if the timer interrupt request is not cleared in the external interrupt routine, the normal timer interrupt (not the timer WAIT interrupt) is serviced since the MPU is no longer in the WAIT mode. #### TIMER The MPU timer contains a single 8-bit software programmable counter (timer data register) with 7-bit software selectable prescaler. Figure 19 shows a block diagram of the timer. The counter may be preset under program control and decrements towards zero. When the counter decrements to zero, the timer interrupt request bit, i.e., bit 7 of the timer control register (TCR), is set. Then if the timer interrupt is not masked, i.e., bit 6 of the TCR and the I bit in the condition code register are both cleared, the processor receives an interrupt. After completion of the current instruction, the processor proceeds to store the appropriate registers on the stack, and then fetches the timer interrupt vector from locations \$1FF8 and \$1FF9 in order to begin servicing the interrupt. If the MPU is interrupted by the timer while in the WAIT mode, the interrupt vector fetch would be from locations \$1FF6 and \$1FF7. The counter continues to count after it reaches zero, allowing the software to determine the number of internal or external input clocks since the timer interrupt request bit was set. The counter may be read at any time by the processor without disturbing the count. The content of the counter becomes stable prior to the read portion of a cycle and does not change during the read. The timer interrupt request bit remains set until cleared by the software. If a read occurs before the timer interrupt is serviced, the interrupt is lost. TCR7 may also be used as a scanned status bit in a non-interrupt mode of operation (TCR6=1). The prescaler is a 7-bit divider which is used to extend the maximum length of the timer. Bit 0, bit 1, and bit 2 of the TCR are programmed to choose the appropriate prescaler output which is used as the counter input. The processor cannot write into or read from the prescaler; however, its contents are cleared to all "0s" by the write operation into TCR when bit 3 of the written data equals 1, which allows for truncation-free counting. The timer input can be configured for three different operating modes, plus a disable mode, depending on the value written to the TCR4, TCR5 control bits. Refer to the Timer Control Register section. #### **TIMER INPUT MODE 1** If TCR4 and TCR5 are both programmed to a "0", the input to the timer is from an internal clock and the external TIMER input is disabled. The internal clock mode can be used for periodic interrupt generation, as well as a reference in frequency and event measurement. The internal clock is the instruction cycle clock and is coincident with address strobe (AS) except during a WAIT instruction. During a WAIT instruction the AS pin goes to a low state but the internal clock to the timer continues to run at its normal rate. #### **TIMER INPUT MODE 2** With TCR4=1 and TCR5=0, the internal clock and the TIMER input pin are ANDed to form the timer input signal. This mode can be used to measure external pulse widths. The external timer input pulse simply turns on the internal clock for the duration of the pulse. The resolution of the count in this mode is $\pm 1$ clock and therefore accuracy improves with longer input pulse widths. #### **TIMER INPUT MODE 3** If TCR4=0 and TCR5=1, then all inputs to the timer are disabled. #### **TIMER INPUT MODE 4** If TCR4=1 and TCR5=1, the internal clock input to the timer is disabled and the TIMER input pin becomes the input to the timer. The external TIMER pin can, in this mode, be used to count external events as well as external frequencies for generating periodic interrupts. Figure 19 shows a block diagram of the timer subsystem. **MOTOROLA** Semiconductor Products Inc. #### FIGURE 19 - TIMER BLOCK DIAGRAM #### NOTES: - 1. Prescaler and timer data register are clocked on the falling edge of the internal clock (AS) or external input. - 2. Timer data register is written to during data strobe (DS) and counts down continuously. #### TIMER CONTROL REGISTER (TCR) | | 7 | 6 5 4 TCR6 TCR5 TCR4 | | 3 | 2 | 1 | 0 | | |----|-----|----------------------|------|------|------|------|------|------| | To | CR7 | TCR6 | TCR5 | TCR4 | TCR3 | TCR2 | TCR1 | TCR0 | All bits in this register except bit 3 are read/write bits. TCR7 — Timer interrupt request bit: bit used to indicate the timer interrupt when it is logic "1". - 1 Set whenever the counter decrements to zero, or under program control. - O Cleared on external reset, power-on reset, STOP instruction, or program control. **TCR6** — Timer interrupt mask bit: when this bit is a logic "1" it inhibits the timer interrupt to the processor. - Set on external reset, power-on reset, STOP instruction, or program control. - 0 Cleared under program control. TCR5 – External or internal bit: selects the input clock source to be either the external TIMER pin or the internal clock (unaffected by RESET). - † Select external clock source. - 0 Select internal clock source (AS). **TCR4** — External enable bit: control bit used to enable the external TIMER pin (unaffected by RESET). - 1 Enable external TIMER pin. - 0 Disable external TIMER pin. | ICna | I CR4 | |------|-------| | 0 | 0 | | 0 | 1 | | 1 | 0 | | 1 | 1 | Internal clock (AS) to timer AND of internal clock (AS) and TIMER pin to timer Inputs to timer disabled TIMER pin to timer **TCR3** – Timer Prescaler Reset bit: writing a "1" to this bit resets the prescaler to zero. A read of this location always indicates a "0" (unaffected by $\overline{\text{RESET}}$ ). TCR2, TCR1, TCR0 — Prescaler address bits: decoded to select one of eight outputs of the prescaler (unaffected by RESET). #### Prescaler | _ | FIE | Scalei | | |------|------|--------|--------| | TCR2 | TCR1 | TCR0 | Result | | 0 | 0 | 0 | ÷ 1 | | 0 | 0 | 1 | ÷ 2 | | 0 | 1 | ÷ 4 | | | 0 | 1 | 1 | ÷8 | | 1 | 0 | 0 | ÷ 16 | | 1 | 0 | 1 | ÷ 32 | | 1 | 1 | 0 | ÷ 64 | | 1 | 1 | 1 | ÷ 128 | #### **INSTRUCTION SET** The MPU has a set of 61 basic instructions. They can be divided into five different types: register/memory, read-modify-write, branch, bit manipulation, and control. The following paragraphs briefly explain each type. All the instructions within a given type are presented in individual tables. **MOTOROLA** Semiconductor Products Inc. - ## **REGISTER/MEMORY INSTRUCTIONS** Most of these instructions use two operands. One operand is either the accumulator or the index register. The other operand is obtained from memory using one of the addressing modes. The jump unconditional (JMP) and jump to subroutine (JSR) instructions have no register operand. Refer to Table 4. #### **READ-MODIFY-WRITE INSTRUCTIONS** These instructions read a memory location or a register, modify or test its contents, and write the modified value back to memory or to the register. The test for negative or zero (TST) instruction is an exception to the read-modifywrite sequence since it does not modify the value. Refer to Table 5. #### **BRANCH INSTRUCTIONS** This set of instructions branches if a particular condition is met, otherwise no operation is performed. Branch instructions are two byte instructions. Refer to Table 6. #### **BIT MANIPULATION INSTRUCTIONS** The MPU is capable of setting or clearing any bit which resides in the first 256 bytes of the memory space, where all port registers, port DDRs, timer, timer control, and on-chip RAM reside. An additional feature allows the software to test and branch on the state of any bit within these 256 locations. The bit set, bit clear and bit test, and branch functions are all implemented with a single instruction. For the test and branch instructions, the value of the bit tested is also placed in the carry bit of the condition code register. Refer to Table #### **CONTROL INSTRUCTIONS** These instructions are register reference instructions and are used to control processor operation during program execution. Refer to Table 8. #### **ALPHABETICAL LISTING** The complete instruction set is given in alphabetical order in Table 9. #### **OPCODE MAP SUMMARY** Table 10 is an opcode map for the instructions used on the MCU. ## **ADDRESSING MODES** The MPU uses ten different addressing modes to provide the programmer with an opportunity to optimize the code to all situations. The various indexed addressing modes make it possible to locate data tables, code conversion tables, and scaling tables anywhere in the memory space. Short indexed accesses are single byte instructions, while the longest instructions (three bytes) permit accessing tables throughout memory. Short and long absolute addressing is also included. Two byte direct addressing instructions access all data bytes in most applications. Extended addressing permits jump instructions to reach all memory. Table 9 shows the addressing modes for each instruction, with the effects each instruction has on the condition code register. An opcode map is shown in Table 10. The term "effective address" or EA is used in describing the various addressing modes, and is defined as the address to or from which the argument for an instruction is fetched or stored. The ten addressing modes of the processor are described below. Parentheses are used to indicate "contents of," an arrow indicates "is replaced by," and a colon indicates concatenation of two bytes. #### INHERENT In inherent instructions all the information necessary to execute the instruction is contained in the opcode. Operations specifying only the index register or accumulator, and no other arguments, are included in this mode. #### **IMMEDIATE** In immediate addressing, the operand is contained in the byte immediatley following the opcode. Immediate addressing is used to access constants which do not change during program execution (e.g., a constant used to initialize a loop counter). $$EA = PC + 1$$ ; $PC + PC + 2$ #### DIRECT In the direct addressing mode, the effective address of the argument is contained in a single byte following the opcode byte. Direct addressing allows the user to directly address the lowest 256 bytes in memory with a single two byte instruction. This includes all on-chip RAM and I/O registers and up to 128 bytes of off-chip ROM. Direct addressing is efficient in both memory and speed. #### **EXTENDED** In the extended addressing mode, the effective address of the argument is contained in the two bytes following the opcode. Instructions with extended addressing modes are capable of referencing arguments anywhere in memory with a single three byte instruction. When using the Motorola assembler, the user need not specify whether an instruction uses direct or extended addressing. The assembler automatically selects the most efficient addressing mode. $$EA = (PC + 1):(PC + 2); PC + PC + 3$$ ddross Bus High a (PC + 1); Address Bus Law (PC + 2); Address Bus High $\leftarrow$ (PC + 1); Address Bus Low $\leftarrow$ (PC + 2) #### INDEXED, NO OFFSET In the indexed, no offset addressing mode, the effective address of the argument is contained in the 8-bit index register. Thus, this addressing mode can access the first 256 memory locations. These instructions are only one byte long. This mode is used to move a pointer through a table or to address a frequently referenced RAM or I/O location. EA = X; $$PC \leftarrow PC + 1$$ Address Bus High $\leftarrow 0$ , Address Bus Low $\leftarrow X$ #### INDEXED, 8-BIT OFFSET Here the EA is obtained by adding the contents of the byte following the opcode to that of the index register; therefore, the operand is located anywhere within the lowest 511 memory locations. For example, this mode of addressing is useful for selecting the m-th element in an n element table. All instructions are two bytes. The contents of the index register (X) is not changed. The contents of (PC+1) is an unsigned 8-bit integer. One byte offset indexing permits look-up tables to be easily accessed in either RAM or ROM. $$EA = X + (PC + 1); PC \leftarrow PC + 2$$ Address Bus High + K; Address Bus Low + X + (PC + 1) where: K = The carry from the addition of X + (PC + 1) #### INDEXED, 16-BIT OFFSET In the indexed, 16-bit offset addressing mode the effective address is the sum of the contents of the unsiged 8-bit index register and the two unsigned bytes following the opcode. This addressing mode can be used in a manner similar to indexed 8-bit offset, except that this three byte instruction allows tables to be anywhere in memory (e.g., jump tables in ROM). As with direct and extended, the M6805 assembler determines the most efficient form of indexed offset — 8 or 16 bit. The content of the index register is not changed. EA = X + [(PC + 1):(PC + 2)]; PC + PC + 3Address Bus High + (PC + 1) + KAddress Bus Low + K + (PC + 2)where: K = The carry from the addition of <math>X + (PC + 2) #### RELATIVE Relative addressing is used only in branch instructions. In relative addressing the content of the 8-bit signed byte following the opcode (the offset) is added to the PC if and only if the branch condition is true. Otherwise, control proceeds to the next instruction. The span of relative addressing is limited to the range of -126 to +129 bytes from the branch instruction opcode location. The Motorola assembler calculates the proper offset and checks to see if it is within the span of the branch. EA = PC + 2+ (PC + 1); PC $\leftarrow$ EA if branch is taken; otherwise, PC $\leftarrow$ PC + 2 #### BIT SET/CLEAR Direct addressing and bit addressing are combined in instructions which set and clear individual memory and I/O bits. In the bit set and clear instructions, the byte is specified as a direct address in the location following the opcode. The first 256 addressable locations are thus accessed. The bit to be modified within that byte is specified with three bits of the opcode. The bit set and clear instructions occupy two bytes, one for the opcode (including the bit number) and the second to address the byte which contains the bit of interest. EA = (PC + 1); PC + PC + 2Address Bus High +0; Address Bus Low +(PC + 1) #### BIT TEST AND BRANCH Bit test and branch is a combination of direct addressing, bit addressing, and relative addressing. The bit address and condition (set or clear) to be tested are part of the opcode. The address of the byte to be tested is in the single byte immediately following the opcode byte (EA1). The signed relative 8-bit offset is in the third byte (EA2) and is added to the PC if the specified bit is set or clear in the specified memory location. This single three byte instruction allows the program to branch based on the condition of any bit in the first 256 locations of memory. EA1 = (PC+1) Address Bus High +0; Address Bus Low +(PC+1) EA2 = PC+3+(PC+2), PC+EA2 if branch taken; otherwise, PC+PC+3 #### SYSTEM CONFIGURATION Figures 20 through 25 show in general terms how the MC146805E2 bus structure may be utilized. Specified interface details vary with the various peripheral and memory devices employed. Table 11 provides a detailed description of the information present on the bus, read/write $(R/\overline{W})$ pin and the load instruction (LI) pin during each cycle for each instruction. This information is useful in comparing actual with expected results during debug of both software and hardware as the control program is executed. The information is categorized in groups according to addressing mode and number of cycles per instruction. | | | | | | TABL | <u> 4 - Ri</u> | GISTER | MEMO | RY INST | RUCTIO | NS | | | | | | | | | |------------------------------------------|----------|------------|------------|-------------|------------|----------------|-------------|------------|------------|-------------|------------------------|------------|-------------|---------------------------|------------|--------|----------------------------|------------|--------| | | | <u> </u> | | | | | | | | Addressi | ng Mode | 16 | | | | 4 | <b>.</b> | | | | | | Immediate | | | | Direct | | Extended | | | Indexed<br>(No Offset) | | | indexed<br>(8-Bit Offset) | | | Indexed<br>(16-Bit Offset) | | | | Function | Mnemonic | Op<br>Code | #<br>Bytes | #<br>Cycles | Op<br>Code | #<br>Bytes | #<br>Cycles | Op<br>Code | #<br>Bytes | #<br>Cycles | Op<br>Code | #<br>Bytes | #<br>Cycles | Op<br>Code | #<br>Bytes | Cycles | Op<br>Code | #<br>Bytes | Cycles | | Load A from Memory | LDA | A6 | 2 | 2 | B6 | 2 | 3 | C6 | 3 | 4 | F6 | 1 | 3 | E6 | 2 | 4 | D6 | 3 | 5 | | Load X from Memory | LDX | AE | 2 | 2 | BE | 2 | 3 | CE | 3 | 4 | FE | 1 | 3 | EE | 2 | 4 | DE | 3 | 5 | | Store A in Memory | STA | _ | _ | | B7 | 2 | 4 | C7 | 3 | 5 | F7 | 1 | 4 | <b>E</b> 7 | 2 | 5 | D7 | 3 | 6 | | Store X in Memory | STX | | - | | BF | 2 | 4 | CF | 3 | 5 | FF | 1 | 4 | EF | 2 | 5 | DF | 3 | 6 | | Add Memory to A | ADD | AB | 2 | 2 | BB | 2 | 3 | СВ | 3 | 4 | FB | 1 | 3 | EB | 2 | 4 | DB | 3 | 5 | | Add Memory and<br>Carry to A | ADC | A9 | _ 2 | 2 | В9 | 2 | 3 | С9 | 3 | 4 | F9 | 1 | 3 | E9 | 2 | 4 | D9 | 3 _ | 5 | | Subtract Memory | SUB | A0 | 2 | 2 | В0 | 2 | 3 | CO | 3 | 4 | F0 | 1 | 3 | E0 | 2 | 4 | D0 | 3 | 5 | | Subtract Memory from<br>A with Borrow | SBC | A2 | 2 | 2 | B2 | 2 | 3 | C2 | 3 | 4 | F2 | 1 | 3 | E2 | 2 | 4 | D2 | 3 | 5 | | AND Memory to A | AND | A4 | 2 | 2 | B4 | 2 | 3 | C4 | 3 | 4 | F4 | <b>1</b> | 3 | E4 | 2 | 4 | D4 | 3 | 5 | | OR Memory with A | ORA | AA | 2 | 2 | BA | 2 | 3 | CA | 3 | 4 | FA | 1 | 3 | EA | 2 | 4 | DA | 3 | 5 | | Exclusive OR Memory with A | EOR | A8 | 2 | 2 | В8 | 2 | 3 | C8 | 3 | 4 | F8 | 1 | 3 | E8 | 2 | 4 | D8 | 3 | 5 | | Arithmetic Compare A with Memory | СМР | A1 | 2 | 2 | 81 | 2 | 3 | C1 | 3 | 4 | F1 | 1 | 3 | E1 | 2 | 4 | D1 | 3 | 5 | | Arithmetic Compare X with Memory | СРХ | А3 | 2 | 2 | вз | 2 | 3 | С3 | 3 | 4 | F3 | 1 | 3 | E3 | 2 | 4 | D3 | 3 | 5 | | Bit Test Memory with A (Logical Compare) | BIT | A5 | 2 | 2 | B5 | 2 | 3 | C5 | 3 | 4 | F5 | 1 | 3 | E5 | 2 | 4 | D5 | 3 | 5 | | Jump Unconditional | JMP | _ | | _ | вс | 2 | 2 | СC | 3 | 3 | FC | 1 | 2 | EC | 2 | 3 | DC | 3 | 4 | | Jump to Subroutine | JSR | - | | | BD | 2 | 5 | CD | 3 | 6 | FD | 1 | 5 | ED | 2 | 6 | DD | 3 | 7 | | | | | | IADLE | O THE | AD-MOL | THY-VVKI | I F IN2 | RUCTIC | N2 | | | | | | | |----------------------------|----------|------------|------------|-------------|------------|------------|-------------|------------|------------|-------------|------------|---------------------|-------------|------------|---------------------|-------------| | | | | | | | | | | Addressi | ng Mode | 8 | | | | | | | | | In | herent ( | A) | lr | herent ( | X) | | Direct | | (1 | Indexed<br>No Offse | | (8 | Indexed<br>Bit Offs | | | Function | Mnemonic | Op<br>Code | #<br>Bytes | #<br>Cycles | Op<br>Code | #<br>Bytes | #<br>Cycles | Op<br>Code | #<br>Bytes | #<br>Cycles | Op<br>Code | #<br>Bytes | #<br>Cycles | Op<br>Code | #<br>Bytes | #<br>Cycles | | Increment | INC | 4C | 1 | 3 | 5C | 1 | 3 | 3C | 2 | 5 | 7C | 1 | 5 | 6C | 2 | 6 | | Decrement | DEC | 4A | 1 | 3 | 5A | 1 | 3 | 3A | 2 | 5 | 7A | 1 | 5 | 6A | 2 | 6 | | Clear | CLR | 4F | 1 | 3 | 5F | 1 | 3 | 3F | 2 | 5 | 7F | 1 | 5 | 6F | 2 | 6 | | Complement | СОМ | 43 | 1 | 3 | 53 | 1 | 3 | 33 | 2 | 5 | 73 | 1 | 5 | 63 | 2 | 6 | | Negate<br>(2's Complement) | NEG | 40 | 1 | 3 | 50 | 1 | 3 | 30 | 2 | 5 | 70 | 1 | 5 | 60 | 2 | 6 | | Rotate Left Thru Carry | ROL | 49 | 1 | 3 | 59 | 1 | 3 | 39 | 2 | 5 | 79 | 1 | 5 | 69 | 2 | 6 | | Rotate Right Thru<br>Carry | ROR | 46 | 1 | 3 | 56 | 1 | 3 | 36 | 2 | 5 | 76 | 1 | 5 | 66 | 2 | 6 | | Logical Shift Left | LSL | 48 | 1 | 3 | 58 | 1 | 3 | 38 | 2 | 5 | 78 | 1 | 5 | 68 | 2 | 6 | | Logical Shift Right | LSR | 44 | 1 | 3 | 54 | 1 | 3 | 34 | 2 | 5 | 74 | 1 | 5 | 64 | 2 | 6 | | Arithmetic Shift Right | ASR | 47 | 1 | 3 | 57 | 1 | 3 | 37 | 2 | 5 | 77 | 1 | 5 | 67 | 2 | 6 | | Test for Negative or Zero | TST | 4D | 1 | 3 | 5D | 1 | 3 | 3D | 2 | 4 | 7D | 1 | 4 | 6D | 2 | 5 | TABLE 6 - BRANCH INSTRUCTIONS | | | Relative | Addressin | g Mode | |----------------------------------------|----------|------------|------------|-------------| | Function | Mnemonic | Op<br>Code | #<br>Bytes | #<br>Cycles | | Branch Always | BRA | 20 | 2 | 3 | | Branch Never | BRN | 21 | 2 | 3 | | Branch IFF Higher | вні | 22 | 2 | 3 | | Branch IFF Lower or Same | BLS | 23 | 2 | 3 | | Branch IFF Carry Clear | BCC | 24 | 2 | 3 | | (Branch IFF Higher or Same) | (BHS) | 24 | 2 | 3 | | Branch IFF Carry Set | BCS | 25 | 2 | 3 | | (Branch IFF Lower) | (BLO) | 25 | 2 | 3 | | Branch IFF Not Equal | BNE | 26 | 2 | 3 | | Branch IFF Equal | BEQ | 27 | 2 | 3 | | Branch IFF Half Carry Clear | внсс | 28 | 2 | 3 | | Branch IFF Half Carry Set | BHCS | 29 | 2 | 3 | | Branch IFF Plus | BPL | 2A | 2 《 | 3 | | Branch IFF Minus | ВМІ | 2B | 2 | 3 | | Branch IFF Interrupt Mask Bit is Clear | ВМС | 2C | 2 | 3 | | Branch IFF Interrupt Mask Bit is Set | BMS | 2D 🥒 | 2 | 3 | | Branch IFF Interrupt Line is Low | BIL | 2E | 2 | 3 | | Branch IFF Interrupt Line is High | ВІН | 2F | 2 | 3 | | Branch to Subroutine | BSR 🦠 | AD | 2 | 6 | TABLE 7 — BIT MANIPULATION INSTRUCTIONS | | | | | Addre | essing Mod | es | | |---------------------------|------------------|------------|------------|-------------|------------|------------|-------------| | • • • • | | Bi | ranch | | | | | | Function | Mnemonic | Op<br>Code | #<br>Bytes | #<br>Cycles | Op<br>Code | #<br>Bytes | #<br>Cycles | | Branch IFF Bit n is Set | BRSET n (n=07) | | - | _ | 2•n | 3 | 5 | | Branch IFF Bit n is Clear | BRCLR n (n = 07) | _ | _ | _ | 01 + 2•n | 3 | 5 | | Set Bit n | BSET n (n = 07) | 10 + 2•n | 2 | 5 | _ | - | _ | | Clear Bit n | BCLR n (n = 07) | 11 + 2•n | 2 | 5 | _ | _ | _ | TABLE 8 - CONTROL INSTRUCTIONS | | Set Bit n | B3E1 11 (n = 0/) | 10 + 2 • n | ۷. | 5 | | |-----|-------------|--------------------------|-------------|------------|------------|-------------| | | Clear Bit n | BCLR n (n = 07) | 11 + 2•n | 2 | 5 | - | | | | TABLE 8 — | CONTROL INS | STRUCTIO | ONS | | | | | | | ſ | Inherent | | | All | | Function | Mnemonic | Op<br>Code | #<br>Bytes | #<br>Cycles | | | | Transfer A to X | TAX | 97 | 1 | 2 | | | | Transfer X to A | TXA | 9F | 1 | 2 | | | * | Set Carry Bit | SEC | 99 | 1 | 2 | | | | Clear Carry Bit | CLC | 98 | 1 | 2 | | *** | | Set Interrupt Mask Bit | SEI | 9B | 1 | 2 | | | | Clear Interrupt Mask Bit | CLI | 9A | 1 | 2 | | | | Software Interrupt | SWI | 83 | 1 | 10 | | | | Return from Subroutine | RTS | 81 | 1 | 6 | | | | Return from Interrupt | RTI | 80 | 1 | 9 | | | | Reset Stack Pointer | RSP | 9C | 1 | 2 | | | | No-Operation | NOP | 9D | 1 | 2 | | | | Stop | STOP | 8E | 1 | 2 | | | | Wait | WAIT | 8F | 1 | 2 | TABLE 9 - INSTRUCTION SET | | | | | A | ddressing l | Modes | | | | | Co | ndit | tion | Co | des | |------------|--------------------------------------------------|--------------------------------------------------|------------------|--------------------------------------------------|-------------|------------------------|---------------------|--------------------------------------------------|--------------------------------------------------|--------------------------------------------------|----|------|------|-----|--------| | Mnemonic | Inherent | Immediate | Direct | Extended | Relative | Indexed<br>(No Offset) | Indexed<br>(8 Bits) | Indexed<br>(16 Bits) | Bit<br>Set/<br>Clear | Bit<br>Test &<br>Branch | н | - | N | z | С | | ADC | | X | Х | × | | X | X | X | | | Λ | • | A | Λ | Λ | | ADD | ļ | X | X | X | | X | X | X | | | A | • | A | T A | A | | AND | <u> </u> | X | X | X | | X | X | X | | | • | • | Λ | Λ | (Data) | | ASL | <u> </u> | | X | | | X | X | | | | • | • | Α | A | A | | ASR<br>BCC | X | | X | | | X | X | | L | | • | • | Λ | Λ | A | | BCLR | <b>-</b> | | | | X | | | | <u>L.</u> . | | • | • | | | | | BCS | <del></del> | | | | ., | | | | X | | • | | | | • | | BEQ | <del></del> | | | | X | | | | <u> </u> | | 9 | | • | • | • | | BHCC | <del> </del> | <del> </del> | | | X | | | | <b>!</b> | | • | • | | • | • | | BHCS | <del></del> | <del></del> | <del></del> | <u> </u> | X | | <b></b> | | <u> </u> | | • | | 1. | • | • | | BHI | | <u> </u> | <del></del> | <del></del> | X | | ļ | | <u> </u> | 4 | | • | • | | | | BHS | <b>—</b> | <del></del> | | | X | | | L | <b>!</b> | 4. 1 | | • | | • | • | | BIH | | <del> </del> | | | X | | | | | | • | • | • | • | • | | BIL | <del></del> | <del></del> | | | X | | | | - 4 | | • | • | • | • | • | | BIT | <del></del> | × | x | | Х | | ļ | | | | • | • | | • | • | | BLO | <b>-</b> | <del> ^</del> | <del>^-</del> | X | <del></del> | X | Х | X | | | • | • | A | Α | • | | BLS | <del> </del> | - | $\vdash$ | <del> </del> | X | | <b></b> | | | | • | • | • | | • | | BMC | | <del>-</del> | <del></del> | <del> </del> | X | | <u> </u> | <b></b> | 10000 | <u> </u> | • | • | • | • | • | | BMI | <del> </del> | <del></del> | <del></del> | <del></del> | X | | ļ | | b | <u> </u> | • | • | • | • | • | | BMS | - | <del> </del> | <del></del> | <b></b> | X | | | 4.4 | | <u> </u> | • | • | • | • | • | | BNE | <del></del> | | <del> </del> | ļ | X | | | | L | | • | • | • | • | • | | BPL | | <del></del> | <del> </del> | | X | | | | <u> </u> | | • | • | • | • | • | | BRA | | <u> </u> | <del></del> | | X | | | | <b> </b> | | • | • | • | • | • | | BRN | <del></del> | | | | X | | | | L | | • | • | • | • | • | | BRCLR | | | | | X | | | ļ | | | • | • | • | • | • | | BRSET | <del></del> | <del></del> | <del></del> | ļ | | | | ļ | <u> </u> | X | • | • | • | • | ΙΛ. | | BSET | | | | ļ. ——— | | | 1 | | L | Х | • | • | • | • | Λ | | BSR | | | <u> </u> | | | | | | X | | • | • | • | • | • | | CLC | х | | | | X | | | | <b> </b> | | • | • | • | • | • | | CLI | ·x | | | | | | | | | | • | • | • | • | 0 | | CLR | | | | | | | | | <u> </u> | | • | 0 | | • | • | | | X | | X | ļ | | X | X | | | | • | • | 0 | 1 | • | | CMP | | X | Х | X | | " X | X | X | | | • | • | Λ | Λ | Λ | | COM | Х | _ | X | | | X | Х | | | | • | • | Λ | Λ | 1 | | CPX | | Х | Х | X | | X | X | X | | | • | • | A | Λ | A | | DEC | Х | | Х | | | X | X | | | | • | • | Λ | Λ | • | | EOR | | X | Х | X | ** | X | X | X | | | • | • | Λ | Λ | • | | INC | Х | | Х | | | _ X | X | | | | • | • | Λ | Λ | • | | JMP | | | _ х | X | | X | X | X | | | • | • | • | • | • | | JSR | | | X | X | | X | X | X | | | • | • | • | • | • | | LDA | | X | X | X | | X | Х | Х | | | • | • | Λ | Λ | • | | LDX | | X | X | X | | X | X | X | | <u> </u> | • | • | Λ | A | • | | LSL | Х | | X | | | X | Х | | 1 | T | • | • | Λ | Λ | Λ | | LSR | Х | | _ X | | | X | X | | | | • | • | ō | Ā | Ā | | NEG | X | | X | | | X | X | | | | • | • | Ā | | Ā | | NOP | Х | | | | | | | | | | • | • | • | • | | | ORA | | X | X | X | | Х | Х | × | <u> </u> | | • | • | Ā | A | • | | ROL | X | | X | | | X | Х | | <u> </u> | | • | • | | Ā | Ā | | ROR. | Х | | Х | | | Х | X | | | | • | • | Ā | Ā | Ä | | RSP | X | | | | | | | <del></del> | T | 1 | • | | • | ë | i | | RTI | X | | | | | | | | | <del></del> | 7 | 7 | 7 | 7 | 15 | | RTS | X | | | | | | | l | 1 | <u> </u> | • | | | | | | SBC | | X | X | × | | X | х | X | <del> </del> | <del></del> | • | | Λ | | | | SEC | X | | | | - | | <u> </u> | <del> </del> | <del> </del> | <del> </del> | • | | • | | | | SEI | × | | T | | | | | <del> </del> | <del> </del> | <del> </del> | - | | | - | | | STA | | | Х | X | | × | × | × | <del></del> | <del> </del> | • | | Λ | | | | STOP | × | | | <del></del> | <u> </u> | | | <del> </del> | <del></del> | <del> </del> | • | | | | | | STX | 1 | | × | × | | × | × | X | <b>├</b> ── | <del> </del> | _ | | | | • | | SUB | | Х | x | <del>- x</del> | | x | <del>- ^</del> | <del>x</del> | <del></del> | <del> </del> | • | ٦ | A | ╀ | ۳ | | SWI | Х | <del></del> | <del> ^</del> _ | <del>- ^-</del> | | <del>- ^-</del> - | | <del> ^-</del> | <del></del> | <del></del> | | | Δ | | | | TAX | x | | <del> </del> | <del></del> | | <del></del> | | <b></b> | <b>-</b> | ļ | • | 1 . | | | • | | | x | | × | <del> </del> | <del></del> | × | X | <u> </u> | <del> </del> | <del> </del> | • | • | | | | | TST | | | | | | | | | | | | | | | | | TST<br>TXA | x | | <del> ^</del> _ | | | | <del></del> | | ├─ | <del> </del> | • | | | | | #### **Condition Code Symbols** - H Haff Carry (From Bit 3) Interrupt Mask N Negative (Sign Bit) Z Zero C Carry/Borrow - A Test and Set if True. Cleared Otherwise. Not Affected Load CC Register From Stack Cleared Set #### TABLE 10 - MC146806 CMOS INSTRUCTION SET OPCODE MAP | | Bit Mai | nipulation | Branch | | Re | ad-Modify-V | Vrite | | Control Register/Memory | | | | | | | | | |------------|-----------------|-----------------------------|--------------|--------------|--------------------|---------------|--------------|------------------|-------------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|-----------| | | ВТВ | BSC | REL | DIR | INH | INH | IX1 | ΙX | INH | INH | IMM | DIR | EXT | IX2 | IX1 | ΙX | | | Low Hi | 0000 | 1<br>0001 | 0010 | 3<br>0011 | 4<br>0100 | 5<br>0101 | 6<br>0110 | 7<br>0111 | 1000 | 9<br>1001 | A<br>1010 | B<br>1011 | 1100 | D<br>1101 | E<br>1110 | 1111 | Hi Low | | 0 | BRSETO<br>3 BTB | BSETO<br>2 BSC | BRA<br>2 REL | NEG<br>2 DIR | NEG<br>1 INH | NEG<br>1 INH | NEG 1X1 | NEG 1 IX | RTI<br>1 INH | | SUB<br>2 IMM | SUB 3 | SUB<br>3 EXT | SUB 5 | SUB 4<br>2 IX1 | SUB 3 | 00000 | | 1 0001 | BRCLRO<br>3 BTB | BCLRO<br>2 BSC | BRN<br>2 REL | | | | | | RTS<br>1 INH | | CMP 2 IMM | CMP<br>2 DIR | CMP<br>3 EXT | CMP 3 1X2 | CMP 2 1X1 | CMP IX | 0001 | | 2 0010 | BRSET1<br>3 BTB | BSET1<br>2 BSC | BHI<br>2 REL | | | | | | | | SBC 2 IMM | | SBC SBC | SBC S | SBC 2 IX1 | SBC 3 | 2<br>0010 | | 3<br>0011 | BRCLR1<br>3 BTB | BCLR1<br>2 BSC | BLS<br>2 REL | COM DIR | COMA 1 NH | COMX 3 | COM 6 | COM 1X | SWI<br>1 INH | | CPX 2 | CPX DIR | CPX 3 EXT | CPX 5 | CPX 2 IX1 | CPX 3 | 3<br>0011 | | 4<br>0100 | BRSET2<br>3 BTB | BSET2<br>2 BSC | BCC REL | LSR<br>2 DTR | LSRA NH | LSRX<br>1 INH | LSR 2 IX1 | LSR 1 | | | AND 2 | AND DIR | AND<br>3 EXT | AND 3 | AND 2 (X1 | AND 1X | 0100 | | 5<br>_0101 | BRCLR2<br>3 BTB | BCLR2<br>2 BSC | BCS REL | | 3 | 3 | 6 | 5 | | | BIT 2 | BIT 2 DIR | BIT EXT | BIT 3 | BIT X1 | BIT IX | 5<br>0101 | | 6<br>0110 | BRSET3 | BSET3 | BNE 3 | ROR DIR | RORA | RORX 1 INH | ROR 2 1X1 | ROR 1X | | 2 | LDA 2 IMM | LDA<br>2 DIR | LDA<br>3 EXT | LDA X | LDA<br>2 IX1 | LDA<br>1 IX | 6<br>0110 | | 7 0111 | BRCLR3 | BCLR3 <sup>2</sup><br>2 BSC | BEQ REL | ASR 2 DIR | ASRA 1 INH | ASRX 1 NH | ASR 2 1x1 | ASR 1X 5 | | TAX 1 | 2 | STA<br>2 DIR<br>3 | STA<br>3 EXT | STA 3 1X2 | STA 1X1 | STA<br>1 IX<br>3 | 7 0111 | | 1000 | BRSET4 | BSET4 SSC | BHCC 3 | LSL DIR | LSLA INH | LSLX 3 | LSL 2 1X1 | LSL 1X | | CLC 1 | EOR 2 | EOR DIR | EOR 3 EXT | EOR 3 1X2 | EOR 2 1X1 | EOR 1 IX | 1000 | | 9<br>1001 | BRCLR4<br>3 BTB | BCLR4<br>2 BSC | BHCS REL | ROL<br>2 DIR | ROLA 1 INH | ROLX NH | ROL 2 X1 | ROL<br>1 1x<br>5 | | SEC 1 INH | ADC 1MM | ADC 2 DIR | ADC 3 EXT | ADC IX2 | ADC 1X1 | ADC 1X | 9<br>1001 | | A<br>1010 | BRSET5 | BSET5 | BPL 2 REL | DEC 2 DIR | DECA 1 INH | DECX 1 INH | DEC IX1 | DEC IX | | CLI 1 INH | ORA 2 IMM | ORA<br>2 DIH | ORA<br>3 EXT | ORA<br>3 1X2 | ORA 2 1X1 | ORA IX | A<br>1010 | | B<br>1011 | BRCLR5<br>3 BTB | BCLR5<br>2 BSC | BMI 2 REL | 5 | 3 | 3 | - | 5 | | SEI<br>1 INH<br>2 | ADD 2 IMM | ADD DIR | ADD<br>3 EXT | ADD<br>3 ix2 | ADD 2 1X1 3 | ADD IX | B<br>1011 | | C<br>1100 | BRSET6<br>3 BTB | BSET6<br>2 BSC<br>5 | BMC REL | INC DIR | INCA<br>1 INH<br>3 | INCX<br>1 INH | INC 2 1X1 | INC IX | | RSP 1 INH 2 | 6 | JMP 2 DIR 5 | JMP<br>3 EXT | JMP<br>3 1X2 | JMP 2 1X1 | JMP 1 1X 5 | C<br>1100 | | D<br>1101 | BRCLR6<br>3 BTB | BCLR6<br>2 BSC | BMS REL | TST<br>2 DIR | TSTA | TSTX<br>1 INH | ⊅ST<br>2 IX1 | TST IX | 3 | NOP 1 INH | BSR<br>2 REL<br>2 | JSR<br>2 DIR<br>3 | JSR<br>3 EXT | JSR<br>3 1X2<br>5 | JSR 2 X1 4 | JSR<br>1 IX<br>3 | D<br>1101 | | E<br>1110 | BRSET7<br>3 BTB | BSET7<br>2 BSC<br>5 | BIL REL | 5 | 3 | 3 | | 5 | STOP 1 INH | - 2 | LDX<br>2 IMM | LDX<br>2 DIR | LDX<br>3 EXT<br>5 | 3 X2 | LDX<br>2 X1<br>5 | LDX<br>1 IX<br>4 | E<br>1110 | | F<br>1111 | BRCLR7<br>3 BTB | BCLR7<br>2 BSC | BIH 2 REL | CLR<br>2 DIR | CLRA<br>1 NH | CLRX | CLR IX1 | CLR IX | WAIT 1 INH | TXA 1 | | STX<br>2 DIR | STX<br>3 EXT | STX<br>3 IX2 | STX IX1 | STX<br>1 IX | F<br>1111 | #### Abbreviations for Address Modes | INH | Inherent | |-----|--------------------------------| | Α | Accumulator | | X | Index Register | | IMM | Immediate | | DIR | Direct | | EXT | Extended | | REL | Relative | | BSC | Bit Set/Clear | | BTB | Bit Test and Branch | | IX | Indexed (No Offset) | | IX1 | Indexed, 1 Byte (8-Bit) Offset | | IX2 | Indexed 2 Byte (16-Bit) Offset | #### LEGEND FIGURE 21 — CONNECTION TO CMOS MULTIPLEXED MEMORIES FIGURE 23 — CONNECTION TO LATCHED NON-MULTIPLEXED CMOS ROM AND EPROM FIGURE 25 - CONNECTION TO LATCHED NON-MULTIPLEXED CMOS RAM TABLE 11 — SUMMARY OF CYCLE-BY-CYCLE OPERATION | Address Mode | | | | R/W | LI | | |---------------------|--------------|----------|------------------------------------------------|----------|-----------------|------------------------------------------------------| | Instructions | Cycles | Cycle # | Address Bus | Pin | Pin | Data Bus | | nherent | • | | - | - | | | | SR LSL | | | · | | | | | ASR NEG | | 1 1 | Op Code Address | 1 | 1 | Op Code | | CLR ROL | 3 | 2 | | 1 | Ö | Op Code Next Instruction | | | 3 | ı | Op Code Address +1 | | | | | COM ROR | | 3 | Op Code Address +1 | 1 | 0 | Op Code Next Instruction | | DEC INC TST | L | <u> </u> | | | | | | TAX CLC SEC | | | | | | | | STOP CLI SEI | 2 | 1 | Op Code Address | 1 | 1 | Op Code | | RSP WAIT NOP TXA | * | 2 | Op Code Address +1 | 1 | 0 | Op Code Next Instruction | | TOP WATE NOT TAA | | ļ | | | | | | | | 1 | Op Code Address | 1 | 1 | Op Code | | | 1 | 2 | Op Code Address +1 | 1 | 0 | Op Code Next Instruction | | NTO | | 3 | Stack Pointer | 1 | 0 | Irrelevant Data | | RTS | 6 | 4 | Stack Pointer +1 | 1 | 0.0 | Irrelevant Data | | | | 5 | Stack Pointer +2 | 1 | 6. | Irrelevant Data | | | | 6 | New Op Code Address | 1 | 0 | New Op Code | | | | | | | CONTROL CONTROL | <del></del> | | | | 1 | Op Code Address | 1 | 1 | Op Code | | | | 2 | Op Code Address +1 | 1 | 0 | Op Code Next Instruction | | | | 3 | Stack Pointer | 0 | P 0 | Return Address (LO Byte) | | | 1 | 4 | Stack Pointer - 1 | 0 | 0 | Return Address (HI Byte) | | | | 5 | Stack Pointer -2 | 6 | 0 | Contents of Index Register | | SWI | 10 | 6 | Stack Pointer -3 | Ö | ۱ŏ | Contents of Accumulator | | | | 7 | Stack Pointer -4 | » O | 0 | Contents of CC Register | | | | l . | | » U | ľ | _ | | | | 8 | Vector Address 1FFC (Hex) | 1 | 0 | Address of Int. Routine (HI Byt | | | | 9 | Vector Address 1FFD (Hex) | 1 | 0 | Address of Int. Routine (LO By | | | | 10 | Interrupt Routine Starting Address | 1 | 0 | Interrupt Routine First Opcode | | | | 1 | Op Code Address | 1 | 1 | Op Code | | | | 2 | Op Code Address + 1 | 1 | Ö | Op Code Next Instruction | | | | | , | 1 | _ | | | | | 3 | Stack Pointer | ļ | 0 | Irrelevant Data | | | | 4 | Stack Pointer + 1 | 1 | 0 | Irrelevant Data | | RTI | 9 | 5 | Stack Pointer +2 | 1 | 0 | Irrelevant Data | | | | 6 | Stack Pointer + 3 | 1 | 0 | Irrelevant Data | | | | 7 | Stack Pointer +4 | 1 | Ιo | Irrelevant Data | | | | 8 | Stack Pointer +5 | Ì | Ō | Irrelevant Data | | | | 9 | New Op Code Address | i | ا ŏ | New Op Code | | | l | J 3 | New Op Code Address | | | New Op Code | | mmediate | | . 19 | | | | | | ADC EOR CPX | | A series | | , | | | | ADD LDA LDX | | 1 | Op Code Address | 1 | 1 | Op Code | | AND ORA BIT | 2 | 2 | Op Code Address +1 | i | Ö | Operand Data | | | | • | Op code Address + 1 | ' | ľ | Operand Data | | SBC CMP SUB | | | | | L | | | Bit Set/Clear | | | | | | | | | | 1 | Op Code Address | 1 | 1 | Op Code | | | | 2 | Op Code Address + 1 | i | ö | Address of Operand | | 3SET n | | | l " | | 1 | , | | CLPn | ь 5 | 3 | Address of Operand | 1 | 0 | Operand Data | | SCEN II | | 4 | Address of Operand | 1 | 0 | Operand Data | | | | 5 | Address of Operand | 0 | 0 | Manipulated Data | | Bit Test and Branch | | | | | | | | - Tool and Didney | ) | 1 - | 0.04 444 | | | [ 0 . 0 . d. | | | 1 | 1 | Op Code Address | 1 | 1 | Op Code | | BRSET | 1 | 2 | Op Code Address +1 | 1 | 0 | Address of Operand | | BRCLR n | 5 | 3 | Address of Operand | 1 | 0 | Operand Data | | ONCLA II | 1 | 4 | Op Code Address +2 | 1 | 0 | Branch Offset | | | | 5 | Op Code Address +2 | 1 | Ō | Branch Offset | | Palativa | • | | 1 | <u> </u> | | <u> </u> | | Relative | Г | , | · · · · · · · · · · · · · · · · · · · | | | | | BCC BHI BNE BEQ | | 1 1 | Op Code Address | 1 | 1 | Op Code | | BCS BPL BHCC BLS | , | 1 | 1 ' | | | 1 1 | | BIL BMC BRN BHCS | 3 | 2 | Op Code Address + 1 | 1 | 0 | Branch Offset | | BIH BMI BMS BRA | 1 | 3 | Op Code Address +1 | 1 | 0 | Branch Offset | | Jilli Dillo Dillo | <del> </del> | | 0-0-4-0-4 | | | 0- 0-4- | | | | 1 | Op Code Address | 1 | 1 | Op Code | | | | 2 | Op Code Address +1 | 1 | 0 | Branch Offset | | | 6 | 3 | Op Code Address +1 | 1 | 0 | Branch Offset | | 000 | | | | 1 4 | | | | BSR | " | 4 | Subroutine Starting Address | 1 | 0 | First Subroutine Op Code | | BSR | | 4<br>5 | Subroutine Starting Address<br> Stack Pointer | 0 | 0 | First Subroutine Op Code<br>Return Address (LO Byte) | **MOTOROLA** Semiconductor Products Inc. - | | TABLE 11 — SUMMARY OF CYCLE-BY-CYCLE OPERATION (CONTINUED) | | | | | | | | | |----------------------------|------------------------------------------------------------|---------|-------------------------------------------------|---------------|-----|-----------------------------------------------------------|--|--|--| | Address Mode | | | | R/W | LI | | | | | | Instructions | Cycles | Cycle # | Address Bus | Pin | Pin | Data Bus | | | | | <u>Direct</u> | | | | | | | | | | | JMP | 2 | 1 | Op Code Address | 1 1 | 1 | Op Code | | | | | ADC EOR CPX | | 2 | Op Code Address +1 | 1 | 0 | Jump Address | | | | | ADD LDA LDX | | 1 | Op Code Address | 1 | 1 | Op Code | | | | | AND ORA BIT | 3 | 2 | Op Code Address +1 | 1 1 | 0 | Address of Operand | | | | | SBC CMP SUB | | 3 | Address of Operand | 1 | 0 | Operand Data | | | | | | | 1 | Op Code Address | 1 | 1 | Op Code | | | | | TST | 4 | 2<br>3 | Op Code Address + 1 | 1 1 | 0 | Address of Operand | | | | | 1 | | 4 | Address of Operand Op Code Address + 2 | | 0 | Operand Data Op Code Next Instruction | | | | | | | 1 | Op Code Address | 1 | 1 | Op Code | | | | | STA | 4 | 2 | Op Code Adrress + 1 | 1 | Ö | Address of Operand | | | | | STX | 7 | 3 | Op Code Address +1 | 1 | 0 | Address of Operand | | | | | | | 4 | Address of Operand | 0 | 0 | Operand Data | | | | | LSL LSR DEC | | 1<br>2 | Op Code Address Op Code Address + 1 | 1 | 1 | Op Code | | | | | ASR NEG INC | 5 | 3 | Operand Address | 1 1 | 0 | Address of Operand Current Operand Data | | | | | CLR ROL<br>COM ROR | | 4 | Operand Address | l i l | o d | Current Operand Data | | | | | Com Non | | 5 | Operand Address | 0 | 0 | New Operand Data | | | | | | | 1 | Op Code Address | 1 | 1 | Op Code | | | | | JSR | 5 | 2<br>3 | Op Code Address + 1 Subroutine Starting Address | 1 | 0 | Subroutine Address (LO Byte) 1st Subroutine Op Code | | | | | | | 4 | Stack Pointer | ò | 0 | Return Address (LO Byte) | | | | | | | 5 | Stack Pointer - 1 | 0 | 0 | Return Address (HI Byte) | | | | | Extended | | | | | | | | | | | JMP | | 1 | Op Code Address | 1 | 1 | Op Code | | | | | JMP | 3 | 2<br>3 | Op Code Address + 1 Op Code Address + 2 | 1 1 | 0 | Jump Address (HI Byte) | | | | | ADC BIT ORA | | 1 | Op Code Address | 1 | 1 | Jump Address (LO Byte) Op Code | | | | | ADD CMP LDX | 4 | 2 | Op Code Address + 1 | li | Ö | Address Operand (HI Byte) | | | | | AND EOR SBC | 4 | 3 | Op Code Address +2 | 1 | 0 | Address Operand (LO Byte) | | | | | CPX LDA SUB | | 4 | Address of Operand | 1 | 0 | Operand Data | | | | | | | 1 | Op Code Address | 1 | 1 | Op Code | | | | | STA | 5 | 2 | Op Code Address + 1<br>Op Code Address + 2 | | 0 | Address of Operand (HI Byte) Address of Operand (LO Byte) | | | | | STX | | 4 | Op Code Address +2 | i | ő | Address of Operand (LO Byte) | | | | | | | 5 | Address of Operand | 0 | 0 | Operand Data | | | | | | | 1 | Op Code Address | 1 | 1 | Op Code | | | | | | | 2<br>3 | Op Code Address + 1<br>Op Code Address + 2 | | 0 | Address of Subroutine (HI Byte) | | | | | JSR | 6 | 4 | Subroutine Starting Address | 1 1 | 0 | Address of Subroutine (LO Byte) 1st Subroutine Op Code | | | | | 1 | | 5 | Stack Pointer | o | Ö | Return Address (LO Byte) | | | | | | | 6 | Stack Pointer - 1 | 0 | 0 | Return Address (HI Byte) | | | | | Indexed, No-Offset | | | | , | | | | | | | JMP | 2 | 1<br>2 | Op Code Address<br>Op Code Address + 1 | 1 | 1 | Op Code | | | | | ADC EOR CPX | | | Op Code Address + I | 1 | 0 | Op Code Next Instruction | | | | | ADD LDA LDX | | 1 | Op Code Address | 1 | 1 | Op Code | | | | | AND ORA BIT | 3 | 2<br>3 | Op Code Address + 1<br>Index Register | 1 1 | 0 | Op Code Next Instruction | | | | | SBC CMP SUB | | | | $\perp \perp$ | U | Operand Data | | | | | | | 1 | Op Code Address | 1 | 1 | Op Code | | | | | TST | 4 | 2 | Op Code Address + 1<br>Index Register | 1 1 | 0 | Op Code Next Instruction | | | | | | | 4 | Op Code Address + 1 | 1 1 | 0 | Operand Data Op Code Next Instruction | | | | | | | 1 | Op Code Address | 1 | 1 | Op Code | | | | | STA STX | 4 | 2 | Op Code Address + 1 | 1 | 0 | Op Code Next Instruction | | | | | 314 | | 3<br>4 | Op Code Address + 1<br>Index Register | 0 | 0 | Op Code Next Instruction | | | | | | - | 1 | Op Code Address | 1 | 0 | Operand Data | | | | | LSL LSR DEC<br>ASR NEG INC | | 2 | Op Code Address + 1 | | 0 | Op Code Op Code Next Instruction | | | | | CLR ROL | 5 | 3 | Index Register | 1 | ŏ | Current Operand Data | | | | | COM ROR | | 4<br>5 | Index Register | 1 | 0 | Current Operand Data | | | | | | | 1 | Index Register Op Code Address | 0 | 0 | New Operand Data | | | | | | | 2 | Op Code Address + 1 | | 1 0 | Op Code Op Code Next Instruction | | | | | JSR | 5 | 3 | Index Register | 1 | ő | 1st Subroutine Op Code | | | | | | | 4<br>5 | Stack Pointer | 0 | 0 | Return Address (LO Byte) | | | | | | | 2 | Stack Pointer - 1 | 0 | 0 | Return Address (HI Byte) | | | | TABLE 11 - SUMMARY OF CYCLE-BY-CYCLE OPERATION (CONTINUED) | Address Mode<br>Instructions | Cycles | Cycle# | Address Bus | R/W<br>Pin | LI<br>Pin | Data Bus | |------------------------------|--------|------------------|-------------------------|-------------|-------------|-----------------------------------------------------------------------------------| | Indexed 8-Bit Offset | | | | L | | | | Indexed 6-Bit Offset | 1 | 1 | Op Code Address | 1 | 1 | Op Code | | 1140 | 3 | 2 | Op Code Address + 1 | li | | Offset | | JMP | 3 | 3 | Op Code Address + 1 | 'i | | Offset | | | | | | | | | | ADC EOR CPX | | 1 | Op Code Address | 1 | 1 | Op Code | | ADD LDA LDX | 4 | 2 | Op Code Address +1 | 1 | 0 | Offset | | AND ORA CMP | | 3 | Op Code Address + 1 | 1 | 0 | Offset | | SUB BIT SBC | | 4 | Index Register + Offset | <u> </u> | - | Operand Data | | | | 1 | Op Code Address | 1 | 1 | Op Code | | STA | | 2 | Op Code Address +1 | 1 | 0 | Offset | | STX | 5 | 3 | Op Code Address +1 | 1 | 0 | Offset | | 01 <i>X</i> | | 4 | Op Code Address + 1 | 1 | 0 | Offset | | | | _5 | Index Register + Offset | 0 | 0 | Operand Data | | | | 1 | Op Code Address | 1 | (1/2) | Op Code | | | | 2 | Op Code Address +1 | 1 | 0 | Offset | | TST | 5 | 3 | Op Code Address +1 | 1 | 0 | Offset | | | | 4 | Index Register + Offset | 1 | <b>™</b> 0 | Operand Data | | | | 5 | Op Code Address +2 | 1 | 0 | Op Code Next Instruction | | | | 1 | Op Code Address | 1 | 1 | Op Code | | LSL LSR | | 2 | Op Code Address +1 | 1 | 0 | Offset | | ASR NEG | | 3 | Op Code Address +1 | 1 | 0 | Offset | | CLR ROL | 6 | 4 | Index Register + Offset | 1 | 0 | Current Operand Data | | COM ROR | - | 5 | Index Register + Offset | 1 | 0 | Current Operand Data | | DEC INC | | 6 | Index Register + Offset | 0 | 0 | New Operand Data | | | | 1 | Op Code Address | 1 | 1 | Op Code | | | | 2 | Op Code Address +1 | 1 | 0 | Offset | | | | 3 | Op Code Address + 1 | 1 | 0 | Offset | | JSR | 6 | 4 | Index Register + Offset | 1 | 0 | 1st Subroutine Op Code | | | | 5 | Stack Pointer | 0 | 0 | Return Address LO Byte | | | - | 6 | Stack Pointer -1 | 0 | 0 | Return Address HI Byte | | Indexed, 16-Bit Offset | | | | | | | | | T | 1 | Op Code Address | 1 | 1 | Op Code | | 18.40 | 4 | 2 | Op Code Address +1 | 1 | 0 | Offset (HI Byte) | | JMP | 4 | 3 . ⁴ | Op Code Address +2 | 1 | 0 | Offset (LO Byte) | | | İ | 4 | Op Code Address +2 | 1 | 0 | Offset (LO Byte) | | ADC CMP SUB | 1 | | Op Code Address | 1 | 1 | Op Code | | ADD EOR SBC | | 2 | Op Code Address +1 | 1 | 0 | Offset (HI Byte) | | AND ORA | 5 | 3 | Op Code Address +2 | 1 | 0 | Offset (LO Byte) | | CPX LDA | | 4 | Op Code Address +2 | 1 | 0 | Offset (LO Byte) | | BIT LDX | | 5 | Index Register + Offset | 1 | 0 | Operand Data | | | | 1 | Op Code Address | 1 | 1 | Op Code | | | | 2 | Op Code Address +1 | 1 | 0 | Offset (HI Byte) | | STA | | 3 | Op Code Address +2 | 1 | 0 | Offset (LO Byte) | | STX | б | 4 | Op Code Address +2 | 1 | 0 | Offset (LO Byte) | | | | 5 | Op Code Address +2 | 1 | 0 | Offset (LO Byte) | | | | 6 | Index Register + Offset | 0 | 0 | Operand Data | | | | 1 | Op Code Address | 1 | 1 | Op Code | | | | 2 | Op Code Address + 1 | 1 | Ö | Offset (HI Byte) | | | | 1 | Op Code Address +2 | 1 | 0 | Offset (LO Byte) | | JSR | 7 | 1 | 1 . | 1 | Ö | Offset (LO Byte) | | | | 1 | | 1 | 0 | 1st Subroutine Op Code | | | | 1 | | Ó | ő | Return Address (LO Byte) | | * | | 7 | | 1 | | Return Address (HO Byte) | | JSR | 7 | 3<br>4<br>5<br>6 | 1 . | 1<br>1<br>1 | 0<br>0<br>0 | Offset (LO Byte) Offset (LO Byte) 1st Subroutine Op Code Return Address (LO Byte) | 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. TABLE 11 — SUMMARY OF CYCLE-BY-CYCLE OPERATION (CONTINUED) | Instructions | Cycles | Cycle# | Address Bus | RESET<br>Pin | R/W<br>Pin | LI<br>Pin | Data Bus | |-------------------------------|----------|----------|---------------------------------------|--------------|------------|-----------|--------------------------| | Other Functions | | | | | | | | | | | | \$1FFE | 0 | 1 | 0 | Irrelevant Data | | | | | \$1FFE | 0 | 1 | 0 | Irrelevant Data | | | | 1 | \$1FFE | 1 | 1 | 0 | Irrelevant Data | | Hardware RESET | 5 | 2 | \$1FFE | 1 | 1 | 0 | Irrelevant Data | | | | 3 | \$1FFE | 1 | 1 | 0 | Vector High | | | | 4 | \$1FFF | 1 | 1 | 0 | Vector Low | | | <b>_</b> | 5 | Reset Vector | 1 | 1 | 0 | Op Code | | | | 1 | \$1FFE | 1 | 1 | 0 | Irrelevant Data | | | | • | • | • | • | • | | | | | • | • | • | • | • . | | | Power on Reset | 1922 | • | <u>•</u> | • | • | • | • | | | 1022 | 1919 | \$1FFE | 1 | 1 | 0 | Irrelevant Data | | | | 1920 | \$1FFE | 1 | 1 | 0 | Vector High | | | | 1921 | \$1FFF | 1 1 | 1 | 0 | Vector Low | | | | 1922 | Reset Vector | 1 1 | | 0 | Op Code | | Instruction | Cycles | Cycles # | Address Bus | IRO.<br>Pin | R/₩<br>Pin | LI<br>Pin | Data Bus | | | | | Last Cycle of Previous<br>Instruction | 0 | × | 0 | х | | | | 1 | Next Op Code Address | 0 | 1 | 0 | Irrelevant Data | | | | 2 | Next Op Code Address | / x | 1 | 0 | Irrelevant Data | | <del></del> | | 3 | SP | X | 0 | 0 | Return Address (LO Byte) | | IRQ Interrupt | 10 | 4 | SP – 1 | × | 0 | 0 | Return Address (HI Byte) | | (Timer Vector \$1FF8, \$1FF9) | | 5 | SP – 2 | X | 0 | 0 | Contents Index Reg | | | | 6 | SP-3 | × | 0 | 0 | Contents Accumulator | | | | 7 | SP-4 | × | 0 | 0 | Contents CC Register | | | | 8 | \$1FFA | Х | 1 | 0 | Vector High | | | | 9 | \$1FFB | Х | 1 | 0 | Vector Low | | | L | 10 | TRO Vector | X | 1 | 0 | Int Routine First | #### **APPENDIX** # MC146805E2 INTERRUPT CLARIFICATION Under certain circumstances, the MC146805E2 (BP4XXXX and AW9XXXX) 8-bit Microprocessor Unit TRQ interrupt does not conform to the operation described in this Advanced Information Sheet. - 1. The level sensitive $\overline{\mbox{IRO}}$ mode, which is by far the most frequently used, is FULLY OPERATIONAL: thus, most MC146805E2 applications are unaffected. However, the edge triggered IRQ interrupt mode MIGHT NOT BE SERVICED under certain programming circumstances; therefore, it is recommended that the edge-triggered mode not be used. - 2. An interrupt-vector address CAN BE improperly generated in some circumstances. There is a possibility that when an external interrupt (IRQ) and timer interrupt occur during the WAIT mode (following wait instruction), address locations \$1FF2 and \$1FF3 are selected instead of vector locations \$1FF6 and \$1FF7. There are three specific examples listed below; two of these require no action and the third has a recommended solution. - a. Those not using the WAIT mode need not take any action. - b. If the WAIT mode is used without external interrupt (IRQ pin held high), no precautions are required. - c. When $\overline{\text{IRQ}}$ can be active (low) during the WAIT mode, the vector in locations \$1FF6 and \$1FF7 (the WAIT mode timer interrupt vector) should be duplicated in \$1FF2 and \$1FF3. In this way the circumstances that caused selection of the second vector do not disturb normal program execution. On future MC146805E2 parts, no special actions will be necessary. If you have questions, contact your Motorola distributor or Motorola sales office, or contact Motorola Microprocessor Applications Engineering in Austin, Texas. #### PACKAGE DIMENSIONS - OTES: 1. DIMENSION A: IS DATUM. 2. POSITIONAL TOLERANCE FOR LEADS: #### ⊕ 0.25 (0.010) ⊛ T A⊛ - 3. T IS SEATING PLANE - 4. DIMENSION "L" TO CENTER OF LEADS WHEN FORMED PARALLEL. - 5. DIMENSIONING AND TOLERANCING PER ANSI Y14.5, 1973. # L SUFFIX CERAMIC PACKAGE CASE 715-05 | | MILLIM | ETERS | INC | HES | |-----|--------|-------|-------|-------| | DIM | MIN | MAX | MIN | MAX | | A | 50.29 | | | 2.020 | | В | 14.63 | 15.49 | 0.576 | 0.610 | | Č | 3.05 | 4.32 | 0.120 | 0.170 | | 0 | 0.38 | 0.53 | 0.015 | 0.021 | | F | 0.76 | 1.40 | 0.030 | 0.055 | | G | 254 | BSC | 0.100 | BSC | | J | 0.20 | 0.33 | 0.008 | 0.013 | | K | 2.54 | 4.19 | 0.100 | 0.165 | | L | 14.99 | 15.65 | 0.590 | 0616 | | M | | 100 | - | 100 | | N | 1.02 | 1.52 | 0.040 | 0.060 | NOTES: - DIMENSION-A-IS DATUM. POSITIONAL TOLERANCE FOR LEADS: - ♦ 0.25 (0.010) W T A W - T IS SEATING PLANE - LT. IS SEATING PLANE. DIMENSION L TO CENTER OF LEADS WHEN FORMED PARALLEL. DIMENSION A AND B INCLUDES MENISCUS. # S SUFFIX CERDIP PACKAGE CASE 734-03 | MIN | MAX | MIN | MAX | | |-----------|-------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | 51.31 | 53.24 | 2.020 | 2.096 | | | 12.70 | 15.49 | 0.500 | 0.610 | | | 4.06 | 5.84 | 0.160 | 0.230 | | | 0.38 | 0.56 | 0.015 | 0.022 | | | 1.27 | 1.65 | 0.050 | 0.065 | | | 2.54 BSC | | 0.100 BSC | | | | 0.20 | 0.30 | 0.008 | 0.012 | | | 3.18 | 4.06 | 0.125 | 0.160 | | | 15.24 BSC | | 0.600 BSC | | | | 50 | 150 | 50 | 150 | | | 0.51 | 1.27 | 0.020 | 0.050 | | | | 51.31<br>12.70<br>4.06<br>0.38<br>1.27<br>2.54<br>0.20<br>3.18<br>15.24 | 51.31 53.24<br>12.70 15.49<br>4.06 5.84<br>0.38 0.56<br>1.27 1.65<br>2.54 BSC<br>0.20 0.30<br>3.18 4.06<br>15.24 BSC<br>5° 15° | 51.31 53.24 2.020<br>12.70 15.49 0.500<br>4.06 5.84 0.160<br>0.38 0.56 0.015<br>1.27 1.65 0.050<br>2.54 BSC 0.10<br>0.20 0.30 0.008<br>3.18 4.06 0.125<br>15.24 BSC 0.105<br>0.125 0.125 | | INCHES MILLIMETERS - NOTES: 1. POSITIONAL TOLERANCE OF LEADS (D), SHALL BE WITHIN 0.25 mm (0.010) AT MAXIMUM MATERIAL CONDITION, IN RELATION TO SEATING PLANE AND EACH OTHER. 2. DIMENSION L TO CENTER OF LEADS WHEN FORMED PARALLEL. 3. DIMENSION B DOES NOT INCLUDE MOLD FLASH. | • | | |---|-----------------| | 1 | | | į | | | ١ | P SUFFIX | | + | PLASTIC PACKAGE | | | CASE 711-01 | | | MILLIN | METERS | INCHES | | |-----|-----------|--------|-----------|-------| | DIM | MIN | MAX | MIN | MAX | | A | 51.69 | 52.45 | 2.035 | 2.065 | | В | 13.72 | 14.22 | 0.540 | 0.560 | | C | 3.94 | 5.08 | D.155 | 0.200 | | 0 | 0.36 | 0.56 | 0.014 | 0.022 | | F | 1.02 | 1.52 | 0.040 | 0.060 | | G | 2.54 BSC | | 0.100 BSC | | | Н | 1.65 | 2.16 | 0.065 | 0.085 | | J | 0.20 | 0.38 | 0.008 | 0.015 | | K | 2.92 | 3.43 | 0.115 | 0.135 | | ı | 15.24 BSC | | 0.600 BSC | | | M | 00 | 150 | Oo. | 150 | | N | 0.51 | 1.02 | 0.020 | 0.040 | See front page for chip carrier equivalent pin assignments. - NOTES: 1. DIMENSIONS A & R ARE DATUMS - 1. DIMENSIONS AS A RACE PAID TO BE STANDARD STA # **Z SUFFIX** CHIP CARRIER CASE 761-01 | | MILLIMETERS | | INCHES | | |-----|-------------|-------|-----------|-------| | DIM | MIN | MAX | MIN | MAX | | A | 11.94 | 12.57 | 0.470 | 0.495 | | В | 11.05 | 11.30 | 0.435 | 0.445 | | С | 1.60 | 2.08 | 0.063 | 0.082 | | D | 0.33 | 0.69 | 0.013 | 0.027 | | F | 1.07 | 1.47 | 0.042 | 0.058 | | G | 1,02 BSC | | 0.040 BSC | | | Н | 0.84 | 1.19 | 0.033 | 0.047 | | N | 1.27 | 1.79 | 0.050 | 0.070 | | R | 11.94 | 12.57 | 0.470 | 0.495 | ARECHINE DOCUMENT AND ROLL OF RESERVE DE LA PROPERTIE PORTIE DE LA PROPERTIE PORTIE **MOTOROLA** Semiconductor Products Inc.