3501 ED BLUESTEIN BLVD., AUSTIN, TEXAS 78721 # MC68701 # **Advance Information** # MC68701 MICROCOMPUTER UNIT (MCU) The MC68701 is an 8-bit single chip microcomputer unit (MCU) which significantly enhances the capabilities of the M6800 family of parts. It can be used in production systems to allow for easy firmware changes with minimum delay or it can be used to emulate the MC6801/03 for software development. It includes an upgraded M6800 microprocessor unit (MPU) with upward source and object code compatibility. Execution times of key instructions have been improved and several new instructions have been added including an unsigned multiply. The MCU can function as a monolithic microcomputer or can be expanded to a 64K byte address space. It is TTL compatible and requires one +5 volt power supply for nonprogramming operation. An additional Vpp power supply is needed for EPROM programming. On-chip resources include 2048 bytes of EPROM, 128 bytes of RAM, Serial Communications Interface (SCI), parallel I/O, and a three function Programmable Timer. A summary of MCU features includes: - Enhanced MC6800 Instruction Set - 8×8 Multiply Instruction - Serial Communications Interface (SCI) - Upward Source and Object Code Compatibility with the MC6800 - 16-Bit Three-Function Programmable Timer - Single-Chip or Expanded Operation to 64K Byte Address Space - Bus Compatibility with the M6800 Family - 2048 Bytes of UV Erasable, User Programmable ROM (EPROM) - 128 Bytes of RAM (64 Bytes Retainable on Powerdown) - 29 Parallel I/O and Two Handshake Control Lines - Internal Clock Generator with Divide-by-Four Output - −40 to 85°C Temperature Range # **GENERIC INFORMATION** | Package Type | Frequency (MHz) | Temperature | Generic Number | |--------------|-----------------|----------------|----------------| | Ceramic | 1.0 | 0°C to 70°C | MC68701L | | L Suffix | 1.0 | -40°C to 85°C | MC68701CL | | | 1.25 | 0°C to 70°C | MC68701L-1 | | | 1.25 | - 40°C to 85°C | MC68701CL-1 | | | 1.5 | 0°C to 70°C | MC68A701L | | | 2.0 | 0°C to 70°C | MC68B701L | # MOS (N-CHANNEL, SILICON-GATE, DEPLETION LOAD) # MICROCOMPUTER WITH EPROM # PIN ASSIGNMENT | ∨ss <b>[</b> | | 40 <b>I</b> E | |--------------|----|-------------------------------| | XTAL1 | 2 | 39 <b>I</b> SC1 | | EXTAL 2 | 3 | 38 3 SC2 | | NMI | 4 | 37 <b>P30</b> | | IRQ1 | 5 | 36 P31 | | RESET/VPP[ | 6 | 35 P32 | | ∨cc <b>[</b> | 7 | 34 <b>1</b> P33 | | P20 [ | 8 | 33 <b>7 P34</b> | | P21 | 9 | 32 <b>1</b> P35 | | P22 [ | 10 | 31 <b>P36</b> | | P23 [ | 11 | 30 <b>1</b> P37 | | P24 [ | 12 | 29 P40 | | P10 <b>[</b> | 13 | 28 P41 | | P11 | 14 | 27 <b>P42</b> | | P12[ | 15 | 26 P43 | | P13[ | 16 | 25 P44 | | P14[ | 17 | 24 P45 | | P15 <b>[</b> | 18 | 23 P46 | | P16 [ | 19 | 22 P47 | | P17 | 20 | 21 V <sub>CC</sub><br>Standby | | | | | #### MC68701 MICROCOMPUTER BLOCK DIAGRAM #### MAXIMUM RATINGS | Rating | Symbol | Value | Unit | |----------------------------------------------------|------------------|-----------------------------------------------------------|------| | Supply Voltage | Vcc | -0.3 to +7.0 | V | | Input Voltage | Vin | -0.3 to +7.0 | V | | Operating Temperature Range<br>MC68701<br>MC68701C | ТД | T <sub>L</sub> to T <sub>H</sub><br>0 to 70<br>– 40 to 85 | °C | | Storage Temperature Range | T <sub>stg</sub> | 0 to 85 | °C | #### THERMAL CHARACTERISTICS | Characteristic | Symbol | Value | Rating | | |--------------------|----------|-------|--------------|--| | Thermal Resistance | <b>a</b> | 50 | °C/W | | | Ceramic Package | θJA | 50 | C/ <b>VV</b> | | 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_{CC}$ . Reliability of operation is enhanced if unused inputs are tied to an appropriate logic voltage level (e.g., either $V_{SS}$ or $V_{CC}$ ). ## **POWER CONSIDERATIONS** The average chip-junction temperature, T<sub>J</sub>, in °C can be obtained from: $$T_{J} = T_{A} + (P_{D} \bullet \theta_{JA}) \tag{1}$$ Where: $T_A \equiv Ambient Temperature, °C$ $\theta_{JA} \equiv Package Thermal Resistance, Junction-to-Ambient, °C/W$ PD≡PINT+PPORT PINT≡ICC×VCC, Watts - Chip Internal Power PPORT≡Port Power Dissipation, Watts - User Determined An approximate relationship between PD and TJ (if PPORT is neglected) is: $$P_D = K \div (T_J + 273^{\circ}C)$$ (2) Solving equations 1 and 2 for K gives: $$K = P_{D} \bullet (T_{A} + 273 \circ C) + \theta_{JA} \bullet P_{D}^{2}$$ (3) Where K is a constant pertaining to the particular part. K can be determined from equation 3 by measuring $P_D$ (at equilibrium) for a known $T_A$ . Using this value of K the values of $P_D$ and $T_J$ can be obtained by solving equations (1) and (2) iteratively for any value of $T_A$ . CONTROL TIMING ( $V_{CC}$ =5.0 V $\pm$ 5%, $V_{SS}$ =0, $T_A$ =0 to 70°C) | Characteristic | Symbol | MC68701 | | MC68701-1 | | MC68A701 | | MC68B701 | | I I = ia | |----------------------------------|-----------------|---------|-----|-----------|------|----------|-----|----------|-----|----------| | Characteristic | | Min | Max | Min | Max | Min | Max | Min | Max | Unit | | Frequency of Operation | fo | 0.5 | 1.0 | 0.5 | 1.25 | 0.5 | 1.5 | 0.5 | 2.0 | MHz | | Crystal Frequency | fXTAL | 2.0 | 4.0 | 2.0 | 5.0 | 2.0 | 6.0 | 2.0 | 8.0 | MHz | | External Oscillator Frequency | 4f <sub>o</sub> | 2.0 | 4.0 | 2.0 | 5.0 | 2.0 | 6.0 | 2.0 | 8.0 | MHz | | Crystal Oscillator Start Up Time | t <sub>rc</sub> | - | 100 | _ | 100 | _ | 100 | _ | 100 | ms | | Processor Control Setup Time | tPCS | 200 | _ | 170 | _ | 140 | _ | 110 | _ | ns | # DC ELECTRICAL CHARACTERISTICS ( $V_{CC} = 5.0 \text{ Vdc } \pm 5\%$ , $V_{SS} = 0$ , $T_A = T_L$ to $T_H$ , unless otherwise noted) | | | | | MC68701 | | | | | | |--------------------------------------------------------------------------------------------------------------|----------------------------------------|----------------------------------------------|----------------------------------------------|-----------------|------------------------------------------------|----------------------------------------------|-----------------|----------------------------------------------|------| | Characteristic | | Symbol | Min | Тур | Max | Min | Тур | Max | Unit | | Input High Voltage | V <sub>IH</sub> | V <sub>SS</sub> +4.0<br>V <sub>SS</sub> +2.0 | _ | V <sub>CC</sub> | V <sub>SS</sub> + 4.0<br>V <sub>SS</sub> + 2.2 | _ | V <sub>CC</sub> | V | | | Input Low Voltage | RESET Other Inputs* | VIL | V <sub>SS</sub> -0.3<br>V <sub>SS</sub> -0.3 | _ | V <sub>SS</sub> +0.4<br>V <sub>SS</sub> +0.8 | V <sub>SS</sub> -0.3<br>V <sub>SS</sub> -0.3 | | V <sub>SS</sub> +0.4<br>V <sub>SS</sub> +0.8 | V | | Input Current, See Note<br>(V <sub>in</sub> = 0 to 2.4 V) | Port 4<br>SCI | lin | _ | _ | 0.6<br>1.0 | _ | _ | 1.0<br>1.6 | mA | | Input Current<br>(V <sub>in</sub> = 0 to 5.25 V) | NMI, IRQ1 | l <sub>in</sub> | _ | 1.5 | 2.5 | _ | 1.5 | 5 | μΑ | | Input Current<br>(V <sub>in</sub> = 0 to 0.4 V)<br>(V <sub>in</sub> = 4.0 V to V <sub>CC</sub> ) | RESET/V <sub>PP</sub> | l <sub>in</sub> | _ | - 2.0<br>- | _<br>8.0 | <u>-</u><br>- | -2.0<br>- | _<br>8.0 | mA | | Hi-Z (Off State) Input Current<br>(V <sub>in</sub> =0.5 to 2.4 V) | Ports 1, 2, and 3 | I <sub>TSI</sub> | _ | 2 | 10 | _ | 2 | 20 | μΑ | | Output High Voltage ( $I_{Load} = -65 \mu A$ , $V_{CC} = Min$ ) ( $I_{Load} = -100 \mu A$ , $V_{CC} = Min$ ) | Port 4, SC1, SC2<br>Other Outputs | Vон | V <sub>SS</sub> +2.4<br>V <sub>SS</sub> +2.4 | _ | _<br>_ | V <sub>SS</sub> +2.4<br>V <sub>SS</sub> +2.4 | | <u>-</u> | V | | Output Low Voltage<br>ILoad = 2.0 mA, V <sub>CC</sub> = Min) | All Outputs | VoL | _ | _ | V <sub>SS</sub> +0.5 | | _ | V <sub>SS</sub> +0.6 | V | | Darlington Drive Current $(V_0 = 1.5 \text{ V})$ | Port 1 | Іон | 1.0 | 2.5 | 10.0 | 1.0 | 2.5 | 10.0 | mA | | Internal Power Dissipation (Measured at $T_A = T_L$ in Steady- | State Operation) | PINT | _ | _ | 1500 | _ | _ | 1500 | mW | | Input Capacitance<br>$(V_{in} = 0, T_A = 25$ °C, $f_0 = 1 \text{ MHz})$ | Port 3,<br>Port 4, SCI<br>Other Inputs | C <sub>in</sub> | - | _ | 12.5<br>10.0 | _ | _ | 12.5<br>10.0 | pF | | V <sub>CC</sub> Standby | Powerdown<br>Powerup | V <sub>SBB</sub><br>V <sub>SB</sub> | 4.0<br>4.75 | | 5.25<br>5.25 | 4.0<br>4.75 | _ | 5.25<br>5.25 | V | | Standby Current | Powerdown | ISBB | _ | _ | 6.0 | _ | _ | 8.0 | mΑ | | Programming Time Per Byte ( $T_A =$ | 25°C) | tpp | 25 | _ | 50 | 25 | _ | 50 | ms | | Programming Voltage (T <sub>A</sub> = 25°C) | | Vpp | 20.0 | 21.0 | 22.0 | 20.0 | 21.0 | 22.0 | V | | Programming Current (VRESET = Vpp, $T_A = 25$ °C) | | lpp | _ | 30 | 50 | _ | 30 | 50 | mA | <sup>\*</sup>Except mode programming levels; see Figure 15. NOTE: $\overline{\text{RESET}/\text{Vpp}}$ $\text{l}_{\text{in}}$ differs from MC6801 and MC6803 values. # PERIPHERAL PORT TIMING (Refer to Figures 3-6) | Characteristics | Symbol | MC6 | 8701 | MC68 | 3701-1 | MC68A701 | | MC68B701 | | Unit | |-------------------------------------------------------------------------|-------------------|-----|------|------|--------|----------|-----|----------|-----|------| | Characteristics | Syllibol | Min | Max | Min | Max | Min | Max | Min | Max | Oill | | Peripheral Data Setup Time | <sup>t</sup> PDSU | 200 | _ | 200 | _ | 150 | - | 100 | _ | ns. | | Peripheral Data Hold Time | tPDH | 200 | _ | 200 | _ | 150 | _ | 100 | _ | ns | | Delay Time, Enable Positive Transition to OS3 Negative Transition | tOSD1 | - | 350 | - | 350 | _ | 300 | - | 250 | ns | | Delay Time, Enable Positive Transition to OS3 Positive Transition | tOSD2 | _ | 350 | _ | 350 | _ | 300 | _ | 250 | ns | | Delay Time, Enable Negative Transition to Peripheral Data Valid | tPWD | _ | 350 | - | 350 | _ | 300 | - | 250 | ns | | Delay Time, Enable Negative Transition to<br>Peripheral CMOS Data Valid | tCMOS | _ | 2.0 | _ | 2.0 | _ | 2.0 | - | 2.0 | μs | | Input Strobe Pulse Width | tPWIS | 200 | _ | 200 | _ | 150 | _ | 100 | _ | ns | | Input Data Hold Time | tIH | 50 | _ | 50 | - | 40 | - | 30 | _ | ns | | Input Data Setup Time | tıs | 20 | _ | 20 | _ | 20 | _ | 20 | _ | ns | #### FIGURE 1 — DATA SETUP AND HOLD TIMES (MPU READ) \*Port 3 Non-Latched Operation (LATCHE ENABLE = 0) FIGURE 3 — PORT 3 OUTPUT STROBE TIMING (SINGLE-CHIP MODE) \*Access matches Output Strobe Select (OSS=0, a read; OSS = 1, a write) # FIGURE 2 — DATA SETUP AND HOLD TIMES (MPU WRITE) NOTES: - 1. 10 k Pullup resistor required for Port 2 to reach 0.7 V<sub>CC</sub> - 2. Not applicable to P21 - 3. Port 4 cannot be pulled above VCC FIGURE 4 — PORT 3 LATCH TIMING (SINGLE-CHIP MODE) NOTE: Timing measurements are referenced to a low voltage of 0.8 volts and a high voltage of 2.0 volts unless otherwise noted. FIGURE 5 - CMOS LOAD # FIGURE 6 - TIMING TEST LOAD PORTS 1, 2, 3, 4 C=90 pF for P30-P37, P40-P47, E, SC1, SC2 = 30 pF for P10-P17, P20-P24 $R = 37 \text{ k}\Omega$ for P40-P47, SC1, SC2, = 24 k $\Omega$ for P10-P17, P20-P24, P30-P37, E BUS TIMING (See Notes 2 and 3) | ident | Characteristic | Symbol | MCE | 8701 | MC68 | 3701-1 | MC68A701 | | MC68B701 | | Unit | |--------|--------------------------------------------|---------------------------------|------|------|--------------------|--------|----------|------|----------|------|------| | Number | Characteristic | Symbol | Min | Max | Min | Max | Min | Max | Min | Max | Unit | | 1 | Cycle Time | t <sub>cyc</sub> | 1.0 | 2.0 | 0.8 | 2.0 | _ | 2.0 | 0.5 | 2.0 | μS | | 2 | Pulse Width, E Low | PWEL | 430 | 1000 | 360 | 1000 | 300 | 1000 | 210 | 1000 | ns | | 3 | Pulse Width, E High | PWEH | 450 | 1000 | 360 | 1000 | 300 | 1000 | 220 | 1000 | ns | | 4 | Clock Rise and Fall Time | t <sub>r</sub> , t <sub>f</sub> | _ | 25 | _ | 25 | _ | 25 | _ | 20 | ns | | 9 | Address Hold Time | t <sub>A</sub> H | 20 | _ | 20 | _ | 20 | _ | 10 | _ | ns | | 12 | Non-Muxed Address Valid Time to E* | tAV | 200 | _ | 150 | - | 115 | _ | 70 | _ | ns | | 17 | Read Data Setup Time | tDSR | 80 | _ | 70 | - | 60 | _ | 40 | _ | ns | | 18 | Read Data Hold Time | tDHR | 10 | _ | 10 | - | 10 | _ | 10 | - | ns | | 19 | Write Data Delay Time | tDDW | - | 225 | _ | 200 | _ | 170 | - | 120 | ns | | 21 | Write Data Hold Time | tDHW | 20 | _ | 20 | _ | 20 | - | 10 | _ | ns | | 22 | Multiplexed Address Valid Time to E Rise* | tAVM | 200 | _ | 150 | _ | 115 | _ | 80 | | ns | | 24 | Multiplexed Address Valid Time to AS Fall* | †ASL | 60 | _ | 50 | - | 40 | _ | 20 | _ | ns | | 25 | Multiplexed Address Hold time | †AHL | 20 | - | 20 | _ | 20 | _ | 10 | _ | ns | | 26 | Delay Time, E to AS Rise* | tASD | 90** | _ | 70* <del>*</del> * | - | 60** | _ | 45*** | _ | ns | | 27 | Pulse Width, AS High* | PWASH | 220 | _ | 170 | _ | 140 | _ | 110 | _ | ns | | 28 | Delay Time, AS to E Rise* | tASED | 90 | _ | 70 | _ | 60 | _ | 45 | _ | ns | | 29 | Usable Access Time* | tACC | 595 | - | 465 | _ | 380 | _ | 270 | _ | ns | <sup>\*</sup> At specified cycle time. <sup>\*\*</sup>t<sub>ASD</sub> parameters listed assume external TTL clock drive with 50% ±5% duty cycle. Devices driven by an external TTL clock with 50% ±1% duty cycle or which use a crystal have the following t<sub>ASD</sub> specification: 100 nanoseconds minimum (1.0 MHz devices), 80 nanoseconds minimum (1.25 MHz devices), 65 nanoseconds minimum (1.5 MHz devices), 50 nanoseconds minimum (2.0 MHz devices). #### NOTES: - 1. Voltage levels shown are VL $\leq$ 0.5 V, VH $\geq$ 2.4 V, unless otherwise specified. - 2. Measurement points shown are 0.8 V and 2.0 V, unless otherwise specified. - 3. Usable access time is computed by 12+3-17+4. - 4. Memory devices should be enabled only during E high to avoid port 3 bus contention. # **INTRODUCTION** The MC68701 is an 8-bit monolithic microcomputer which can be configured to function in a wide variety of applications. The facility which provides this extraordinary flexibility is its ability to be hardware programmed into eight different operating modes. The operating mode controls the configuration of 18 of the 40 MCU pins, available on-chip resources, memory map, location (internal or external) of interrupt vectors, and type of external bus. The configuration of the remaining 22 pins is not dependent on the operating mode Twenty-nine pins are organized as three 8-bit ports and one 5-bit port. Each port consists of at least a Data Register and a write-only Data Direction Register. The Data Direction Register is used to define whether corresponding bits in the Data Register are configured as an input (clear) or output (set). The term "port," by itself, refers to all of the hardware associated with the port. When the port is used as a "data port" or "I/O port," it is controlled by the port Data Direction Register and the programmer has direct access to the port pins using the port Data Register. Port pins are labled as Pij where i identifies one of four ports and j indicates the particular bit. The Microprocessor Unit (MPU) is an enhanced MC6800 MPU with additional capabilities and greater throughput. It is upward source and object code compatible with the MC6800. The programming model is depicted in Figure 8 where Accumulator D is a concatenation of Accumulators A and B. A list of new operations added to the M6800 instruction set are shown in Table 1. The basic difference between the MC6801 and the MC68701 is that the MC6801 has an onboard ROM while the MC68701 has an onboard EPROM. The MC68701 is pin and code compatible with the MC6801 and can be used to emulate the MC6801, allowing easy software development using the onboard EPROM. Software developed using the MC68701 can then be masked into the MC6801 ROM. In order to support the onboard EPROM, the MC68701 differs from the MC6801 as follows: - (1) Mode 0 in the MC6801 is a test mode only, while in the MC68701 Mode 0 is also used to program the onboard EPROM and has interrupt vectors at \$BFF0-\$BFFF rather than \$FFF0-\$FFFF. - (2) The MC68701 RAM/EPROM Control Register has two bits used to control the EPROM in Mode 0 that are not defined in the MC6801 RAM Control Register. - (3) The RESET/Vpp pin in the MC68701 is dual purpose, used to supply EPROM power as well as to reset the device; while in the MC6801 the pin is called RESET and is used only to reset the device. FIGURE 8 — MC68701/6801/6803 PROGRAMMING MODEL | | TABLE 1 — NEW INSTRUCTIONS | |--------------|---------------------------------------------------------------------------------------------------------------------------------| | Instruction | Description | | ABX | Unsigned addition of Accumulator B to Index Register | | ADDD | Adds (without carry) the double accumulator to memory and leaves the sum in the double accumulator | | ASLD or LSLD | Shifts the double accumulator left (towards MSB) one bit; the LSB is cleared and the MSB is shifted into the C-bit | | BHS | Branch if Higher or Same; unsigned conditional branch (same as BCC) | | BLO | Branch if Lower; Unsigned conditional branch (same as BCS) | | BRN | Branch Never | | JSR | Additional addressing mode: direct | | LDD | Loads double accumulator from memory | | LSL | Shifts memory or accumulator left (towards MSB) one bit; the LSB is cleared and the MSB is shifted into the C-bit (same as ASL) | | LSRD | Shifts the double accumulator right (towards LSB) one bit; the MSB is cleared and the LSB is shifted into the C-bit | | MUL | Unsigned multiply; multiplies the two accumulators and leaves the product in the double accumulator | | PSHX | Pushes the Index Register to stack | | PULX | Pulls the Index Register from stack | | STD | Stores the double accumulator to memory | | SUBD | Subtracts memory from the double accumulator and leaves the difference in the double accumulator | | CPX | Internal processing modified to permit its use with any conditional branch instruction | # **OPERATING MODES** The MCU provides eight different operating modes which are selectable by hardware programming and referred to as Mode 0 through Mode 7. The operating mode controls the memory map, configuration of Port 3, Port 4, SC1, SC2, and the physical location of interrupt vectors. #### **FUNDAMENTAL MODES** The eight MCU modes can be grouped into three fundamental modes which refer to the type of bus it supports: Single Chip, Expanded Non-Multiplexed, and Expanded Multiplexed. Modes 4 and 7 are single chip modes. Mode 5 is the expanded non-multiplexed mode, and the remaining modes are expanded multiplexed modes. Table 2 summarizes the characteristics of the operating modes. #### Single-Chip Modes (4, 7) In the Single-Chip Mode, the four MCU ports are configured as parallel input/output data ports, as shown in Figure 9. The MCU functions as a monolithic microcomputer in these two modes without external address or data buses. A maximum of 29 I/O lines and two Port 3 control lines are provided. Peripherals or another MCU can be interfaced to Port 3 in a loosely coupled dual processor configuration, as shown in Figure 10. In Single-Chip Test Mode (4), the RAM responds to \$XX80 through \$XXFF and the EPROM is removed from the internal address map. A test program must first be loaded into the RAM using modes 0, 1, 2, or 6. If the MCU is reset and then programmed into Mode 4, execution will begin at \$XXFE:XXFF. Mode 5 can be irreversibly entered from Mode 4 without asserting RESET by setting bit 5 of the Port 2 Data Register. This mode is used primarily to test Ports 3 and 4 in the Single-Chip and Non-Multiplexed Modes. #### TABLE 2 — SUMMARY OF MC68701 OPERATING MODES #### Common to all Modes: Reserved Register Area Port 1 Port 2 Programmable Timer Serial Communications Interface # Single Chip Mode 7 128 bytes of RAM; 2048 bytes of EPROM Port 3 is a parallel I/O port with two control lines Port 4 is a parallel I/O port SC1 is Input Strobe 3 (IS3) SC2 is Output Strobe 3 (OS3) # Expanded Non-Multiplexed Mode 5 128 bytes of RAM; 2048 bytes of EPROM 256 bytes of external memory space Port 3 is an 8-bit data bus Port 4 is an input port/address bus SC1 is Input/Output Select (IOS) SC2 is Read/Write (R/W) # Expanded Multiplexed Modes 1, 2, 3, 6 Four memory space options (64K address space): - (1) No internal RAM or EPROM (Mode 3) - (2) Internal RAM, no EPROM (Mode 2) - (3) Internal RAM and EPROM (Mode 1) - (4) Internal RAM, EPROM with partial address bus (Mode 6) Port 3 is a multiplexed address/data bus Port 4 is an address bus (inputs/address in Mode 6) SC1 is Address Strobe (AS) SC2 is Read/Write (R/W) # Test Mode 4 - (1) May be changed to Mode 5 without going through Reset - (2) May be used to test Ports 3 and 4 as I/O ports # Expanded Multiplexed Mode 0 - (1) Internal RAM and EPROM - (2) External interrupt vectors located at \$BFF0-\$BFFF - (3) Used to program EPROM #### Expanded Non-Multiplexed Mode (5) A modest amount of external memory space is provided in the Expanded Non-Multiplexed Mode while significant on-chip resources are retained. Port 3 functions as an 8-bit bidirectional data bus and Port 4 is configured initially as an input data port. Any combination of the eight least-significant address lines may be obtained by writing to the Port 4 Data Direction Register. Stated alternatively, any combination of A0 to A7 may be provided while retaining the remainder as input data lines. Internal pullup resistors are intended to pull the Port 4 lines high until the port is configured. Figure 11 illustrates a typical system configuration in the Expanded Non-Multiplexed Mode. The MCU interfaces directly with M6800 family parts and can access 256 bytes of external address space at \$100 through \$1FF. IOS provides an address decode of external memory (\$100-\$1FF) and can be used as a memory page select or chip select line. # Expanded-Multiplexed Modes (0, 1, 2, 3, 6) In the Expanded-Multiplexed Modes, the MCU has the ability to access a 64K byte memory space. Port 3 functions as a time multiplexed address/data bus with address valid on the negative edge of Address Strobe (AS), and data valid while E is high. In Modes 0 to 3, Port 4 provides address lines A8 to A15. In Mode 6, however, Port 4 is initially configured at RESET as an input data port. The Port 4 Data Direction Register can then be changed to provide any combination of address lines, A8 to A15. Stated alternatively, any subset of A8 to A15 can be provided while retaining the remaining Port 4 lines as input data lines. Internal pullup resistors pull the Port 4 lines high until software configures the port. Figure 12 depicts a typical configuration for the Expanded-Multiplexed Modes. Address Strobe can be used to control a transparent D-type latch to capture addresses A0 to A7, as shown in Figure 13. This allows Port 3 to function as a Data Bus when E is high. In Mode 0, the internal and external data buses are connected; there must therefore be no memory map overlap in order to avoid potential bus conflicts. Mode 0 is used to program the onboard EPROM. All interrupt vectors are external in this mode and are located at \$BFFO-\$BFFF. #### PROGRAMMING THE MODE The operating mode is determined at RESET by the levels asserted on P22, P21, and P20. These levels are latched into PC2, PC1, and PC0 of the program control register on the positive edge of RESET. The operating mode may be read from the Port 2 Data Register as shown below, and programming levels and timing must be met as shown in Figure 14. A brief outline of the operating modes is shown in Table 3. #### **PORT 2 DATA REGISTER** | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |-----|-----|-----|-----|-----|-----|-----|-----|--------| | PC2 | PC1 | PC0 | P24 | P23 | P22 | P21 | P20 | \$0003 | Circuitry to provide the programming levels is dependent primarily on the normal system usage of the three pins. If configured as outputs, the circuit shown in Figure 15 may be used; otherwise, three-state buffers can be used to provide isolation while programming the mode. #### **MEMORY MAPS** The MCU can provide up to 64K byte address space depending on the operating mode. A memory map for each operating mode is shown in Figure 16. The first 32 locations of each map are reserved for the MCU internal registers as shown in Table 4, with exceptions as indicated. #### TABLE 3 - MODE SELECTION SUMMARY | Mode | P22<br>PC2 | P21<br>PC1 | P20<br>PC0 | EPROM | RAM | Interrupt<br>Vectors | Bus<br>Mode | Operating<br>Mode | |------|------------|------------|------------|------------------|------|----------------------|------------------------|--------------------------------| | 7 | н | Н | Н | 1 | 1 | 1 | ı | Single Chip | | 6 | н | Н | L | ı | ı | 1 | MUX <sup>(5, 6)</sup> | Multiplexed/Partial Decode | | 5 | Н | L | Н | I | ı | ı | NMUX <sup>(5, 6)</sup> | Non-Multiplexed/Partial Decode | | 4 | Н | L | L | l <sup>(2)</sup> | J(1) | 1 | 1 | Single Chip Test | | 3 | L | Н | Н | E | Е | E | MUX <sup>(4)</sup> | Multiplexed/No RAM or EPROM | | 2 | L | Н | L | E | 1 | E | MUX <sup>(4)</sup> | Multiplexed/RAM | | 1 | L | L | Н | 1 | I | E | MUX <sup>(4)</sup> | Multiplexed/RAM and EPROM | | 0 | L | L | L | - | ı | l(3) | MUX <sup>(4)</sup> | Multiplexed/Programming | #### Legend: I — Internal E — External MUX — Multiplexed NMUX — Non-Multiplexed L — Logic "0" H — Logic "1" #### Notes: - (1) Internal RAM is addressed at \$XX80 - (2) Internal EPROM is disabled - (3) Interrupt vectors located at \$BFF0-\$BFFF - (4) Addresses associated with Ports 3 and 4 are considered external in Modes 0, 1, 2, and 3 - (5) Addresses associated with Port 3 are considered external in Modes 5 and 6 - (6) Port 4 default is user data input; address output is optional by writing to Port 4 Data Direction Register FIGURE 12 - EXPANDED MULTIPLEXED CONFIGURATION Vcc **→** E XTAL1 MMI EXTAL2 VCC Standby RESET MC68701 Port 3 8 Lines 8 I/O Lines Multiplexed Data/Address -R∕W Port 2 Port 4 5 1/0 Lines 8 Lines Serial I/O Address Bus 16-Bit Timer ٧ss Vcc XTAL1 Port 3 Data Bus (D0-D7) EXTAL2 Latch VCC Standby Port 4 RESET Address Bus NMI MC68701 16 (A0-A15) R/W IRQ1 ➤ R/W Port 1 8 I/C Port 2 51/0 SCI Timer √ss ROM PIA RAM NOTE: To avoid data bus (Port 3) contention in the expanded multiplexed modes, memory devices should be enabled only during E high time. #### FIGURE 14 - MODE PROGRAMMING TIMING #### MODE PROGRAMMING (Refer to Figure 14) | Characteristic | Symbol | Min | Тур | Max | Unit | |-------------------------------------|------------------|-----|-------|-----|----------| | Mode Programming Input Voltage Low | VMPL | _ | T - 1 | 1.8 | V | | Mode Programming Input Voltage High | VMPH | 4.0 | T - 1 | | V | | Mode Programming Diode Differential | VMPDD | 0.6 | T - T | _ | V | | RESET Low Pulse Width | PWRSTL | 3.0 | _ | | E-Cycles | | Mode Programming Set-Up Time | tMPS | 2.0 | - | | E-Cycles | | Mode Programming Hold Time | | | | | | | RESET Rise Time≥1 μs | <sup>t</sup> MPH | 0 | - | _ | ns | | RESET Rise Time<1 μs | | 100 | | _ | | FIGURE 15 - TYPICAL MODE PROGRAMMING CIRCUIT # Notes: - 1. Mode 0 as shown (switches closed). - 2. R1 = 10k ohms (typical). - 3. The RESET time constant is equal to RC where R is the equivalent parallel resistance of R2 and the number of resistors (R1) placed in the circuit by closed mode control switches. - D = 1N914, 1N4001 (typical). - 5. If $V = V_{CC}$ , then R2 = 50 ohms (typical) to meet V<sub>IH</sub> for the RESET/VPP pin. $V = V_{CC}$ is also compatible with MC6801. The - RESET time constant in this case is approximately R2\*C. 6. Switch S1 allows selection of normal (RESET) or programming (Vpp) as the input to the RESET/Vpp pin. During switching, the input level is held at a value determined by a diode (D), resistor (R2) and input voltage (V). - 7. While S1 is in the "Program" position, RESET should not be asserted. - 8. From powerup, RESET must be held low for at least $t_{RC}$ . The capacitor, C, is shown for conceptual purposes only and is on the order of 1000 $\mu$ F for the circuit shown. Typically, a buffer with an RC input will be used to drive RESET, eliminating the need for the larger capacitor. - 9. Diode Vf should not exceed VMPDD min. FIGURE 16 — MC68701 MEMORY MAPS (CONTINUED) # FIGURE 16 - MC68701 MEMORY MAPS (CONCLUDED) # TABLE 4 - INTERNAL REGISTER AREA | Register | Address | |-----------------------------------------------------------------------------------------------------------------------|----------------------------| | Port 1 Data Direction Register*** Port 2 Data Direction Register*** Port 1 Data Register Port 2 Data Register | 00<br>01<br>02<br>03 | | Port 3 Data Direction Register*** Port 4 Data Direction Register*** Port 3 Data Register Port 4 Data Register | 04*<br>05**<br>06*<br>07** | | Timer Control and Status Register<br>Counter (High Byte)<br>Counter (Low Byte)<br>Output Compare Register (High Byte) | 08<br>09<br>0A<br>0B | | Register | Address | |----------------------------------------------|-------------| | Output Compare Register (Low Byte) | oc | | Input Capture Register (High Byte) | OD | | Input Capture Register (Low Byte) | 0E | | Port 3 Control and Status Register | 0F* | | Rate and Mode Control Register | 10 | | Transmit/Receive Control and Status Register | 11<br>12 | | Receive Data Register | 13 | | Transmit Data Register | 13 | | RAM/EPROM Control Register<br>Reserved | 14<br>15-1F | | | | - \*External addresses in Modes 0, 1, 2, 3, 5, 6; cannot be accessed in Mode 5 (No IOS) - \*\*External addresses in Modes 0, 1, 2, 3 - \* \* \* 1 = output, 0 = Input #### MC68701 INTERRUPTS The MCU supports two types of interrupt requests: maskable and non-maskable. A Non-Maskable Interrupt ( $\overline{\text{NMI}}$ ) is always recognized and acted upon at the completion of the current instruction. Maskable interrupts are controlled by the Condition Code Register's I-bit and by individual enable bits. The I-bit controls all maskable interrupts. Of the maskable interrupts, there are two types: $\overline{\text{IRQ1}}$ and $\overline{\text{IRQ2}}$ . The Programmable Timer and Serial Communications Interface use an internal $\overline{\text{IRQ2}}$ interrupt line. External devices (and $\overline{\text{IS3}}$ ) use $\overline{\text{IRQ1}}$ . An $\overline{\text{IRQ1}}$ interrupt is serviced before $\overline{\text{IRQ2}}$ if both are pending. All IRQ2 interrupts use hardware prioritized vectors. The single SCI interrupt and three timer interrupts are serviced in a prioritized order and each is vectored to a separate location. All MCU interrupt vector locations are shown in Table 5. | TABLE 5 — MCU INTERRUPT VEC | |-----------------------------| |-----------------------------| | Mod | de 0 | Modes 1-7 | | | |------|------|-----------|------|--------------------------| | MSB | LSB | MSB | LSB | Interrupt | | BFFE | BFFF | FFFE | FFFF | RESET | | BFFC | BFFD | FFFC | FFFD | NMI | | BFFA | BFFB | FFFA | FFFB | Software Interrupt (SWI) | | BFF8 | BFF9 | FFF8 | FFF9 | IRQ1 (or IS3) | | BFF6 | BFF7 | FFF6 | FFF7 | ICF (Input Capture) * | | BFF4 | BFF5 | FFF4 | FFF5 | OCF (Output Compare) * | | BFF2 | BFF3 | FFF2 | FFF3 | TOF (Timer Overflow)* | | BFF0 | BFF1 | FFF0 | FFF1 | SCI(RDRF+ORFE+TDRE)* | <sup>\*</sup>IRQ2 Interrupt The Interrupt flowchart is depicted in Figure 17 and is common to every MCU interrupt excluding reset. During interrupt servicing the Program Counter, Index Register, A Accumulator, B Accumulator, and Condition Code Register are pushed to the stack. The I-bit is set to inhibit maskable interrupts and a vector is fetched corresponding to the current highest priority interrupt. The vector is transferred to the Program Counter and instruction execution is resumed. Interrupt and RESET timing are illustrated in Figures 18 and 19. # **FUNCTIONAL PIN DESCRIPTIONS** # VCC AND VSS VCC and VSS provide power to a large portion of the MCU. The power supply should provide +5 volts ( $\pm5\%$ ) to VCC, and VSS should be tied to ground. Total power dissipation (including VCC Standby), will not exceed PD milliwatts. # VCC STANDBY VCC Standby provides power to the standby portion (\$80 through \$BF) of the RAM and the STBY PWR and RAME bits of the RAM Control Register. Voltage requirements depend on whether the MCU is in a powerup or powerdown state. In the powerup state, the power supply should provide +5 volts (±5%) and must reach VSB volts before RESET reaches 4.0 volts. During powerdown, VCC Standby must remain above VSBB (min) to sustain the standby RAM and STBY PWR bit. While in powerdown operation, the standby current will not exceed ISBB. It is typical to power both VCC and VCC Standby from the same source during normal operation. A diode must be used between them to prevent supplying power to VCC during powerdown operation. VCC Standby should be tied to ground in Mode 3. #### XTAL1 AND EXTAL2 These two input pins interface either a crystal or TTL compatible clock to the MCU internal clock generator. Divide-by-four circuitry is included which allows use of the inexpensive 3.58 MHz or 4.4336 MHz Color Burst TV crystals. A 20 pF capacitor should be tied from each crystal pin to ground to ensure reliable startup and operation. Alternatively, EXTAL2 may be driven by an external TTL compatible clock at $4f_{\rm O}$ with a duty cycle of 50% ( $\pm$ 5%) with XTAL1 connected to ground. The internal oscillator is designed to interface with an AT-cut quartz crystal resonator operated in parallel resonance mode in the frequency range specified for $f_{XTAL}$ . The crystal should be mounted as close as possible to the input pins to minimize output distortion and startup stabilization time.\*\* The MCU is compatible with most commercially available crystals. Nominal crystal parameters are shown in Figure 20. #### RESET/VPP This input is used to reset the MCU internal state and provide an orderly startup procedure. During powerup, RESET must be held below 0.4 volts: (1) at least tRC after VCC reaches 4.75 volts in order to provide sufficient time for the clock generator to stabilize, and (2) until VCC Standby reaches VSB volts. RESET must be held low at least three E-cycles if asserted during powerup operation. This pin is also used to supply Vpp in Mode 0 for programming the EPROM, and supplies operating power to the EPROM during powerup operation. #### E (ENABLE) This is an output clock used primarily for bus synchronization. It is TTL compatible and is the slightly skewed divide-by-four result of the MCU input clock frequency. It will drive one Schottky TTL load and 90 pF, and all data given in cycles is referenced to this clock unless otherwise noted. #### NMI (NON-MASKABLE INTERRUPT) An $\overline{\text{NMI}}$ negative edge requests an MCU interrupt sequence, but the current instruction will be completed before it responds to the request. The MCU will then begin an interrupt sequence. Finally, a vector is fetched from \$FFFC and \$FFFD (or \$BFFC and \$BFFD in Mode 0), transferred to the Program Counter and instruction execution is resumed. $\overline{\text{NMI}}$ typically requires a 3.3 k $\Omega$ (nominal) resistor to VCC. There is no internal $\overline{\text{NMI}}$ pullup resistor. $\overline{\text{NMI}}$ must be held low for at least one E-cycle to be recognized under all conditions. # **IRQ1** (MASKABLE INTERRUPT REQUEST 1) IRQ1 is a level-sensitive input which can be used to request an interrupt sequence. The MPU will complete the current instruction before it responds to the request. If the inter- \*\*Devices made with masks subsequent to T7A and CB4 incorporate an advanced clock with improved startup characteritics. rupt mask bit (I-bit) in the Condition Code Register is clear, the MCU will begin an interrupt sequence. A vector is fetched from \$FFF8 and \$FFF9 (or \$BFF8 and \$BFF9 in Mode 0), transferred to the Program Counter, and instruction execution is resumed. $\overline{IRQ1}$ typically requires an external 3.3 k $\Omega$ (nominal) resistor to VCC for wire-OR applications. $\overline{IRQ1}$ has no internal pullup resistor. #### SC1 AND SC2 (STROBE CONTROL 1 AND 2) The function of SC1 and SC2 depends on the operating mode. SC1 is configured as an output in all modes except single chip mode, whereas SC2 is always an output. SC1 and SC2 can drive one Schottky load and 90 pF. # SC1 and SC2 In Single Chip Mode In Single Chip Mode, SC1 and SC2 are configured as an input and output, respectively, and both function as Port 3 control lines. SC1 functions as $\overline{\text{IS3}}$ and can be used to indicate that Port 3 input data is ready or output data has been accepted. Three options associated with $\overline{\text{IS3}}$ are controlled by the Port 3 Control and Status Register and are discussed in the Port 3 description. If unused, $\overline{\text{IS3}}$ can remain unconnected. SC2 is configured as $\overline{OS3}$ and can be used to strobe output data or acknowledge input data. It is controlled by Output Strobe Select (OSS) in the Port 3 Control and Status Register. The strobe is generated by a read (OSS=0) or write (OSS=1) to the Port 3 Data Register. $\overline{OS3}$ timing is shown in Figure 5. #### FIGURE 20 - MC68701 OSCILLATOR CHARACTERISTICS ## (a) Nominal Recommended Crystal Parameters CL = 20 pF (typical) #### NOTE TTL-compatible oscillators may be obtained from: Motorola Component Products Attn: Data Clock Sales 2553 N. Edginton St. Franklin Park, IL 60131 Tel: 312-451-1000 Telex: 433-0067 #### MC68701 Nominal Crystal Parameters | | 3.58 MHz | 4.00 MHz | 5.0 MHz | 6.0 MHz | 8.0 MHz | |----------------|----------|----------|--------------|--------------|--------------| | RS | 60 Ω | 50 Ω | 30-50 Ω | 30-50 Ω | 20-40 Ω | | C <sub>0</sub> | 3.5 pF | 6.5 pF | 4.6 pF | 4-6 pF | 4.6 pF | | C <sub>1</sub> | 0.015 pF | 0.025 pF | 0.01-0.02 pF | 0.01-0.02 pF | 0.01-0.02 pF | | Q | >40 k | >30 k | >20 k | >20 k | >20 k | \*Note: These are representative AT-cut crystal parameters only. Crystals of other types of cuts may also be used. **Equivalent Circuit** ## (b) Oscillator Stabilization Time (tpc) # SC1 And SC2 In Expanded Non-Multiplexed Mode In the Expanded Non-Multiplexed Mode, both SC1 and SC2 are configured as outputs. SC1 functions as Input/Output Select (IOS) and is asserted only when \$0100 through \$01FF is sensed on the internal address bus. SC2 is configured as Read/Write and is used to control the direction of data bus transfers. An MPU read is enabled when Read/Write and E are high. # SC1 And SC2 In Expanded Multiplexed Mode In the Expanded Multiplexed Modes, both SC1 and SC2 are configured as outputs. SC1 functions as Address Strobe and can be used to demultiplex the eight least significant addresses and the data bus. A latch controlled by Address Strobe captures address on the negative edge, as shown in Figure 15. SC2 is configured as Read/Write and is used to control the direction of data bus transfers. An MPU read is enabled when Read/Write and E are high. #### P10-P17 (PORT 1) Port 1 is a mode independent 8-bit I/O port with each line an input or output as defined by the Port 1 Data Direction Register. The TTL compatible three-state output buffers can drive one Schottky TTL load and 30 pF, Darlington transistors, or CMOS devices using external pullup resistors. It is configured as a data input port by RESET. Unused lines can remain unconnected. #### P20-P24 (PORT 2) Port 2 is a mode-independent, 5-bit, multipurpose I/O port. The voltage levels present on P20, P21, and P22 on the rising edge of RESET determine the operating mode of the MCU. The entire port is then configured as a data input port. The Port 2 lines can be selectively configured as data output lines by setting the appropriate bits in the Port 2 Data Direction Register. The Port 2 Data Register is used to move data through the port. However, if P21 is configured as an output, it will be tied to the timer Output Compare function and cannot be used to provide output from the Port 2 Data Register. Port 2 can also be used to provide an interface for the Serial Communications Interface and the timer Input Edge function. These configurations are described in the appropriate SCI and Timer sections of this publication. The Port 2 high-impedance, TTL compatible output buffers are capable of driving one Schottky TTL load and 30 pF or CMOS devices using external pullup resistors. #### **PORT 2 DATA REGISTER** | 7 | | | | | | 1 | · | | |-----|-----|-----|-----|-----|-----|-----|-----|--------| | PC2 | PC1 | PC0 | P24 | P23 | P22 | P21 | P20 | \$0003 | #### P30-P37 (PORT 3) Port 3 can be configured as an I/O port, a bidirectional 8-bit data bus, or a multiplexed address/data bus depending on the operating mode. The TTL compatible three-state output buffers can drive one Schottky TTL load and 90 pF. Unused lines can remain unconnected. #### Port 3 In Single-Chip Mode Port 3 is an 8-bit I/O port in the Single-Chip Mode, with each line configured by the Port 3 Data Direction Register. There are also two lines, $\overline{\text{IS3}}$ and $\overline{\text{OS3}}$ , which can be used to control Port 3 data transfers. Three Port 3 options are controlled by the Port 3 Control and Status Register and are available only in Single-Chip Mode: (1) Port 3 input data can be latched using IS3 as a control signal, (2) $\overline{OS3}$ can be generated by either an MPU read or write to the Port 3 Data Register, and (3) an $\overline{IRQ1}$ interrupt can be enabled by an $\overline{IS3}$ negative edge. Port 3 latch timing is shown in Figure 4. #### PORT 3 CONTROL AND STATUS REGISTER | IS3<br>Flag | IS3<br>IRQ1<br>Enable | × | oss | Latch<br>Enable | × | × | х | \$000F | | |------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|---------------------------------------------|---------------------------------------------|--------------------------------------|-----------------------------------------------|--| | Bit 0-2<br>Bit 3 | 2 | | LAT<br>inpu<br>is lat<br>latch<br>3 Da<br>clear | t latch fo<br>ched by<br>is transp<br>ata Regis<br>red durin | r Por<br>an ISC<br>paren<br>ster.<br>g reso | t 3. If s<br>nega<br>t after<br>LATC<br>et. | set, in<br>tive ed<br>a read<br>H EN | trols the put data dge. The d of Port ABLE is | | | Bit 4 | oss (Output Strobe Select). This bit determines whether Os3 will be generated by a read or write of the Por Data Register. When clear, the strobe is generated by a read; when set, it is generated by a write. Oss is cleared during reset. | | | | | | | | | | Bit 5 | | | | used. | A RI E | \//he | n set | an IRO1 | | | Bit 6 | | | IS3 IRQ1 ENABLE. When set, an IRQ1 interrupt will be enabled whenever IS3 FLAG is set; when clear, the interrupt is inhibited. This bit is cleared during reset. | | | | | | | # Port 3 In Expanded Non-Multiplexed Mode Port 3 is configured as a bidirectional data bus (D7-D0) in the Expanded Non-Multiplexed Mode. The direction of data transfers is controlled by Read/Write (SC2). Data is clocked by E (Enable). IS3 FLAG. This read-only status bit is set by an IS3 negative edge. It is cleared by a read of the Port 3 Control and Status Register (with IS3 FLAG set) followed by a read or write to the Port 3 Data Register or during reset. #### Port 3 In Expanded Multiplexed Mode Port 3 is configured as a time multiplexed address (A0-A7) and data bus (D7-D0) in the Expanded Multiplexed Modes where Address Strobe (AS) can be used to demultiplex the two buses. Port 3 is held in a high impedance state between valid address and data to prevent potentional bus conflicts. Bit 7 #### P40-P47 (PORT 4) Port 4 is configured as an 8-bit I/O port, as address outputs, or as data inputs depending on the operating mode. Port 4 can drive one Schottky TTL load and 90 pF and is the only port with internal pullup resistors. Unused lines can remain unconnected. # Port 4 In Single Chip Mode In Single Chip Mode, Port 4 functions as an 8-bit I/O port with each line configured by the Port 4 Data Direction Register. Internal pullup resistors allow the port to directly interface with CMOS at 5 volt levels. External pullup resistors to more than 5 volts, however, cannot be used. #### Port 4 In Expanded Non-Multiplexed Mode Port 4 is configured during reset as an 8-bit input port, where the Port 4 Data Direction Register can be written to provide any or all of eight address lines A0 to A7. Internal pullup resistors pull the lines high until the Port 4 Data Direction Register is configured. #### Port 4 In Expanded Multiplexed Mode In all Expanded Multiplexed modes except Mode 6, Port 4 functions as half of the address bus and provides A8 to A15. In Mode 6, the port is configured during reset as an 8-bit parallel input port, where the Port 4 Data Direction Register can be written to provide any or all of upper address lines A8 to A15. Internal pullup resistors pull the lines high until the Port 4 Data Direction Register is configured, where bit 0 controls A8. #### RESIDENT MEMORY The MC68701 has 128 bytes of onboard RAM and 2048 bytes of onboard UV erasable EPROM. This memory is controlled by four bits in the RAM/EPROM Control Register. One half of the RAM is powered through the $V_{CC}$ standby pin and is maintainable during $V_{CC}$ powerdown. This standby portion of the RAM consists of 64 bytes located from \$80 through \$BF. Power must be supplied to $V_{CC}$ standby if the internal RAM is to be used, regardless of whether standby power operation is anticipated. In Mode 3, $V_{CC}$ standby should be tied to ground. The RAM is controlled by the RAM/EPROM Control Register. #### RAM/EPROM CONTROL REGISTER (\$14) The RAM/EPROM Control Register includes four bits: STBY PWR, RAME, PPC, and PLC. Two of these bits, STBY PWR and RAME, are used to control RAM access and determine the adequacy of the standby power source during power-down operation. It is intended that RAME be cleared and STBY PWR be set as part of a power-down procedure. RAME and STBY PWR are Read/Write bits. The remaining two bits, PLC and PPC, control the operation of the EPROM. PLC and PPC are readable in all modes but can be changed only in Mode 0. The PLC bit can be written without restriction in Mode 0, but operation of the PPC bit is controlled by the state of PLC. Associated with the EPROM are an 8-bit data latch and a 16-bit address latch. The data latch is enabled at all times, latching each data byte written to the EPROM. The address latch is controlled by the PLC bit. A description of the RAM/EPROM Control Register follows. #### MC68701 RAM/EPROM CONTROL REGISTER | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |-------------|------|---|---|---|---|-----|-----|------| | STBY<br>PWR | RAME | X | × | × | × | PPC | PLC | \$14 | Bit 0 PLC. Programming Latch Control. This bit controls (a) a latch which captures the EPROM address to be programmed and (b) whether the PPC bit can be cleared. The latch is triggered by an MPU write to a location in the EPROM. This bit is set during reset and can be cleared only in Mode 0. The PLC bit is defined as follows: PLC=0 EPROM address latch enabled; EPROM address is latched during MPU writes to the EPROM. PLC=1 EPROM address latch is transparent. Bit 1 PPC. Programming Power Control. This bit gates power from the RESET/VPP pin to the EPROM programming circuit. PPC is set during reset and whenever the PLC bit is set. It can be cleared only if (a) operating in Mode 0, and (b) if PLC has been previously cleared. The PPC bit is defined as follows: PPC = 0 EPROM programming power (Vpp) applied. PPC = 1 EPROM programming power (Vpp) is not applied. Bit 2-5 Bit 6 RAME RAM Enable. This Read/Write bit can be used to remove the entire RAM from the internal memory map. RAME is set (enabled) during reset provided standby power is available on the positive edge of reset. If RAME is clear, any access to a RAM address is external. If RAME is set and not in Mode 3, the RAM is included in the internal map. Bit 7 STBY PWR Standby Power. This bit is a read/ write status bit which, when once set, remains set as long as VCC standby remains above VSBB (minimum). As long as this bit is set following a period of standby operation, the standby power supply has adequately preserved the data in the standby RAM. If this bit is cleared during a period of standby operation, it indicates that VCC standby had fallen to a level sufficiently below VSBB (minimum) to suspect that data in the standby RAM is not valid. This bit can be set only by software and is not affected during reset. Note that if PPC and PLC are set, they cannot be simultaneously cleared with a single MPU write. The PLC bit must be cleared prior to attempting to clear PPC. If both PPC and PLC are clear, setting PLC will also set PPC. In addition, it is assumed that Vpp is applied to the RESET/Vpp pin whenever PPC is clear. If this is not the case, the result is undefined. #### **ERASING THE MC68701 EPROM** Ultraviolet erasure will clear all bits of the EPROM to the "0" state. Note that this erased state differs from that of some other widely used EPROMs (such as the MCM68708) where the erased state is a "1". The MC68701 EPROM is programmed by erasing it to "0's" and entering "1's" into the desired bit locations. The MC68701 EPROM can be erased by exposure to high intensity ultraviolet light with a wave length of 2537A for a minimum of 30 minutes. The recommended integrated dose (UV intensity X exposure time) is 15 Ws/cm. The lamps should be used without shortwave filters and the MC68701 should be positioned about one inch away from the UV tubes. The MC68701 transparent lid should always be covered after erasing. This protects both the EPROM and light-sensitive nodes from accidental exposure to ultraviolet light. # PROGRAMMING THE MC68701 EPROM When the MC68701 is released from Reset in Mode 0, a vector is fetched from location \$BFFE:BFFF. This provides a method for an external program to obtain control of the microcomputer with access to every location in the EPROM. To program the EPROM, it is necessary to operate the MC68701 in Mode 0 under the control of a program resident in external memory which can facilitate loading and programming of the EPROM. After the pattern has been loaded into external memory, the EPROM can be programmed as follows: - Apply programming power (Vpp) to the RESET/Vpp pin. - Clear the PLC control bit and set the PPC bit by writing \$FE to the RAM/EPROM Control Register. - c. Write data to the next EPROM location to be programmed. Triggered by an MPU write to the EPROM, internal latches capture both the EPROM address and the data byte. - d. Clear the PPC bit for programming time, t<sub>pp</sub>, by writing \$FC to the RAM/EPROM Control Register and waiting for time, t<sub>pp</sub>. This step gates the programming power (V<sub>PP</sub>) from the RESET/V<sub>PP</sub> pin to the EPROM which programs the location. - Repeat steps b through d for each byte to be programmed. - f. Set the PLC and PPC bits by writing \$FF to the RAM/EPROM control register. - g. Remove the programming power (Vpp) from the RESET/Vpp pin. The EPROM can now be read and verified. Because of the erased state of an EPROM byte is \$00, it is not necessary to program a location which is to contain \$00. Finally, it should be noted that the result of inadvertently programming a location more than once is the logical OR of the data patterns. A routine which can be used to program the MC68701 EPROM is provided at the end of this publication. This non-reentrant routine requires four double byte variables named IMBEQ, IMEND, PNTR, and WAIT to be initialized prior to entry to the routine. These variables indicate (a) the first and last memory locations which bound the data to be programmed into the EPROM, (b) the first EPROM location to be programmed, and (c) a number which is used to generate the programming time delay. The last variable, WAIT, takes into account the MCU input crystal (or TTL-compatible clock) frequency to insure the programming time, $t_{pp}$ , is met. WAIT is defined as the number of MPU E-cycles that will occur in the real-time EPROM programming interval, $t_{pp}$ . For example, if $t_{pp} = 50$ milliseconds and the MC68701 is being driven with a 4.00 MHz TTL-compatible clock: WAIT (MPU E-cycles) = $.t_{pp}*(MCU INPUT FREQ/)4*10^6$ = $50000(4*10^6)/4*10^6$ = 50000 #### NOTE A monitor program called PRObug is available from Motorola Microsystems. PRObug contains a user option for programming the on-board MC68701 EPROM. # PROGRAMMABLE TIMER The Programmable Timer can be used to perform input waveform measurements while independently generating an output waveform. Pulse widths can vary from several microseconds to many seconds. A block diagram of the Timer is shown in Figure 21. #### **COUNTER (\$09:0A)** The key timer element is a 16-bit free-running counter which is incremented by E (Enable). It is cleared during reset and is read-only with one exception: a write to the counter (\$09) will preset it to \$FFF8. This feature, intended for testing, can disturb serial operations because the counter provides the SCI internal bit rate clock. TOF is set whenever the counter contains all 1's. #### **OUTPUT COMPARE REGISTER (\$0B:0C)** The Output Compare Register is a 16-bit Read/Write register used to control an output waveform or provide an arbitrary timeout flag. It is compared with the free-running counter on each E-cycle. When a match occurs, OCF is set and OLVL is clocked to an output level register. If Port 2, bit 1, is configured as an output, OLVL will appear at P21 and the Output Compare Register and OLVL can then be changed for the next compare. The function is inhibited for one cycle after a write to the high byte of the Compare Register (\$0B) to ensure a valid compare. The Output Compare Register is set to \$FFFF during reset. ## **INPUT CAPTURE REGISTER (\$0D:0E)** The Input Capture Register is a 16-bit read-only register used to store the free-running counter when a "proper" input transition occurs as defined by IEDG. Port 2, bit 0 should be configured as an input, but the edge detect circuit always PRObug is a trademark of Motorola Inc. senses P20 even when configured as an output. An input capture can occur independently of ICF: the register always contains the most current value. Counter transfer is inhibited, however, between accesses of a double byte MPU read. The input pulse width must be at least two E-cycles to #### TIMER CONTROL AND STATUS REGISTER (\$08) ensure an input capture under all conditions. The Timer Control and Status Register (TCSR) is an 8-bit register of which all bits are readable while bits 0-4 can be written. The three most significant bits provide the timer status and indicate if: - a proper level transition has been detected, - a match has occurred between the free-running counter and the output compare register, and - the free-running counter has overflowed. Each of the three events can generate an IRQ2 interrupt and is controlled by an individual enable bit in the TCSR. #### TIMER CONTROL AND STATUS REGISTER (TCSR) | / | O | 5 | 4 | 3 | 2 | 1 | U | | |-----|-----|-----|------|------|------|------|------|--------| | ICF | OCF | TOF | EICI | EOCI | ETOI | IEDG | OLVL | \$0008 | output level register by a successful output compare and will appear at P21 if Bit 1 of the Port 2 Data Direction Register is set. It is cleared during Bit 1 EIDG Bit 2 ETOI Bit 3 EOCI Bit 4 EICI Input Edge. IEDG is cleared during reset and controls which level transition will trigger a counter transfer to the Input Capture Register: IEDG = 0 Transfer on a negative-edge IEDG = 1 Transfer on a positive-edge. Enable Timer Overflow Interrupt. When set, an IRQ2 interrupt is enabled for a timer overflow; when clear, the interrupt is inhibited. It is cleared during reset. Enable Output Compare Interrupt. When set, an IRQ2 interrupt is enabled for an output compare; when clear, the interrupt is inhibited. It is cleared during reset. Enable Input Capture Interrupt. When set, an IRQ2 interrupt is enabled for an input capture; when clear, the interrupt is inhibited. It is cleared during **MOTOROLA** Semiconductor Products Inc. Bit 5 TOF Timer Overflow Flag. TOF is set when the counter contains all 1's. It is cleared by reading the TCSR (with TOF set) then reading the counter high byte (\$09), or by RESET. Bit 6 OCF Output Compare Flag. OCF is set Output Compare Flag. OCF is set when the Output Compare Register matches the free-running counter. It is cleared by reading the TCSR (with OCF set) and then writing to the Output Compare Register (\$0B or \$0C), or by RESET. Bit 7 ICF Input Capture Flag. ICF is set to in- dicate a proper level transition; it is cleared by reading the TCSR (with ICF set) and then the Input Capture Register High Byte (\$0D), or by RESET. # SERIAL COMMUNICATIONS INTERFACE (SCI) A full-duplex asynchronous Serial Communications Interface (SCI) is provided with two data formats and a variety of rates. The SCI transmitter and receiver are functionally independent, but use the same data format and bit rate. Serial data formats include standard mark/space (NRZ) and Biphase and both provide one start bit, eight data bits, and one stop bit. "Baud" and "bit rate" are used synonymously in the following description. # **WAKE-UP FEATURE** In a typical serial loop multi-processor configuration, the software protocol will usually identify the addressee(s) at the beginning of the message. In order to permit uninterested MPU's to ignore the remainder of the message, a wake-up feature is included whereby all further SCI receiver flag (and interrupt) processing can be inhibited until the data line goes idle. An SCI receiver is re-enabled by an idle string of ten consecutive 1's or during reset. Software must provide for the required idle string between consecutive messages and prevent it within messages. #### PROGRAMMABLE OPTIONS The following features of the SCI are programmable: - format: standard mark/space (NRZ) or Bi-phase - clock: external or internal bit rate clock - Baud: one of 4 per E-clock frequency, or external clock (X8 desired baud) - wake-up feature: enabled or disabled - interrupt requests: enabled individually for transmitter and receiver - clock output: internal bit rate clock enabled or disabled to P22 #### SERIAL COMMUNICATIONS REGISTERS The Serial Communications Interface includes four addressable registers as depicted in Figure 22. It is controlled by the Rate and Mode Control Register and the Transmit/Receive Control and Status Register. Data is transmitted and received utilizing a write-only Transmit Register and a read-only Receive Register. The shift registers are not accessible to software. #### Rate and Mode Control Register (RMCR) (\$10) The Rate and Mode Control Register controls the SCI bit rate, format, clock source, and under certain conditions, the configuration of P22. The register consists of four write-only bits which are cleared during reset. The two least significant bits control the bit rate of the internal clock and the remaining two bits control the format and clock source. #### RATE AND MODE CONTROL REGISTER (RMCR) | 7_ | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |----|---|---|---|-----|-----|-----|-----|--------| | X | Х | Х | × | CC1 | CC0 | SS1 | SS0 | \$0010 | Bit 1:Bit 0 SS1:SS0 Speed Select. These two bits select the Baud rate when using the internal clock. Four rates may be selected which are a function of the MCU input frequency. Table 6 lists bit time and rates for three selected MCU frequencies. Bit 3:Bit 2 CC1:CC0 Clock Control and Format Select. These two bits control the format and select the serial clock source. If CC1 is set, the DDR value for P22 is forced to the complement of CC0 and cannot be altered until CC1 is cleared. If CC1 is cleared after having been set, its DDR value is unchanged. Table 7 defines the formats, clock source, and use of P22. If both CC1 and CC0 are set, an external TTL compatible clock must be connected to P22 at eight times (8X) the desired bit rate, but not greater than E, with a duty cycle of 50% ( $\pm$ 10%). If CC1:CC0=10, the internal bit rate clock is provided at P22 regardless of the values for TE or RE. **NOTE:** The source of SCI internal bit rate clock is the timer free running counter. An MPU write to the counter can disturb serial operations. # Transmit/Receive Control And Status Register (TRCSR) (\$11) The Transmit/Receive Control and Status Register controls the transmitter, receiver, wake-up feature, and two individual interrupts and monitors the status of serial operations. All eight bits are readable while bits 0 to 4 are also writable. The register is initialized to \$20 by RESET. # TRANSMIT/RECEIVE CONTROL AND STATUS REGISTER (TRCSR) | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | | |------|------|------|-----|----|-----|----|----|--------| | RDRF | ORFE | TDRE | RIE | RE | TIE | TE | WU | \$0011 | TABLE 6 - SCI BIT TIMES AND RATES | SS1:SS0 4f <sub>0→</sub> | | 4f <sub>o</sub> → | 2.4576 MHz | 4.0 MHz | 4.9152 MHz | | |--------------------------|-----------|-------------------|-------------------|---------------------|---------------------|--| | 331 | 551:550 E | | 614.4 kHz | 1.0 MHz | 1.2288 MHz | | | 0 | 0 | ÷ 16 | 26 μs/38,400 Baud | 16 μs/62,500 Baud | 13.0 μs/76,800 Baud | | | 0 | 1 | ÷ 128 | 208 μs/4,800 Baud | 128 μs/7812.5 Baud | 104.2 μs/9,600 Baud | | | 1 | 0 | ÷ 1024 | 1.67 ms/600 Baud | 1.024 ms/976.6 Baud | 833.3 μs/1,200 Baud | | | 1 | .1 | ÷ 4096 | 6.67 ms/150 Baud | 4.096 ms/244.1 Baud | 3.33 ms/300 Baud | | | External (P22) | | (P22) | Up to 76,800 Baud | Up to 125,000 Baud | Up to 153,600 Baud | | TABLE 7 — SCI FORMAT AND CLOCK SOURCE CONTROL | CC1:CC0 | Format | Clock Source | Port 2, Bit 2 | |---------|----------|--------------|---------------| | 0 0 | Bi-Phase | Internal | Not Used | | 0 1 | NRZ | Internal | Not Used | | 1 0 | NRZ | Internal | Output | | 1 1 | NRZ | External | Input | FIGURE 22 - SCI REGISTERS Bit 0 WU "Wake-up" on Idle Line. When set, WU enables the wake-up function; it is cleared by ten consecutive 1's or during reset. WU will not set if the line is idle. Bit 1 TE Transmit Enable. When set, P24 DDR bit is set, cannot be changed, and will remain set if TE is subsequently cleared. When TE is changed from clear to set, the transmitter is connected to P24 and a preamble of nine consecutive 1's is transmitted. TE is cleared during reset. Bit 2 TIE Transmit Interrupt Enable. When set, an IRQ2 interrupt is enabled when TDRE is set; when clear, the interrupt is inhibited. TE is cleared during reset. Bit 3 RE Receive Enable. When set, the P23 DDR bit is cleared, cannot be changed, and will remain clear if RE is subsequently cleared. While RE is set, the SCI receiver is enabled. RE is cleared during reset. Bit 4 RIE Receiver Interrupt Enable. When set, an IRQ2 interrupt is enabled when RDRF and/or ORFE is set: when clear. the interrupt is inhibited. RIE is cleared during reset. Bit 5 TDRE Transmit Data Register Empty. TDRE is set when the Transmit Data Register is transferred to the output serial shift Transmit Data Register Empty. TDRE is set when the Transmit Data Register is transferred to the output serial shift register or during reset. It is cleared by reading the TRCSR (with TDRE set) and then writing to the Transmit Data Register. Additional data will be transmitted only if TDRE has been cleared. Bit 6 ORFE Overrun Framing Error. If set, ORFE indicates either an overrun or framing error. An overrun is a new byte ready to transfer to the Receiver Data Register with RDRF still set. A receiver framing error has occurred when the byte boundaries of the bit stream are not synchronized to the bit counter. An overrun can be distinguished from a framing error by the state of RDRF: if RDRF is set, then an overrun has occurred; otherwise a framing error has been detected. Data is not transferred to the Receive Data Register in an overrun condition. Unframed data causing a framed error is transferred to the Receive Data Register. However, subsequent data transfer is blocked until the framing error flag is cleared.\* ORFE is cleared by reading the TRCSR (with ORFE set) then the Receive Data Register, or during reset. Bit 7 RDRF Receive Data Register Full. RDRF is set when the input serial shift register is transferred to the Receive Data Register. It is cleared by reading the TRCSR (with RDRF set), and then the Receive Data Register, or during reset. #### SERIAL OPERATIONS The SCI is initialized by writing control bytes first to the Rate and Mode Control Register and then to the Transmit/Receive Control and Status Register. When TE is set, the output of the transmit serial shift register is connected to P24 and serial output is initiated by transmitting to 9-bit preamble of 1's. At this point one of two situations exist: 1) if the Transmit Data Register is empty (TDRE=1), a continuous string of 1's will be sent indicating an idle line, or 2) if a byte has been written to the Transmit-Data Register (TDRE=0), it will be transferred to the output serial shift register (synchronized with the bit rate clock), TDRE will be set, and transmission will begin. The start bit (0), eight data bits (beginning with bit 0) and a stop bit (1), will be transmitted. If TDRE is still set when the next byte transfer should occur, 1's will be sent until more data is provided. In Bi-phase format, the output toggles at the start of each bit and at half-bit time when a "1" is sent. Receive operation is controlled by RE which configures P23 as an input and enables the receiver. SCI data formats are illustrated in Figure 23. FIGURE 23 - SCI DATA FORMATS <sup>\*</sup>Devices made with mask numbers T7A and CB4 do not transfer unframed data to the Receive Data Register. ## **INSTRUCTION SET** The MC68701 is upward source and object code compatible with the MC6800. Execution times of key instructions have been reduced and several new instructions have been added, including a hardware multiply. A list of new operations added to the MC6800 instruction set is shown in Table 1. In addition, two new special opcodes, 4E and 5E, are provided for test purposes. These opcodes force the program counter to increment like a 16-bit counter, causing address lines used in the expanded modes to increment until the device is reset. These opcodes have no mnemonics. The coding of the first (or only) byte corresponding to an executable instruction is sufficient to identify the instruction and the addressing mode. The hexadecimal equivalents of the binary codes, which result from the translation of the 82 instructions in all valid modes of addressing, are shown in Table 8. There are 220 valid machine codes, 34 unassigned codes, and 2 reserved for test purposes. #### PROGRAMMING MODEL A programming model for the MC68701 is shown in Figure 9. Accumulator A can be concatenated with accumulator B and jointly referred to as accumulator D where A is the most significant byte. Any operation which modifies the double accumulator will also modify accumulator A and/or B. Other registers are defined as follows: **Program Counter** — The program counter is a 16-bit register which always points to the next instruction. **Stack Pointer** — The stack pointer is a 16-bit register which contains the address of the next available location in a pushdown/pullup (LIFO) queue. The stack resides in random access memory at a location defined by the programmer. **Index Register** — The Index Register is a 16-bit register which can be used to store data or provide an address for the indexed mode of addressing. **Accumulators** — The MCU contains two 8-bit accumulators, A and B, which are used to store operands and results from the arithmetic logic unit (ALU). They can also be concatenated and referred to as the D (double) accumulator. Condition Code Registers — The condition code register indicates the results of an instruction and includes the Overflow (V), Carry/Borrow from MSB (C), and Half Carry following five condition bits: Negative (N), Zero (Z), from bit 3 (H). These bits are testable by the conditional branch instructions. Bit 4 is the interrupt mask (I-bit) and inhibits all maskable interrupts when set. The two unused bits, B6 and B7 are read as ones. #### **ADDRESSING MODES** The MC68701 provides six addressing modes which can be used to reference memory. A summary of addressing modes for all instructions is presented in Tables 9, 10, 11, and 12 where execution times are provided in E cycles. Instruction execution times are summarized in Table 13. With an input frequency of 4 MHz, E cycles are equivalent to microseconds. A cycle-by-cycle description of bus activity for each instruction is provided in Table 14 and a description of selected instructions is shown in Figure 24. **Immediate Addressing** — The operand or "immediate byte(s)" is contained in the following byte(s) of the instruction where the number of bytes matches the size of the register. These are two or three byte instructions. **Direct Addressing** — The least significant byte of the operand address is contained in the second byte of the instruction and the most significant byte is assumed to be \$00. Direct addressing allows the user to access \$00 through \$FF using two byte instructions and execution time is reduced by eliminating the additional memory access. In most applications, the 256-byte area is reserved for frequently referenced data **Extended Addressing** — The second and third bytes of the instruction contain the absolute address of the operand. These are three byte instructions. Indexed Addressing — The unsigned offset contained in the second byte of the instruction is added with carry to the Index Register and used to reference memory without changing the Index Register. These are two byte instructions **Inherent Addressing** — The operand(s) are registers and no memory reference is required. These are single byte instructions. **Relative Addressing** — Relative addressing is used only for branch instructions. If the branch condition is true, the Program Counter is overwritten with the sum of a signed single byte displacement in the second byte of the instruction and the current Program Counter. This provides a branch range of -126 to 129 bytes from the first byte of the instruction. These are two byte instructions. TABLE 8 - CPU INSTRUCTION MAP | OP | MNEM | MODE | ~ | # | OP | MNEM | MODE | _ | # | OP | MNEM | MODE | ~ | # | OP | MNEM | MODE | ~ | # | OP | MNEM | MODE | ~ | # | |-----|------|----------|---|---|----|------|------------|----|---|----|------|----------|---|---|----|------|----------|---|---|----|---------|----------|-----|---| | 00 | • | | | | 34 | DES | INHER | 3 | 1 | 68 | ASL | INDXD | 6 | 2 | 9C | CPX | DIR | 5 | 2 | D0 | SUBB | DIR | 3 | 2 | | 01 | NOP | INHER | 2 | 1 | 35 | TXS | <b>A</b> | 3 | 1 | 69 | ROL | <b>A</b> | 6 | 2 | 9D | JSR | <b>A</b> | 5 | 2 | D1 | CMPB | <b>A</b> | 3 | 2 | | 02 | • | <b>A</b> | | | 36 | PSHA | T | 3 | 1 | 6A | DEC | T | 6 | 2 | 9E | LDS | ¥ | 4 | 2 | D2 | SBCB | | 3 | 2 | | 03 | • | T | | | 37 | PSHB | i | 3 | 1 | 6B | • | - 1 | | | 9F | STS | DIŘ | 4 | 2 | D3 | ADDD | - [ | 5 | 2 | | 04 | LSRD | - 1 | 3 | 1 | 38 | PULX | | 5 | 1 | 6C | INC | | 6 | 2 | A0 | SUBA | INDXD | 4 | 2 | D4 | ANDB | - 1 | 3 | 2 | | 05 | ASLD | - ( | 3 | 1 | 39 | RTS | | 5 | 1 | 6D | TST | | 6 | 2 | Α1 | CMPA | <b>A</b> | 4 | 2 | D5 | BITB | - [ | 3 | 2 | | 06 | TAP | 1 | 2 | 1 | ЗА | ABX | 1 | 3 | 1 | 6E | JMP | ₩ | 3 | 2 | A2 | SBCA | T | 4 | 2 | D6 | LDAB | - 1 | 3 | 2 | | 07 | TPA | 1 | 2 | 1 | 3B | RTI | 1 | 10 | 1 | 6F | CLR | INDXD | 6 | 2 | А3 | SUBD | 1 | 6 | 2 | D7 | STAB | 1 | 3 | 2 | | 08 | INX | 1 | 3 | 1 | 3C | PSHX | | 4 | 1 | 70 | NEG | EXTND | 6 | 3 | Α4 | ANDA | | 4 | 2 | D8 | EORB | | 3 | 2 | | 09 | DEX | 1 | 3 | 1 | 3D | MUL | ì | 10 | 1 | 71 | • | <b>A</b> | | | A5 | BITA | 1 | 4 | 2 | D9 | ADCB | } | 3 | 2 | | 0A | CLV | - | 2 | 1 | 3E | WAI | 1 | 9 | 1 | 72 | • | T | | | A6 | LDAA | - 1 | 4 | 2 | DA | ORAB | - 1 | 3 | 2 | | 0B | SEV | ı | 2 | 1 | 3F | SWI | | 12 | 1 | 73 | СОМ | | 6 | 3 | Α7 | STAA | 1 | 4 | 2 | DB | ADDB | - 1 | 3 | 2 | | OC. | CLC | - 1 | 2 | 1 | 40 | NEGA | | 2 | 1 | 74 | LSR | - 1 | 6 | 3 | A8 | EORA | - 1 | 4 | 2 | DC | LDD | - 1 | 4 | 2 | | 0D | SEC | Ì | 2 | 1 | 41 | • | - 1 | | | 75 | • | ŀ | | | Α9 | ADCA | 1 | 4 | 2 | DD | STD | - 1 | 4 | 2 | | 0E | CLI | - 1 | 2 | 1 | 42 | • | | | | 76 | ROR | - | 6 | 3 | АА | ORAA | İ | 4 | 2 | DE | LDX | * | 4 | 2 | | 0F | SEI | - 1 | 2 | 1 | 43 | COMA | | 2 | 1 | 77 | ASR | ı | 6 | 3 | АВ | ADDA | İ | 4 | 2 | DF | STX | DIR | 4 | 2 | | 10 | SBA | 1 | 2 | 1 | 44 | LSRA | | 2 | 1 | 78 | ASL | 1 | 6 | 3 | AC | CPX | Ì | 6 | 2 | EO | SUBB | INDXD | 4 | 2 | | 11 | CBA | - 1 | 2 | 1 | 45 | • | | | | 79 | ROL | ł | 6 | 3 | AD | JSR | | 6 | 2 | E1 | СМРВ | <b>A</b> | 4 | 2 | | 12 | • | | | | 46 | RORA | | 2 | 1 | 7A | DEC | 1 | 6 | 3 | AE | LDS | ₩ | 5 | 2 | E2 | SBCB | Τ | 4 | 2 | | 13 | • | İ | | | 47 | ASRA | | 2 | 1 | 7B | • | - | | | AF | STS | INDXD | 5 | 2 | E3 | ADDD | | 6 | 2 | | 14 | • | | | | 48 | ASLA | | 2 | 1 | 7C | INC | | 6 | 3 | во | SUBA | EXTND | 4 | 3 | E4 | ANDB | - 1 | 4 | 2 | | 15 | • | - 1 | | | 49 | ROLA | | 2 | 1 | 7D | TST | - 1 | 6 | 3 | В1 | CMPA | <b>A</b> | 4 | 3 | E5 | BITB | - 1 | 4 | 2 | | 16 | TAB | | 2 | 1 | 4A | DECA | | 2 | 1 | 7E | JMP | ₩ | 3 | 3 | B2 | SBCA | Τ | 4 | 3 | E6 | LDAB | l | 4 | 2 | | 17 | TBA | - 1 | 2 | 1 | 4B | • | 1 | - | | 7F | CLR | EXTND | 6 | 3 | В3 | SUBD | 1 | 6 | 3 | E7 | STAB | | 4 | 2 | | 18 | • | ₩ | _ | | 4C | INCA | | 2 | 1 | 80 | SUBA | IMMED | 2 | 2 | В4 | ANDA | į | 4 | 3 | E8 | EORB | i | 4 | 2 | | 19 | DAA | INHER | 2 | 1 | 4D | TSTA | | 2 | 1 | 81 | CMPA | <b>A</b> | 2 | 2 | B5 | BITA | | 4 | 3 | E9 | ADCB | | 4 | 2 | | 1A | • | | | | 4E | Т | | | | 82 | SBCA | T | 2 | 2 | В6 | LDAA | l | 4 | 3 | EA | ORAB | Į. | 4 | 2 | | 1B | ABA | INHER | 2 | 1 | 4F | CLRA | | 2 | 1 | 83 | SUBD | | 4 | 3 | В7 | STAA | ı | 4 | 3 | EB | ADDB | | 4 | 2 | | 1C | • | = | _ | | 50 | NEGB | 1 | 2 | 1 | 84 | ANDA | | 2 | 2 | В8 | EORA | - 1 | 4 | 3 | EC | LDD | ĺ | 5 | 2 | | 1D | • | | | | 51 | • | | | | 85 | BITA | | 2 | 2 | В9 | ADCA | - 1 | 4 | 3 | ED | STD | | 5 | 2 | | 1E | • | | | | 52 | • | Ī | | | 86 | LDAA | | 2 | 2 | ВА | ORAA | ł | 4 | 3 | EE | LDX | * | 5 | 2 | | 1F | • | | | | 53 | COMB | - 1 | 2 | 1 | 87 | • | | | | вв | ADDA | - 1 | 4 | 3 | EF | STX | INDXD | 5 | 2 | | 20 | BRA | REL | 3 | 2 | 54 | LSRB | Ì | 2 | 1 | 88 | EORA | 1 | 2 | 2 | вс | CPX | ŀ | 6 | 3 | F0 | SUBB | EXTND | 4 | 3 | | 21 | BRN | <b>A</b> | 3 | 2 | 55 | • | | | | 89 | ADCA | | 2 | 2 | BD | JSR | | 6 | 3 | F1 | CMPB | <b>A</b> | 4 | 3 | | 22 | вні | Τ | 3 | 2 | 56 | RORB | l | 2 | 1 | 8A | ORAA | | 2 | 2 | BE | LDS | ₩ | 5 | 3 | F2 | SBCB | T | 4 | 3 | | 23 | BLS | - 1 | 3 | 2 | 57 | ASRB | - 1 | 2 | 1 | 88 | ADDA | ¥ | 2 | 2 | BF | STS | EXTND | 5 | 3 | F3 | ADDD | 1 | 6 | 3 | | 24 | BCC | | 3 | 2 | 58 | ASLB | - 1 | 2 | 1 | 8C | CPX | IMMED | 4 | 3 | CO | SUBB | IMMED | 2 | 2 | F4 | ANDB | | 4 | 3 | | 25 | BCS | l | 3 | 2 | 59 | ROLB | | 2 | 1 | 8D | BSR | REL | 6 | 2 | C1 | CMPB | <b>A</b> | 2 | 2 | F5 | BITB | - 1 | 4 | 3 | | 26 | BNE | ĺ | 3 | 2 | 5A | DECB | | 2 | 1 | 8E | LDS | IMMED | 3 | 3 | C2 | SBCB | Т | 2 | 2 | F6 | LDAB | | 4 | 3 | | 27 | BEQ | | 3 | 2 | 5B | • | | | | 8F | • | | | | СЗ | ADDD | - 1 | 4 | 3 | F7 | STAB | | 4 | 3 | | 28 | BVC | - 1 | 3 | 2 | 5C | INCB | 1 | 2 | 1 | 90 | SUBA | DIR | 3 | 2 | C4 | ANDB | - 1 | 2 | 2 | F8 | EORB | 1 | 4 | 3 | | 29 | BVS | | 3 | 2 | 5D | TSTB | - 1 | 2 | 1 | 91 | CMPA | <b>A</b> | 3 | 2 | C5 | BITB | | 2 | 2 | F9 | ADCB | | 4 | 3 | | 2A | BPL | 1 | 3 | 2 | 5E | Т | ₩ | | | 92 | SBCA | T | 3 | 2 | C6 | LDAB | ŀ | 2 | 2 | FA | ORAB | | 4 | 3 | | 2B | ВМІ | i | 3 | 2 | 5F | CLRB | INHER | 2 | 1 | 93 | SUBD | l l | 5 | 2 | C7 | • | l | | | FB | ADDB | | 4 | 3 | | 2C | BGE | | 3 | 2 | 60 | NEG | INDXD | 6 | 2 | 94 | ANDA | j | 3 | 2 | C8 | EORB | | 2 | 2 | FC | LDD | | 5 | 3 | | 2D | BLT | - 1 | 3 | 2 | 61 | • | <b>A</b> . | | | 95 | BITA | | 3 | 2 | C9 | ADCB | į. | 2 | 2 | FD | STD | | 5 | 3 | | 2E | BGT | ₩ | 3 | 2 | 62 | • | Τ | | | 96 | LDAA | | 3 | 2 | CA | ORAB | | 2 | 2 | FE | LDX | ₩ | 5 | 3 | | 2F | BLE | REL | 3 | 2 | 63 | сом | - 1 | 6 | 2 | 97 | STAA | 1 | 3 | 2 | СВ | ADDB | | 2 | 2 | FF | STX | EXTND | 5 | 3 | | 30 | TSX | INHER | 3 | 1 | 64 | LSR | - 1 | 6 | 2 | 98 | EORA | | 3 | 2 | СС | LDD | | 3 | 3 | l | | | | | | 31 | INS | <b>A</b> | 3 | 1 | 65 | • | 1 | - | _ | 99 | ADCA | 1 | 3 | 2 | CD | • | ₩ | | | 1 | * UNDER | INED OP | COD | Ε | | 32 | PULA | T. | 4 | 1 | 66 | ROR | . 🔰 | 6 | 2 | 9A | ORAA | | 3 | 2 | CE | LDX | IMMED | 3 | 3 | 1 | | | | | | 33 | PULB | ٧ | 4 | 1 | 67 | ASR | INDXD | 6 | 2 | 9B | ADDA | * | 3 | 2 | CF | • | | | | 1 | | | | | # NOTES: 1. Addressing Modes INHER≡Inherent INDXD≡Indexed IMMED≡Immediate REL≡Relative EXTND≡Extended DIR≡Direct - 2. Unassigned opcodes are indicated by "•" and should not be executed. - 3. Codes marked by "T" force the PC to function as a 16-bit counter. # TABLE 9 - INDEX REGISTER AND STACK MANIPULATION INSTRUCTIONS | | | | | | | - | | | | | | | | | | | | | Con | ditio | n C | odes | <u>, </u> | |-----------------------------|------|----|-----|----|----|-------|----|---------|-----|---|----|------|----|----|------|-----|------------------------------------------------------|---------|----------|----------|----------|------|-----------------------------------------------| | | | ir | nme | ed | 0 | Direc | ct | | nde | x | E | xter | nd | In | here | ent | Boolean/ | 5 | 4 | 3 | 2 | 1 | 0 | | Pointer Operations | MNEM | Op | ~ | # | Op | T~ | # | Op | ~ | # | Op | ~ | # | Op | ~ | # | Arithmetic Operation | Н | 1 | 2 | Z | > | С | | Compare Index Register | CPX | 8C | 4 | 3 | 9C | 5 | 2 | AC | 6 | 2 | вс | 6 | 3 | | | | X – M:M + 1 | • | • | 1 | 1 | 1 | 1 | | Decrement Index Register | DEX | | | | | | Π | | | | | | | 09 | 3 | 1 | X−1 <del></del> X | • | • | • | ‡ | • | • | | Decrement Stack Pointer | DES | | | | | | | | | | | | | 34 | 3 | 1 | SP-1→SP | • | • | • | • | • | • | | Increment Index Register | INX | | | | | | Π | | | | | | | 08 | 3 | 1 | X+1 → X | • | • | • | 1 | • | • | | Increment Stack Pointer | INS | | | | | Π | | | | | | | | 31 | 3 | 1 | 1 SP+1 → SP | • | • | • | • | • | • | | Load Index Register | LDX | CE | 3 | 3 | DE | 4 | 2 | EE | 5 | 2 | FE | 5 | 3 | | | | $M \longrightarrow X_H, (M+1) \longrightarrow X_L$ | • | • | <b>‡</b> | 1 | R | • | | Load Stack Pointer | LDS | 8E | 3 | 3 | 9E | 4 | 2 | ΑE | 5 | 2 | BE | 5 | 3 | | | | $M \longrightarrow SP_H, (M+1) \longrightarrow SP_L$ | • | • | Ţ | <b>‡</b> | R | • | | Store Index Register | STX | | | | DF | 4 | 2 | EF | 5 | 2 | FF | 5 | 3 | | | | $X_H \longrightarrow M, X_L \longrightarrow (M+1)$ | • | • | 1 | 1 | R | • | | Store Stack Pointer | STS | | | | 9F | 4 | 2 | AF | 5 | 2 | BF | 5 | 3 | | | | $SP_H \rightarrow M, SP_L \rightarrow (M+1)$ | • | • | 1 | 1 | R | • | | Index Reg → Stack Pointer | TXS | Π | | | | | Г | | | | | | | 35 | 3 | 1 | X-1→SP | • | • | • | • | • | • | | Stack Pntr → Index Register | TSX | 1 | | | | Γ | | | | | | | | 30 | 3 | 1 | SP+1→X | • | • | • | • | • | • | | Add | ABX | | | | | | | | | | | | | ЗА | 3 | 1 | $B+X \longrightarrow X$ | • | • | • | • | • | • | | Push Data | PSHX | T | | | | Г | | T | | | | | | 3C | 4 | 1 | $X_L \rightarrow M_{SP}, SP - 1 \rightarrow SP$ | • | • | • | • | • | • | | | 1 | | | | | | | ļ | | | | | | L | | | $X_{H} \rightarrow M_{SP}, SP - 1 \rightarrow SP$ | | | | | | | | Pull Data | PULX | | | | | | | | | | | | | 38 | 5 | 1 | $SP+1 \rightarrow SP, M_{SP} \rightarrow X_{H}$ | • | • | • | • | • | • | | <u> </u> | | L_ | | L | | L | L | <u></u> | | | L | | | | L | | $SP+1 \rightarrow SP, M_{SP} \rightarrow X_L$ | <u></u> | <u> </u> | L | L | | Ш | TABLE 10 - ACCUMULATOR AND MEMORY INSTRUCTIONS (Sheet 1 of 2) | Accumulator and | T | In | nme | d | D | irec | t | lı | nde | • | E | ten | d | lı | nhe | - | Boolean | С | one | ditio | on ( | od | es | |-------------------|------|--------------------------------------------------|----------|---|----|----------|---|----------|-------|---|----|----------|---|----|-----|----|-----------------------|----------------|-----|---------|------|-----------|---------| | Memory Operations | MNE | Op | ~ | # | Op | ~ | # | Op | ~ | # | Op | ~ ] | # | Op | ~ | # | Expression | Н | 1 | N | Z | V | TC | | Add Acmitrs | ABA | | | | | | П | | | | | | | 1B | 2 | 1 | A + B A | $\blacksquare$ | • | 1 | 1 | T | | | Add B to X | ABX | | | | | | | | | | | | | 3A | 3 | 1 | 00:B + X - X | • | • | • | • | • | 1 | | Add with Carry | ADCA | 89 | 2 | 2 | 99 | 3 | 2 | Α9 | 4 | 2 | В9 | 4 | 3 | | | | A + M + C - A | П | • | 1 | 1 | T | $\Box$ | | , | ADCB | C9 | 2 | 2 | D9 | 3 | 2 | E9 | 4 | 2 | F9 | 4 | 3 | | | | B + M + C -B | | • | 1 | | П | П | | Add | ADDA | 8B | 2 | 2 | 9B | 3 | 2 | AB | 4 | 2 | BB | 4 | 3 | | | П | A + M -A | П | • | 1 | 1 | T | $\Pi$ | | | ADDB | СВ | 2 | 2 | DB | 3 | 2 | ΕB | 4 | 2 | FB | 4 | 3 | | | | B + M A | П | • | 17 | 1 | 1 | TI | | Add Double | ADDD | C3 | 4 | 3 | D3 | 5 | 2 | E3 | 6 | 2 | F3 | 6 | 3 | | | | D + M:M + 1 - D | • | • | П | | П | T | | And | ANDA | 84 | 2 | 2 | 94 | 3 | 2 | A4 | 4 | 2 | B4 | 4 | 3 | | | | A·M — A | • | • | T | | R | T | | | ANDB | C4 | 2 | 2 | D4 | 3 | 2 | E4 | 4 | 2 | F4 | 4 | 3 | | | | B · M → B | • | • | 11 | 1 | R | T | | Shift Left, | ASL | | | | | | | 68 | 6 | 2 | 78 | 6 | 3 | | | | | • | • | | | T | | | Arithmetic | ASLA | | | | | | | | | | | | | 48 | 2 | 1 | | • | • | H | П | 1 | T | | | ASLB | | | | | | | | | | | | | 58 | 2 | 1 | 57 00 | • | • | $\prod$ | | $\Box$ | Ι | | Shift Left Dbl | ASLD | | | | | | | | | | | | | 05 | 3 | 1 | | • | • | II | | $\coprod$ | $\perp$ | | Shift Right, | ASR | | | | | | | 67 | 6 | 2 | 77 | 6 | 3 | | | | | • | • | 11 | | Ш | $\perp$ | | Arithmetic | ASRA | | | | | | | | | | | | | 47 | 2 | 1 | → [[] | • | • | 11 | | $\sqcup$ | $\perp$ | | | ASRB | | | | | | | | | | | | | 57 | 2 | 1 | 67 50 | • | • | | 1 | | L | | Bit Test | BITA | 85 | 2 | 2 | 95 | 3 | 2 | Α5 | 4 | 2 | B5 | 4 | 3 | | | | A · M | • | • | | 1 | R | L | | | BITB | C5 | 2 | 2 | D5 | 3 | 2 | E5 | 4 | 2 | F5 | 4 | 3 | | | | B · M | • | • | 1 | 1 | R | | | Compare Acmitrs | CBA | | | | | | | | | | | | | 11 | 2 | 1 | A - B | • | • | ] : | 1 | 1 | Ι | | Clear | CLR | | | | | | | 6F | 6 | 2 | 7F | 6 | 3 | | | | 00 <del>-</del> M | • | • | R | | R | Ι | | | CLRA | | | | | | | | | | | | | 4F | 2 | 1 | 00 <del>-</del> A | • | • | R | S | R | Ι | | | CLRB | | | | | | | | | | | | | 5F | 2 | 7 | 00 <del></del> B | • | • | R | S | R | | | Compare | CMPA | 81 | 2 | 2 | 91 | 3 | 2 | A1 | 4 | 2 | B1 | 4 | 3 | | | | A - M | • | • | 1 | 1 | 1 | Ι | | | CMPB | C1 | 2 | 2 | D1 | 3 | 2 | E1 | 4 | 2 | F1 | 4 | 3 | | | | B - M | • | • | | | $\Box$ | Ι | | 1's Complement | COM | | | | | | | 63 | 6 | 2 | 73 | 6 | 3 | | | | M → M | • | • | | | R | I | | | COMA | | | | | | П | | | | | | | 43 | 2 | 1 | Ā <del>-</del> A | • | • | $\prod$ | | R | I | | | COMB | | | | | | | | | | | | | 53 | 2 | | B→B | • | • | | П | R | | | Decimal Adj, A | DAA | | | | | | Π | | | | | | | 19 | 2 | 1 | Adj binary sum to BCD | • | • | | | | I | | Decrement | DEC | | | | | | | 6A | 6 | 2 | 7A | 6 | 3 | | | | M - 1 M | • | • | | | | | | | DECA | | | | | | | | | | | | | 4A | 2 | 1 | A - 1 <del>-</del> A | • | • | | 1 | | | | | DECB | | | | | | | | | | | | | 5A | 2 | 1 | B - 1 <del></del> B | • | • | | | | Ţ | | Exclusive OR | EORA | 88 | 2 | 2 | 98 | 3 | 2 | A8 | 4 | 2 | B8 | 4 | 3 | | | | A ⊕ M <del>-</del> A | • | • | | | R | ] | | | EORB | C8 | 2 | 2 | D8 | 3 | 2 | E8 | 4 | 2 | F8 | 4 | 3 | | | Γ | B ⊕ M <del>-</del> B | • | • | | | R | | | Increment | INC | | | | | | T | 6C | 6 | 2 | 7C | 6 | 3 | | | Γ | M + 1 - M | • | • | 1 | 1 | | Τ | | | INCA | | | | | | Г | | | | | | | 4C | 2 | 1 | A + 1 - A | • | • | | 1 | $\prod$ | Т | | | INCB | | | | | Π | | | Π | | | | | 5C | 2 | 1 | B + 1 B | • | • | 1 | | LT | T | | Load Acmitrs | LDAA | 86 | 2 | 2 | 96 | 3 | 2 | A6 | 4 | 2 | В6 | 4 | 3 | T | | | M -A | • | • | | | R | T | | | LDAB | C6 | 2 | 2 | D6 | 3 | 2 | E6 | 4 | 2 | F6 | 4 | 3 | | | Π | M →B | • | • | | | R | T | | Load Double | LDD | cc | 3 | 3 | DC | 4 | 2 | EC | 5 | 2 | FC | 5 | 3 | | | | M:M + 1 - D | • | • | 1 | П | R | T | | Logical Shift, | LSL | 1 | T | | | | T | 68 | 6 | 2 | 78 | 6 | 3 | | | Π | | • | • | 1 | 1 | | Ť | | Left | LSLA | | T | | | T | T | | | | T | Г | Г | 48 | 2 | 1 | | • | • | 11 | | T | Ť | | = | LSLB | 1 | $\vdash$ | Г | | | 1 | | 1 | 1 | 1 | Π | | 58 | 2 | 1 | <b> </b> | • | • | П | Ti | | T | | | LSLD | <del> </del> | 1 | 1 | | <u> </u> | 1 | <b>†</b> | $t^-$ | T | T | <u> </u> | T | 05 | | 11 | 1 - | • | • | 11 | 11 | $\Pi$ | + | TABLE 10 — ACCUMULATOR AND MEMORY INSTRUCTIONS (Sheet 2 of 2) | Accumulator and | 14015 | In | nme | be | D | irec | t | I | nd ex | ( | E> | ten | d | I | nhe | · | Boolean | C | one | ditic | on ( | Cod | les | _ | |-----------------------------------------|-------|---------|----------|----|----|------|---|----|-------|---|----|-----|---|----|-----|---|------------------------|---|-----|---------|---------|--------|--------|----------| | Memory Operations | MNE | Op | ~ | # | Op | ~ | # | Op | ~ | # | Op | ~ | # | Op | ~ | # | Expression | H | 1 | N | Z | IV | 丌 | c | | Shift Right, | LSR | | | | | | | 64 | 6 | 2 | 74 | 6 | 3 | | | | > | • | • | R | 1 | 1 | 广 | ! | | Logical | LSRA | | | | | | | | | | | | | 44 | 2 | 1 | ○ <b>→</b> □□□□□→□ | • | • | R | 11 | $\Box$ | $\Box$ | - | | · · | LSRB | | | | | | | | | | | | | 54 | 2 | 1 | b7 b0 | • | • | R | | $\Pi$ | T | ī | | | LSRD | | | | | | | | | | | | | 04 | 3 | 1 | | • | • | R | П | П | | ; | | Multiply | MUL | | | | T | | | | | | | | | 3D | 10 | 1 | A X B - D | • | • | • | • | 1 | 丌 | ī | | 2's Complement | NEG | | | | | | П | 60 | 6 | 2 | 70 | 6 | 3 | | | П | 00 - M <del>-</del> M | • | • | T | 1 | 17 | $\top$ | T | | (Negate) | NEGA | | | | | | | | | | | | | 40 | 2 | 1 | 00 - A <del>-</del> A | • | • | T | Ti | 1 | Т | : | | | NEGB | | | | | | | | | | | | | 50 | 2 | 1 | 00 - B <del>- </del> B | • | • | T | 1 | $\Box$ | П | Г | | No Operation | NOP | | | | | | | | | | | | | 01 | 2 | 1 | PC + 1 - PC | • | • | • | • | • | 1 | • | | Inclusive OR | ORAA | 8A | 2 | 2 | 9A | 3 | 2 | AA | 4 | 2 | BA | 4 | 3 | | | | A + M A | • | • | П | | R | रोत | • | | | ORAB | CA | 2 | 2 | DA | 3 | 2 | EA | 4 | 2 | FA | 4 | 3 | | | П | B + M B | • | • | П | | R | 1 1 | • | | Push Data | PSHA | | | | | | Ī | | | | | | | 36 | 3 | 1 | A -Stack | • | • | • | • | • | 7 | • | | | PSHB | | | | | | | | | | | | | 37 | 3 | 1 | B - Stack | • | • | • | • | • | 1 | • | | Pull Data | PULA | | | | | | | | | Г | | | | 32 | 4 | 1 | Stack -A | • | • | • | • | • | 1 | Đ | | | PULB | | | | | | | | | | | | | 33 | 4 | 1 | Stack -B | • | • | • | • | • | ī | D | | Rotate Left | ROL | | | | | | | 69 | 6 | 2 | 79 | 6 | 3 | | | | <b>←</b> | • | • | П | | T | Т | <u>-</u> | | | ROLA | | | | | | | | | | | | | 49 | 2 | 1 | | • | • | 1 | 1 | Ti | Т | _ | | | ROLB | | | | | | | | | | | | | 59 | 2 | 1 | b7 b0 | • | • | 1 | | | T | ī | | Rotate Right | ROR | | | | | | | 66 | 6 | 2 | 76 | 6 | 3 | | | П | _ | • | • | 11 | $\prod$ | П | T | Γ | | • | RORA | | | | | | П | | | | | | | 46 | 2 | 1 | | • | • | T | | 1 | T | ┌ | | | RORB | | | | | | | | | | | | | 56 | 2 | 1 | b7 b0 | • | • | 1 | $\Box$ | T | Т | ī | | Subtract Acmitr | SBA | | | | | | Π | | | | | | | 10 | 2 | 1 | A - B A | • | • | П | | T | Т | Γ | | Subtract with | SBCA | 82 | 2 | 2 | 92 | 3 | 2 | A2 | 4 | 2 | B2 | 4 | 3 | | | П | A - M - C - A | • | • | T | | | | Γ | | Carry | SBCB | C2 | 2 | 2 | D2 | 3 | 2 | E2 | 4 | 2 | F2 | 4 | 3 | | | П | B - M - C - B | • | • | T | | П | | Γ | | Store Acmitrs | STAA | | | | 97 | 3 | 2 | A7 | 4 | 2 | B7 | 4 | 3 | | | П | A - M | • | • | $\prod$ | $\Box$ | R | | <u> </u> | | | STAB | | | | D7 | 3 | 2 | E7 | 4 | 2 | F7 | 4 | 3 | | | П | B <del></del> M | • | • | П | | R | 1 | • | | | STD | | Т | | DD | 4 | 2 | ED | 5 | 2 | FD | 5 | 3 | | | П | D - M:M + 1 | • | • | | | R | I | <u> </u> | | Subtract | SUBA | 80 | 2 | 2 | 90 | 3 | 2 | AO | 4 | 2 | во | 4 | 3 | | | | A - M <del>-</del> A | • | • | 1 | 1 | Ti | Т | Γ | | | SUBB | co | 2 | 2 | DO | 3 | 2 | ΕO | 4 | 2 | FO | 4 | 3 | | | П | B - M → B | • | • | П | 1 | П | Т | - | | Subtract Double | SUBD | 83 | 4 | 3 | 93 | 5 | 2 | A3 | 6 | 2 | вз | 6 | 3 | | | Г | D - M:M + 1 -D | • | • | П | П | Ti | Т | 1 | | Transfer Acmitr | TAB | | T | | | | T | | | | | | | 16 | 2 | 1 | A -B | • | • | T | 1 | R | 1 | 5 | | *************************************** | TBA | | $\vdash$ | Г | | | | | Т | | | | П | 17 | 2 | 1 | B <del>-</del> A | • | • | T | П | R | 1 | <u> </u> | | Test, Zero or | TST | | | | | | | 6D | 6 | 2 | 7D | 6 | 3 | | | Г | M - 00 | • | • | П | | R | ī | R | | Minus | TSTA | T | | | | | Г | | | | | | П | 4D | 2 | 1 | A - 00 | • | • | П | П | R | īŢī | R | | | TSTB | <b></b> | Г | | | i | | | | П | | | | 5D | 2 | 1 | B - 00 | • | • | П | T | R | ıTı | R | The condition code register notes are listed after Table 12. TABLE 11 - JUMP AND BRANCH INSTRUCTIONS | | | | | | | | | | | | | | | | | | | Со | ndit | ion | Cod | le R | eg. | |--------------------------|------|----|-------|---|----|-------|----|----|-----|---|----|-----------|---|----------|------|---|----------------------------------|----|------|-----|-----|------|-----| | | | | Direc | | _ | elati | ve | | nde | _ | | xter | | | here | | | 5 | 4 | 3 | | 1 | 0 | | Operations | MNEM | Op | _ | # | | | # | Op | ~ | # | Op | <u> ~</u> | # | Op | _ | # | Branch Test | Н | | 2 | Z | > | С | | Branch Always | BRA | | | | 20 | 3 | 2 | | | | | L | | | L | L | None | • | • | • | • | • | • | | Branch Never | BRN | L | | | 21 | 3 | 2 | | | | | <u> </u> | | <u> </u> | L | L | None | • | • | • | • | · | • | | Branch If Carry Clear | BCC | | | | 24 | 3 | 2 | | | | Ŀ | | L | | | | C=0 | • | • | • | ٠ | · | • | | Branch If Carry Set | BCS | | | | 25 | 3 | 2 | | | | | | | | | | C=1 | • | • | • | • | • | • | | Branch If = Zero | BEQ | | | | 27 | 3 | 2 | | | | | | | | | | Z = 1 | • | • | • | • | • | • | | Branch If ≥Zero | BGE | | | | 2C | 3 | 2 | | | | | | | | | | N <b>⊕</b> V=0 | • | • | ٠ | • | • | • | | Branch If >Zero | BGT | | | | 2E | 3 | 2 | | | | | | | | | | $Z+(N \oplus V)=0$ | • | ٠ | ٠ | • | • | • | | Branch If Higher | ВНІ | | | | 22 | 3 | 2 | | | | | | | | | | C+Z=0 | • | • | • | • | • | • | | Branch If Higher or Same | BHS | | | | 24 | 3 | 2 | | | | | | | | | | C=0 | • | • | • | • | • | • | | Branch If ≤Zero | BLE | | | | 2F | 3 | 2 | | | | | | | | | | $Z + (N \oplus V) = 1$ | • | ٠ | • | • | • | • | | Branch If Carry Set | BLO | | | | 25 | 3 | 2 | | | | | | | | | | C=1 | • | • | • | • | • | • | | Branch If Lower Or Same | BLS | | | | 23 | 3 | 2 | | | | | | | | Г | | C+Z=1 | • | • | • | • | • | • | | Branch If < Zero | BLT | | П | | 2D | 3 | 2 | | | | | | | | | | N ⊕ V = 1 | • | • | • | • | • | • | | Branch If Minus | BMI | | | | 2B | 3 | 2 | | | | | | | | | | N = 1 | • | • | • | • | • | • | | Branch If Not Equal Zero | BNE | | | | 26 | 3 | 2 | | | | | | | | | | Z=0 | • | • | • | • | • | • | | Branch If Overflow Clear | BVC | | | | 28 | 3 | 2 | | | | | | | | | | V = 0 | • | • | • | ٠ | • | • | | Branch If Overflow Set | BVS | | | | 29 | 3 | 2 | | | | | | | | | | V = 1 | • | • | ٠ | • | • | • | | Branch If Plus | BPL | | | | 2A | 3 | 2 | | | | | | | | | | N = 0 | • | • | • | • | • | • | | Branch To Subroutine | BSR | | | | 8D | 6 | 2 | | | | | | | | | Π | | • | • | • | • | • | • | | Jump | JMP | | | | | | | 6E | 3 | 2 | 7E | 3 | 3 | | | | See Special Operations-Figure 24 | • | • | • | • | • | • | | Jump To Subroutine | JSR | 9D | 5 | 2 | | | | ΑD | 6 | 2 | BD | 6 | 3 | | | | | • | • | • | • | ٠ | • | | No Operation | NOP | | | | | | | | | | | | | 01 | 2 | 1 | | • | • | • | • | • | • | | Return From Interrupt | RTI | | | | | | | | | | | | | 3B | 10 | 1 | | 1 | 1 | 1 | 1 | 1 | 1 | | Return From Subroutine | RTS | | | | | | | | | | | | | 39 | 5 | 1 | See Special Operations-Figure 24 | • | • | • | • | • | • | | Software Interrupt | SWI | | | | | | | | | | | | | 3F | 12 | 1 | | • | S | • | • | • | • | | Wait For Interrupt | WAI | | | | | | | | | | | | | 3E | 9 | 1 | ] | • | • | • | • | • | • | TABLE 12 — CONDITION CODE REGISTER MANIPULATION INSTRUCTIONS | | | | | | | | Cond | ition | Code | Reg | ister | |----------------------|------|--------|----|---|-------------------|---|------|-------|------|-----|-------| | | 11 | nherer | nt | | | 5 | 4 | 3 | 2 | 1 | 0 | | Operations | MNEM | Op | ~ | # | Boolean Operation | Н | 1 | N | Z | ٧ | С | | Clear Carry | CLC | 0C | 2 | 1 | 0 <b>→</b> C | • | • | • | • | • | R | | Clear Interrupt Mask | CLI | 0E | 2 | 1 | 0-1 | • | R | • | • | • | • | | Clear Overflow | CLV | 0A | 2 | 1 | 0 <del> V</del> | • | • | • | • | R | • | | Set Carry | SEC | 0D | 2 | 1 | 1 → C | • | • | • | • . | • | S | | Set Interrupt Mask | SEI | OF | 2 | 1 | 1→1 | • | S | • | • | • | • | | Set Overflow | SEV | 0B | 2 | 1 | 1 → V | • | • | • | • | S | • | | Accumulator A → CCR | TAP | 06 | 2 | 1 | A → CCR | 1 | 1 | 1 | 1 | 1 | 1 | | CCR → Accumulator A | TPA | 07 | 2 | 1 | CCR → A | • | • | • | • | • | • | #### **LEGEND** - Op Operation Code (Hexadecimal) - ~ Number of MPU Cycles - MSP Contents of memory location pointed to by Stack Pointer - # Number of Program Bytes - + Arithmetic Plus - Arithmetic Minus - Boolean AND - X Arithmetic Multiply - + Boolean Inclusive OR - ⊕ Boolean Exclusive OR - M Complement of M - → Transfer Into - 0 Bit=Zero - 00 Byte=Zero # **CONDITION CODE SYMBOLS** - H Half-carry from bit 3 - I Interrupt mask - N Negative (sign bit) - Z Zero (byte) - V Overflow, 2's complement - C Carry/Borrow from MSB - R Reset Always - S Set Always - ‡ Affected - Not Affected TABLE 13 — INSTRUCTION EXECUTION TIMES IN E CYCLES | | | ADE | RESSI | NG MOI | DE | | |------------------------------------------------|-----------|-----------------------------------------|-------------|----------------------------|----------------------------|-----------------------------------------| | | Immediate | Direct | Extended | Indexed | Inherent | Relative | | ABA<br>ABX<br>ADC<br>ADD<br>ADDD<br>AND<br>ASL | 2 2 4 2 | 3 3 5 3 | • 4 4 6 4 6 | •<br>4<br>4<br>6<br>4 | 2 3 • • • 2 | • • • • • | | ASLD<br>ASR<br>BCC<br>BCS<br>BEQ<br>BGE<br>BGT | • | • | 6 | 6 | 3 2 | 3<br>3<br>3<br>3 | | BHI<br>BHS<br>BIT<br>BLE<br>BLO<br>BLS<br>BLT | 2 | 3 • • | 4 | 4 | • | 3<br>3<br>3<br>3<br>3 | | BMI<br>BNE<br>BPL<br>BRA<br>BRN<br>BSR<br>BVC | • | • | • | • | • • • • • • | 3 3 3 3 3 3 3 3 3 3 6 3 3 6 6 3 6 6 6 6 | | BVS<br>CBA<br>CLC<br>CLI<br>CLR<br>CLV<br>CMP | • | • • • • • • • • • • • • • • • • • • • | 6 | •<br>•<br>•<br>6<br>•<br>4 | 2<br>2<br>2<br>2<br>2<br>2 | 3 | | COM CPX DAA DEC DES DEX EOR INC | 2 | 5 • • • • • • • • • • • • • • • • • • • | 4 6 6 6 4 6 | 6 6 • 6 • 4 6 • | 2<br>2<br>2<br>3<br>3<br>• | | | | | ADD | RESSIN | IG MO | DE | | |---------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------|-----------------------|--------------|-------------------------------------------|-------------------------------------------------|----------| | | Immediate | Direct | Extended | Indexed | Inherent | Relative | | INX JMP JSR LDA LDD LDS LDX LSL LSLD LSR LSRD MUL NEG NOP ORA PSH PSHX PUL PULX ROL ROR RTI RTS SBA SBC SEC SEI SEV STA STD STS STX SUB SWI | 2<br>3<br>3<br>3<br>3<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0<br>0 | 5 5 3 4 4 4 4 3 5 5 • | 364555666644 | 3 6 4 5 5 5 6 6 6 6 6 6 6 6 6 6 6 6 6 6 6 | 3<br>• • • • • • • • • • • • • • • • • • • | | | TAB TAP TBA TPA TST TSX TXS WAI | • | • | 6 | 6 | 12<br>2<br>2<br>2<br>2<br>2<br>2<br>3<br>3<br>9 | • | # SUMMARY OF CYCLE-BY-CYCLE OPERATION Table 14 provides a detailed description of the information present on the Address Bus, Data Bus, and the Read/Write (R/W) line during each cycle of each instruction. The information is useful in comparing actual with expected results during debug of both software and hardware as the program is executed. The information is categorized in groups according to addressing mode and number of cycles per instruction. In general, instructions with the same addressing mode and number of cycles execute in the same manner. Exceptions are indicated in the table. Note that during MPU reads of internal locations, the resultant value will not appear on the external Data Bus except in Mode 0. "High order" byte refers to the most significant byte of a 16-bit value. TABLE 14 - CYCLE-BY-CYCLE OPERATION (Sheet 1 of 5) | | ss Mode and | | Cycle | | R/W | | |---------------------------------|---------------------------------|--------|-----------------------|----------------------------------------------------------------------------------------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------| | Ins | tructions | Cycles | # | Address Bus | Line | Data Bus | | IMMEDIA | TE | | | | | | | ADC<br>ADD<br>AND<br>BIT<br>CMP | EOR<br>LDA<br>ORA<br>SBC<br>SUB | 2 | 1 2 | Opcode Address<br>Opcode Address + 1 | 1 | Opcode<br>Operand Data | | LDS<br>LDX<br>LDD | | 3 | 1<br>2<br>3 | Opcode Address Opcode Address+1 Opcode Address+2 | 1<br>1<br>1 | Opcode<br>Operand Data (High Order Byte)<br>Operand Data (Low Order Byte) | | CPX<br>SUBD<br>ADDD | | 4 | 1<br>2<br>3<br>4 | Opcode Address Opcode Address + 1 Opcode Address + 2 Address Bus FFFF | 1<br>1<br>1<br>1 | Opcode Operand Data (High Order Byte) Operand Data (Low Order Byte) Low Byte of Restart Vector | | DIRECT | | | <b>4</b> | | | | | ADC<br>ADD<br>AND<br>BIT<br>CMP | EOR<br>LDA<br>ORA<br>SBC<br>SUB | 3 | 1<br>2<br>3 | Opcode Address<br>Opcode Address + 1<br>Address of Operand | 1 1 1 | Opcode<br>Address of Operand<br>Operand Data | | STA | | 3 | 1<br>2<br>3 | Opcode Address Opcode Address + 1 Destination Address | 1<br>1<br>0 | Opcode Destination Address Data from Accumulator | | LDS<br>LDX<br>LDD | | 4 | 1<br>2<br>3<br>4 | Opcode Address Opcode Address + 1 Address of Operand Operand Address + 1 | 1<br>1<br>1 | Opcode Address of Operand Operand Data (High Order Byte) Operand Data (Low Order Byte) | | STS<br>STX<br>STD | | 4 | 1<br>2<br>3<br>4 | Opcode Address Opcode Address + 1 Address of Operand Address of Operand + 1 | 1<br>1<br>0<br>0 | Opcode Address of Operand Register Data (High Order Byte) Register Data (Low Order Byte) | | CPX<br>SUBD<br>ADDD | | 5 | 1<br>2<br>3<br>4<br>5 | Opcode Address Opcode Address + 1 Operand Address Operand Address + 1 Address Bus FFFF | 1<br>1<br>1<br>1 | Opcode Address of Operand Operand Data (High Order Byte) Operand Data (Low Order Byte) Low Byte of Restart Vector | | JSR | | 5 | 1<br>2<br>3<br>4<br>5 | Opcode Address Opcode Address + 1 Subroutine Address Stack Pointer Stack Pointer - 1 | 1<br>1<br>1<br>0<br>0 | Opcode<br>Irrelevant Data<br>First Subroutine Opcode<br>Return Address (Low Order Byte)<br>Return Address (High Order Byte) | TABLE 14 — CYCLE-BY-CYCLE OPERATION (Sheet 2 of 5) | l . | Mode and | Cycles | Cycle<br># | Address Bus | R/W<br>Line | Data Bus | |----------------------------------------|-----------------------------------------|--------|----------------------------|------------------------------------------------------------------------------------------------------------------|----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | EXTENDED | ructions | Cycles | - | Address Bus | Line | Data bus | | JMP | *************************************** | 3 | 1 2 3 | Opcode Address Opcode Address + 1 Opcode Address + 2 | 1 1 1 | Opcode Jump Address (High Order Byte) Jump Address (Low Order Byte) | | ADC<br>ADD<br>AND<br>BIT<br>CMP | EOR<br>LDA<br>ORA<br>SBC<br>SUB | 4 | 1<br>2<br>3<br>4 | Opcode Address Opcode Address + 1 Opcode Address + 2 Address of Operand | 1 1 1 1 | Opcode Address of Operand Address of Operand (Low Order Byte) Operand Data | | STA | | 4 | 1<br>2<br>3<br>4 | Opcode Address Opcode Address+1 Opcode Address+2 Operand Destination Address | 1 1 1 0 | Opcode Destination Address (High Order Byte) Destination Address (Low Order Byte) Data from Accumulator | | LDS<br>LDX<br>LDD | | 5 | 1<br>2<br>3<br>4<br>5 | Opcode Address Opcode Address + 1 Opcode Address + 2 Address of Operand Address of Operand + 1 | 1<br>1<br>1<br>1<br>1 | Opcode Address of Operand (High Order Byte) Address of Operand (Low Order Byte) Operand Data (High Order Byte) Operand Data (Low Order Byte) | | STS<br>STX<br>STD | | 5 | 1<br>2<br>3<br>4<br>5 | Opcode Address Opcode Address + 1 Opcode Address + 2 Address of Operand Address of Operand + 1 | 1<br>1<br>1<br>0<br>0 | Opcode Address of Operand (High Order Byte) Address of Operand (Low Order Byte) Operand Data (High Order Byte) Operand Data (Low Order Byte) | | ASL<br>ASR<br>CLR<br>COM<br>DEC<br>INC | LSR<br>NEG<br>ROL<br>ROR<br>TST* | 6 | 1<br>2<br>3<br>4<br>5<br>6 | Opcode Address Opcode Address + 1 Opcode Address + 2 Address of Operand Address Bus FFFF Address of Operand | 1<br>1<br>1<br>1<br>1<br>0 | Opcode Address of Operand (High Order Byte) Address of Operand (Low Order Byte) Current Operand Data Low Byte of Restart Vector New Operand Data | | CPX<br>SUBD<br>ADDD | | 6 | 1<br>2<br>3<br>4<br>5<br>6 | Opcode Address Opcode Address + 1 Opcode Address + 2 Operand Address Operand Address + 1 Address Bus FFFF | 1<br>1<br>1<br>1<br>1 | Opcode Operand Address (High Order Byte) Operand Address (Low Order Byte) Operand Data (High Order Byte) Operand Data (Low Order Byte) Low Byte of Restart Vector | | JSR | | 6 | 1<br>2<br>3<br>4<br>5<br>6 | Opcode Address Opcode Address + 1 Opcode Address + 2 Subroutine Starting Address Stack Pointer Stack Pointer – 1 | 1<br>1<br>1<br>1<br>0<br>0 | Opcode Address of Subroutine (High Order Byte) Address of Subroutine (Low Order Byte) Opcode of Next Instruction Return Address (Low Order Byte) Return Address (High Order Byte) | <sup>\*</sup>TST does not perform the write cycle during the sixth cycle. The sixth cycle is another address bus=\$FFFF. TABLE 14 — CYCLE-BY-CYCLE OPERATION (Sheet 3 of 5) | Address Mode and | | Cycle | | R/W | | |------------------|--------|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|----------------------------------| | Instructions | Cycles | # | Address Bus | Line | Data Bus | | INDEXED | | | | | • | | JMP | 3 | 1 | Opcode Address | 1 | Opcode | | | | 2 | Opcode Address+1 | 1 | Offset | | | | 3 | Address Bus FFFF | 1 | Low Byte of Restart Vector | | ADC EOR | 4 | 1 | Opcode Address | 1 | Opcode | | ADD LDA | | 2 | Opcode Address+1 | 1 | Offset | | AND ORA | | 3 | Address Bus FFFF | 1 | Low Byte of Restart Vector | | BIT SBC | | 4 | Index Register Plus Offset | 1 | Operand Data | | CMP SUB | | | , and the second | | | | STA | 4 | 1 | Opcode Address | 1 | Opcode | | | 1 | 2 | Opcode Address + 1 | 1 | Offset | | | | 3 | Address Bus FFFF | 1 | Low Byte of Restart Vector | | | | 4 | Index Register Plus Offset | 0 | Operand Data | | LDS | 5 | 1 | Opcode Address | 1 | Opcode | | LDX | | 2 | Opcode Address + 1 | 1 | Offset | | LDD | | 3 | Address Bus FFFF | 1 | Low Byte of Restart Vector | | | | 4 | Index Register Plus Offset | 1 | Operand Data (High Order Byte) | | | | 5 | Index Register Plus Offset + 1 | 1 | Operand Data (Low Order Byte) | | STS | 5 | 1 | Opcode Address | 1 | Opcode | | STX | | 2 | Opcode Address + 1 | 1 1 | Offset | | STD | | 3 | Address Bus FFFF | 1 | Low Byte of Restart Vector | | | | 4 | Index Register Plus Offset | 0 | Operand Data (High Order Byte) | | | | 5 | Index Register Plus Offset + 1 | 0 | Operand Data (Low Order Byte) | | ASL LSR | 6 | 1 | Opcode Address | 1 | Opcode | | ASR NEG | | 2 | Opcode Address + 1 | 1 | Offset | | CLR ROL | | 3 | Address Bus FFFF | 1 | Low Byte of Restart Vector | | COM ROR | | 4 | Index Register Plus Offset | 1 | Current Operand Data | | DEC TST* | | 5 | Address Bus FFFF | 1 | Low Byte of Restart Vector | | INC | | 6 | Index Register Plus Offset | 0 | New Operand Data | | CPX | 6 | 1 | Opcode Address | 1 | Opcode | | SUBD | | 2 | Opcode Address + 1 | 1 | Offset | | ADDD | | 3 | Address Bus FFFF | 1 | Low Byte of Restart Vector | | | 1 1 | 4 | Index Register + Offset | 1 | Operand Data (High Order Byte) | | | | 5 | Index Register + Offset + 1 | 1 | Operand Data (Low Order Byte) | | | | 6 | Address Bus FFFF | | Low Byte of Restart Vector | | JSR | 6 | 1 | Opcode Address | 1 | Opcode | | | | 2 | Opcode Address + 1 | 1 | Offset | | | | 3 | Address Bus FFFF | 1 1 | Low Byte of Restart Vector | | | | 4 | Index Register + Offset | 1 | First Subroutine Opcode | | | | 5 | Stack Pointer | 0 | Return Address (Low Order Byte) | | | | 6 | Stack Pointer – 1 | 0 | Return Address (High Order Byte) | <sup>\*</sup>TST does not perform the write cycle during the sixth cycle. The sixth cycle is another address bus=\$FFFF. TABLE 14 — CYCLE-BY-CYCLE OPERATION (Sheet 4 of 5) | | ess Mode and | Cycles | Cycle<br># | Address Bus | R/W<br>Line | Data Bus | |------------|--------------|--------|------------|-------------------------------------|-------------|---------------------------------------------------------------| | NHEREN | NT | 1./ | L | | | | | ABA | DAA SEC | 2 | 1 | Opcode Address | 1 1 | Opcode | | ASL<br>ASR | DEC SEI | | 2 | Opcode Address + 1 | 1 | Opcode of Next Instruction | | CBA<br>CLC | LSR TAB | 1 | | | | | | CLI | NOP TBA | 1 | | | | | | CLR | ROL TPA | 1 | | | | | | CLV | ROR TST | | 1 | | | | | COM | SBA | ŀ | | | | | | ABX | | 3 | 1 | Opcode Address | 1 | Opcode | | ADA | | " | 2 | Opcode Address + 1 | l i | Irrelevant Data | | | | | 3 | Address Bus FFFF | 1 | Low Byte of Restart Vector | | ASLD | | 3 | 1 | Opcode Address | 1 | Opcode | | LSRD | | | 2 | Opcode Address + 1 | 1 1 | Irrelevant Data | | | | | 3 | Address Bus FFFF | 1 | Low Byte of Restart Vector | | DES | | 3 | 1 | Opcode Address | 1 | Opcode | | INS | | | 2 | Opcode Address + 1 | 1 | Opcode of Next Instruction | | | | | 3 | Previous Stack Pointer Contents | 1 | Irrelevant Data | | INX | | 3 | 1 | Opcode Address | 1 | Opcode | | DEX | | | 2 | Opcode Address + 1 | 1 | Opcode of Next Instruction | | | | | 3 | Address Bus FFFF | 1 | Low Byte of Restart Vector | | PSHA | | 3 | 1 | Opcode Address | 1 | Opcode | | PSHB | | | 2 | Opcode Address + 1 | 1 1 | Opcode of Next Instruction | | | | | 3 | Stack Pointer | 0 | Accumulator Data | | TSX | | 3 | 1 | Opcode Address | 1 | Opcode | | | | | 2 | Opcode Address + 1 | 1 | Opcode of Next Instruction | | | | | 3 | Stack Pointer | 1 | Irrelevant Data | | TXS | | 3 | 1 | Opcode Address | 1 | Opcode | | | | | 2 | Opcode Address + 1 | 1 1 | Opcode of Next Instruction | | | | | 3 | Address Bus FFFF | 1 | Low Byte of Restart Vector | | PULA | | 4 | 1 | Opcode Address | 1 1 | Opcode | | PULB | | | 2 | Opcode Address + 1 Stack Pointer | 1 1 | Opcode of Next Instruction<br>Irrelevant Data | | | | | 4 | Stack Pointer + 1 | | Operand Data from Stack | | PSHX | | 4 | 1 | Opcode Address | 1 | Opcode | | 1 3117 | | - | 2 | Opcode Address + 1 | | Irrelevant Data | | | | | 3 | Stack Pointer | l i l | Index Register (Low Order Byte) | | | | | 4 | Stack Pointer - 1 | 0 | Index Register (High Order Byte) | | PULX | | 5 | 1 | Opcode Address | 1 | Opcode | | | | | 2 | Opcode Address + 1 | 1 | Irrelevant Data | | | | | 3 | Stack Pointer | 1 | Irrelevant Data | | | | | 4 | Stack Pointer + 1 | 1 | Index Register (High Order Byte) | | | | | 5 | Stack Pointer + 2 | 1 | Index Register (Low Order Byte) | | RTS | | 5 | 1 | Opcode Address | 1 | Opcode | | | | | 2 | Opcode Address + 1 | 1 1 | Irrelevant Data | | | | | 3<br>4 | Stack Pointer Stack Pointer + 1 | 1 1 | Irrelevant Data Address of Next Instruction (High Order Byte) | | | | | 5 | Stack Pointer + 1 Stack Pointer + 2 | | Address of Next Instruction (Low Order Byte) | | WAI | | 9 | 1 | Opcode Address | 1 | Opcode | | VVAI | | " | 2 | Opcode Address + 1 | | Opcode of Next Instruction | | | | | 3 | Stack Pointer | ; | Return Address (Low Order Byte) | | | | | 4 | Stack Pointer – 1 | l ŏ l | Return Address (High Order Byte) | | | | | 5 | Stack Pointer – 2 | 0 | Index Register (Low Order Byte) | | | | | 6 | Stack Pointer – 3 | 0 | Index Register (High Order Byte) | | | | | 7 | Stack Pointer - 4 | 0 | Contents of Accumulator A | | | | | 8 | Stack Pointer - 5 | 0 | Contents of Accumulator B | | | | | 9 | Stack Pointer – 6 | 0 | Contents of Condition Code Register | # TABLE 14 — CYCLE-BY-CYCLE OPERATION (Sheet 5 of 5) | Address Mode and | | Cycle | | R/W | | |------------------|--------|----------|-----------------------------|-------------|-------------------------------------------------------| | Instructions | Cycles | # | Address Bus | Line | Data Bus | | NHERENT | | | | | | | MUL | 10 | 1 | Opcode Address | 1 | Opcode | | | 1 | 2 | Opcode Address + 1 | 1 | Irrelevant Data | | | | 3 | Address Bus FFFF | 1 1 | Low Byte of Restart Vector | | | | 4 | Address Bus FFFF | 1 1 | Low Byte of Restart Vector | | | | 5 | Address Bus FFFF | 1 1 | Low Byte of Restart Vector | | | | 6 | Address Bus FFFF | 1 | Low Byte of Restart Vector | | | | 7 | Address Bus FFFF | 1 1 | Low Byte of Restart Vector | | | | 8 | Address Bus FFFF | | Low Byte of Restart Vector | | | | 9 | Address Bus FFFF | | Low Byte of Restart Vector | | | | 10 | Address Bus FFFF | 1 | Low Byte of Restart Vector | | | 10 | | | | · | | RTI | 10 | 1 | Opcode Address | 1 | Opcode | | | | 2 | Opcode Address + 1 | 1 | Irrelevant Data | | | | 3 | Stack Pointer | 1 | Irrelevant Data | | | | 4 | Stack Pointer + 1 | 1 | Contents of Condition Code Register from Stack | | | | 5 | Stack Pointer+2 | 1 | Contents of Accumulator B from Stack | | | | 6 | Stack Pointer+3 | 1 | Contents of Accumulator A from Stack | | | | 7 | Stack Pointer + 4 | 1 | Index Register from Stack (High Order Byte) | | | | 8 | Stack Pointer + 5 | 1 1 | Index Register from Stack (Low Order Byte) | | | | 9 | Stack Pointer+6 | 1 | Next Instruction Address from Stack (High Order Byte) | | | | 10 | Stack Pointer+7 | 1 | Next Instruction Address from Stack (Low Order Byte) | | SWI | 12 | 1 | Opcode Address | 1 | Opcode | | | | 2 | Opcode Address + 1 | 1 | Irrelevant Data | | | | 3 | Stack Pointer | 0 | Return Address (Low Order Byte) | | | | 4 | Stack Pointer - 1 | 0 | Return Address (High Order Byte) | | | 1 | 5 | Stack Pointer - 2 | 0 | Index Register (Low Order Byte) | | | | 6 | Stack Pointer - 3 | | Index Register (High Order Byte) | | | 1 | 7 | Stack Pointer – 4 | 0 | Contents of Accumulator A | | | | 8 | Stack Pointer – 5 | 0 | Contents of Accumulator B | | | | 9 | Stack Pointer – 6 | l o | Contents of Condition Code Register | | | | 10 | Stack Pointer – 7 | | Irrelevant Data | | | | 11 | Vector Address FFFA (Hex) | 1 1 | Address of Subroutine (High Order Byte) | | | | 12 | Vector Address FFFB (Hex) | | Address of Subroutine (Low Order Byte) | | RELATIVE | 1 | لــــــا | | | | | BCC BHT BNE BLO | 3 | 1 | Op Code Address | 1 | Op Code | | BCS BLE BPL BHS | | 2 | Op Code Address +1 | 1 1 | Branch Offset | | BEQ BLS BRA BRN | i | 3 | Address Bus FFFF | 1 1 | Low Byte of Restart Vector | | BGE BLT BVC | | - | | 1 1 | , | | BGT BMT BVS | | | | | | | BSR | 6 | 1 | Op Code Address | 1 | Op Code | | | | 2 | Op Code Address +1 | 1 | Branch Offset | | | | 3 | Address Bus FFFF | 1 | Low Byte of Restart Vector | | | | 4 | Subroutine Starting Address | 1 1 | Op Code of Next Instruction | | | | 5 | Stack Pointer | 0 | Return Address (Low Order Byte) | | | 1 | 6 | Stack Pointer -1 | $I \circ I$ | Return Address (High Order Byte) | FIGURE 24 - SPECIAL OPERATIONS ■ Stack Pointer Address of next instruction in Main Program to be executed upon return from subroutine RTNH= Most significant byte of Return Address RTNL= Least significant byte of Return Address ■ ■ Stack Pointer After Execution K=8-bit Unsigned Value # **EPROM PROGRAMMING ROUTINE** | PAGE | 001 | EPROM | •SA:1 | EPROM | *** F | ROUT | INE TO | O PROGE | RAM | THE M | C68701 | EPROM ** | k* | |----------------|-----|-------|-------|---------|--------|------------|------------|----------------------|----------|-----------|------------|-----------------------|-------------------| | 00001 | | | | NAM | | EPROI | M | | | | | | | | 00002 | | | | OPT | : 2 | ZO1,1 | LLEN= | 80 | | | | | | | 00003 | | | | TTL | , ; | *** ] | ROUTI | NE TO I | PROG | RAM 1 | THE MC6 | 8701 EPRO | OM ** | | 00004 | | | | | | | | | | | | | | | 00005 | | | | ***** | **** | *** | **** | **** | *** | ***** | ***** | **** | **** | | 00006 | | | * | | | | | | | | | | | | 00007 | | | * | E P R C | ) M | | | | | | TINE T | O PROGRA | AM | | 00008 | | | * | | | TH | E MC6 | 8701 E | PROM | 1• | | | | | 00009 | | | * | | | וזייי | E BOII | TENTE D | DACE | AMC 1 | TUE MC6 | 8701 EPR | OΜ | | 00010<br>00011 | | | * | | | | | G AT | | | | | | | 00011 | | | * | | | | | F MEMO | | | | T "IMBE | | | 00012 | | | * | | | | | ING AT | | | | i indi | G | | 00013 | | | * | | | 2111 | 2112 | 1110 111 | | 11110 | - | | | | 00015 | | | * | CALLING | CON | VENT | ION: | | | | | | | | 00016 | | | * | | | | | | | | | | | | 00017 | | | * | JSR | EPR | OM | | | | | | | | | 00018 | | | * | | | | | | | | | | | | 00019 | | | * | NOTES: | | | | | | | | | | | 00020 | | | * | | | | | | | | | | | | 00021 | | | * | 1. | | | | | | | | TE VALU | | | 00022 | | | * | | | | | | PRIC | OR TO | ) REIN | IG CALLE | D • | | 00023 | | | * | | THES | E VA | LUES | ARE: | | | | | | | 00024 | | | * | | TIME | | 4 DOI | יות חות | יבוחי | ADDDE | CC LIII | CH POIN | TC | | 00025<br>00026 | | | * | | TWRE | | | | | | | PROGRAMM | | | 00028 | | | * | | | | | THE EP | | | O DL | INCORDE | מםנו | | 00027 | | | * | | | | INIO | IIID DI | KOII | • | | | | | 00029 | | | * | | IMEN | D = | A DOU | BLE BY | TE . | ADDRE | SS WHI | CH POIN | TS | | 00030 | | | * | | | _ | | | | | | GRAMED I | | | 00031 | | | * | | | | INTO | THE EF | PROM | • | | | | | 00032 | | | * | | | | | | | | | | | | 00033 | | | * | | PNTR | <b>:</b> = | | | | | | CH POIN | | | 00034 | | | * | | | | | | | YTE I | N THE | EPROM TO | BE | | 00035 | | | * | | | | PROGE | RAMMED. | • | | | | | | 00036 | | | * | | | _ | 4 DOI | ini e ns | ידוח | COLLYTT | TD 57AT I | TE UNITOU | TC | | 00037 | | | * | | WAIT | _ = | | | | | | JE WHICH<br>UT FREQUE | | | 00038<br>00039 | | | * | | | | | | | | | UTPUT CO | | | 00039 | | | * | | | | | | | | | E A 50 MS | | | 00040 | | | * | | | | | | | | IVALEN' | | | | 00041 | | | * | | | | | | | • | | | | | 00043 | | | * | | | | 50000 | ) * (M( | CU I | NPUT | FREQ) | / 4 * 10 | **6 | | 00044 | | | * | | | | | | | | | | | | 00045 | | | * | | | | VALUI | ES FOR | TYP | ICAL | INPUT | FREQS AF | RE: | | 00046 | | | * | | | | | | | | | TAIDIM T | 250 | | 00047 | | | * | | | | WA: | IT | | | MCU | INPUT FI | KEQ | | 00048 | | | * | | | | | | _ | | | | | | 00049 | | | * | | | | | (\$7797) | | | | 2.45 MHZ<br>4.00 MHZ | | | 00050<br>00051 | | | * | | | | | (\$C350)<br>(\$EFBF) | | | | 4.00 MHZ | | | 00051 | | | * | | | J | | (YEEDE | , | | | | | | 00053 | | | * | | IT. | IS A | SSUMFI | D THAT | POW | VER (V | /PP) IS | AVAILA | BLE | | 00054 | | | * | | TO | THE | RESET | PIN F | OR F | ROGRA | AMMING. | | | | 00055 | | | * | | - | ' | | _ | | | | | | | 00056 | 5 | | * | 3. | THI | S RO | UTINE | PERF | ORMS | NO NO | ERROR | CHECKI | NG • | | 00057 | 7 | | * | | | | | | | | | | | | 00058 | 3 | | * | Routine | parame | eter ini | tializatio | on, such a | as sta | ick poin | ter, etc., | must be don | e prior to entry. | | | | | | (Use of | PRObu | g will | ensure a | all needec | d initia | alization | 1.) | | | # **EPROM PROGRAMMING ROUTINE** | 00060 | PAGE ( | 002 | EPRO | M | ·SA: | l EPRO | M *** | ROUTINE 1 | TO PROGRAM THE MC68701 EPROM *** | |------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------|------|------|------|---------|---------|------------|----------------------------------| | 00063 | 00061 | | | | | * E Q | UATI | E S | | | O0064 | | | | 0000 | ) A | TOOD | EOU | 600 | TIMED CONTROL /CMAT DECICAED | | O0065 | | | | | | | • | • | | | O0066 O014 | | | | | | | • | • | | | O0067 | | | | | | | • | | | | O0069 O0070A 0080 | 00067 | | | | | | ` | • | • | | O0070A 0080 | 00068 | | | | | * L O | CAL | VARI | [ A B L E S | | OOO71A OO80 | | | | | | | | | | | OOO72A | | | | | _ | | | | | | OOD 74A OOS OOS OOS A PNTR RMB 2 COUNTER VALUE | | | | | | | | | | | OOO74A OO86 OO02 A WAIT RMB 2 COUNTER VALUE | | | | | | | | | | | 00075 00076 | | | | | | | | | | | O0076 | | 0000 | • | 000. | | MALI | KHD | 2 | COUNTER VALUE | | O0078A 3000 | | | | | | * E P | ROM | STAF | RTS HERE | | 00079A 3000 DE 84 A EPROM LDX PNTR RESTORE WHEN DONE 00081A 3002 3C PSHX RESTORE WHEN DONE 00081A 3003 DE 80 A LDX IMBEG USE STACK 00082 00083A 3005 3C EPRO02 PSHX SAVE POINTER ON STACK 00084A 3006 86 FE A LDAA #\$FE REMOVE VPP, SET LATCH 00085A 3008 97 14 A STAA EPRCNT PPC-1, PLC-0 00086A 300A A6 00 A LDAA X MOVE DATA MEMORY-TO-LATCH 00087A 300C DE 84 A LDX PNTR GET WHERE TO PUT IT 00088A 300E A7 00 A STAA X STASH AND LATCH 00089A 3010 08 INX NEXT ADDR 00090A 3011 DF 84 A STX PNTR ALL SET FOR NEXT 00091A 3013 86 FC A LDAA #\$FC ENABLE EPROM POWER (VPP) 00092A 3015 97 14 A STAA EPMCNT PPC-0, PLC-0 00093 00094 * NOW WAIT FOR 50 MSEC TIMEOUT USING OUTPUT COMPARE. 00097A 3019 D3 09 A ADDD TIMER BUMP CURRENT VALUE 00098A 301B 7F 0008 A CLR TCSR CLEAR OCF 00099A 301E DD 0B A STD OUTCMP SET OUTPUT COMPARE 00100A 3020 86 40 A LDAA #\$40 NOW WAIT FOR OCF 001010 00102A 3022 95 08 A EPRO04 BITA TCSR 00103A 3024 27 FC 3022 BEQ EPRO04 00103A 3024 27 FC 3022 BEQ EPRO04 00105A 3027 08 INX NEXT ONE 00106A 3028 9C 82 A CPX IMEND MAYBE DONE 00107A 3028 0C 82 A CPX IMEND MAYBE DONE 00107A 3028 0C 82 A CPX IMEND MAYBE DONE 00107A 3028 0C 82 A CPX IMEND MAYBE DONE 00107A 3030 38 PULX RESTORE PNTR 00110A 3030 38 PULX RESTORE PNTR 00111A 3031 DF 84 A STX PNTR 00112A 3033 39 RTS THAT'S ALL | 00077 | | | | | | | | | | 00080A 3002 3C | 00078A | 3000 | ) | | | | ORG | \$3000 | | | 00081A 3003 DE 80 A LDX IMBEG USE STACK 00082 00083A 3005 3C EPR002 PSHX SAVE POINTER ON STACK 00084A 3006 86 FE A LDAA #\$FE REMOVE VPP, SET LATCH 00085A 3008 97 14 A STAA EPMCNT PPC=1, PLC=0 00086A 300A A6 00 A LDAA X MOVE DATA MEMORY-TO-LATCH 00087A 300C DE 84 A LDX PNTR GET WHERE TO PUT IT 00088A 300E A7 00 A STAA X STASH AND LATCH 00089A 3010 08 INX NEXT ADDR 00090A 3011 DF 84 A STX PNTR ALL SET FOR NEXT 00091A 3013 86 FC A LDAA #\$FC ENBLE EPROM POWER (VPP) 00092A 3015 97 14 A STAA EPMCNT PPC=0, PLC=0 00093 00094 * NOW WAIT FOR 50 MSEC TIMEOUT USING OUTPUT COMPARE. 00095 00096A 3017 DC 86 A LDD WAIT GET CYCLE COUNTER 00099A 301E DD 08 A STD OUTCMP SET OUTPUT COMPARE. 00099A 301E DD 08 A STD OUTCMP SET OUTPUT COMPARE 00100A 3020 86 40 A LDAA #\$40 NOW WAIT FOR OCF 001010 001010 3020 86 40 A LDAA #\$40 NOW WAIT FOR OCF 00103A 3024 27 FC 3022 BEQ EPR004 NOT YET 00106A 3026 38 PULX SETUP FOR NEXT ONE 00106A 3027 08 INX NEXT 00106A 3028 9C 82 A CPX IMEND MAYBE DONE 00107A 302A 23 D9 3005 BLS EPR002 NOT YET 00108A 302E 97 14 A STAA EPMCNT PEPON NOW WAIT LATCH 00109A 302B 9C 82 A CPX IMEND MAYBE DONE 00107A 302A 23 D9 3005 BLS EPR002 NOT YET 00108A 302C 86 FF A LDAA #\$FF REMOVE VPP, INHIBIT LATCH 00109A 3030 38 PULX RESTORE PNTR 00110A 3030 38 PULX RESTORE PNTR 00110A 3030 38 PULX RESTORE PNTR 00111A 3031 DF 84 A STAA EPMCNT FROM NOW BE READ 00110A 3030 38 PULX RESTORE PNTR | | | | 84 | Α | EPROM | | PNTR | | | 00082 00083A 3005 3C | | | | 00 | | | | 71070 | | | 00083A 3005 3C | | 3003 | DE | 80 | A | | LDX | IMBEG | USE STACK | | 00084A 3006 86 FE A LDAA #\$FE REMOVE VPP, SET LATCH 00085A 3008 97 14 A STAA EPMCNT PPC=1, PLC=0 00086A 300A A6 00 A LDAA X MOVE DATA MEMORY-TO-LATCH 00087A 300C DE 84 A LDX PNTR GET WHERE TO PUT IT 00088A 300E A7 00 A STAA X STASH AND LATCH 00089A 3010 08 INX NEXT ADDR 00090A 3011 DF 84 A STX PNTR ALL SET FOR NEXT 00091A 3013 86 FC A LDAA #\$FC ENABLE EPROM POWER (VPP) 00092A 3015 97 14 A STAA EPMCNT PPC=0, PLC=0 00093 00094 * NOW WAIT FOR 50 MSEC TIMEOUT USING OUTPUT COMPARE. 00097A 3019 D3 09 A ADDD TIMER BUMP CURRENT VALUE 00099A 301E DD 0B A STD OUTCMP SET OUTPUT COMPARE 00100A 3020 86 40 A LDAA #\$40 NOW WAIT FOR OCF 00101 00102A 3022 95 08 A EPRO04 BITA TCSR 00103A 3024 27 FC 3022 BEQ EPRO04 00105A 3027 08 INX NEXT 00106A 3028 9C 82 A CPX IMEND MAYBE DONE 00107A 302A 23 D9 3005 BLS EPRO02 0010A 3030 38 0011A 3030 38 0011B 504 A STAA EPMCNT EPROM CAN NOW BE READ 0010A 3030 38 0011A 3030 38 0011A 3030 38 0011A 3030 38 0011A 3031 DF 84 A STAA EPMCNT EPROM CAN NOW BE READ 0011A 3031 DF 84 A STAA EPMCNT EPROM CAN NOW BE READ 0011A 3031 DF 84 A STAA EPMCNT EPROM CAN NOW BE READ 0011A 3033 39 0011B 5001B | | 3005 | 3.0 | | | FPROO2 | рсих | | SAVE POINTER ON STACK | | 00085A 3008 97 14 A STAA EPMCNT PPC=1, PLC=0 00086A 300A A6 00 A LDAA X MOVE DATA MEMORY-TO-LATCH 00087A 300C DE 84 A LDX PNTR GET WHERE TO PUT IT 00088A 300E A7 00 A STAA X STASH AND LATCH 00089A 3010 08 INX NEXT ADDR 00090A 3011 DF 84 A STX PNTR ALL SET FOR NEXT 00091A 3013 86 FC A LDAA #\$FC ENABLE EPROM POWER (VPP) 00092A 3015 97 14 A STAA EPMCNT PPC=0, PLC=0 00093 00094 * NOW WAIT FOR 50 MSEC TIMEOUT USING OUTPUT COMPARE. 00095 00096A 3017 DC 86 A LDD WAIT GET CYCLE COUNTER 00097A 3019 D3 09 A ADDD TIMER BUMP CURRENT VALUE 00099A 301B DD 0B A STD OUTCMP SET OUTPUT COMPARE 00100A 3020 86 40 A LDAA #\$40 NOW WAIT FOR OCF 001010 00102A 3022 95 08 A EPRO04 BITA TCSR 00103A 3024 27 FC 3022 BEQ EPRO04 NOT YET 00104A 3026 38 PULX SETUP FOR NEXT ONE 00105A 3027 08 INX NEXT 00105A 3027 08 INX NEXT 00106A 3028 9C 82 A CPX IMEND MAYBE DONE 00107A 302A 23 D9 3005 BLS EPRO02 NOT YET 00108A 302C 86 FF A LDAA #\$FF REMOVE VPP, INHIBIT LATCH 00109A 302B 97 14 A STAA EPMCNT EPROW CAN NOW BE READ 00110A 3030 38 PULX RESTORE PNTR 00110A 3030 38 PULX RESTORE PNTR 00111A 3031 DF 84 A STX PNTR 00111A 3031 DF 84 A STX PNTR 00111A 3031 DF 84 A STX PNTR 00111A 3031 DF 84 A STX PNTR | | | - | FE | Α | EI ROOZ | | #SFE | | | 00086A 300A A6 00 A LDAA X MOVE DATA MEMORY-TO-LATCH 00087A 300C DE 84 A LDX PNTR GET WHERE TO PUT IT 00088A 300E A7 00 A STAA X STASH AND LATCH 00089A 3010 08 INX NEXT ADDR 00090A 3011 DF 84 A STX PNTR ALL SET FOR NEXT 00091A 3013 86 FC A LDAA #\$FC ENABLE EPROM POWER (VPP) 00092A 3015 97 14 A STAA EPMCNT PPC=0, PLC=0 00093 | | | | | | | | | | | 00088A 300E A7 00 A STAA X STASH AND LATCH 00089A 3010 08 INX NEXT ADDR 00090A 3011 DF 84 A STX PNTR ALL SET FOR NEXT 00091A 3013 86 FC A LDAA #\$FC ENABLE EPROM POWER (VPP) 00092A 3015 97 14 A STAA EPMCNT PC=0, PLC=0 00093 00094 * NOW WAIT FOR 50 MSEC TIMEOUT USING OUTPUT COMPARE. 00095 00096A 3017 DC 86 A LDD WAIT GET CYCLE COUNTER 00097A 3019 D3 09 A ADDD TIMER BUMP CURRENT VALUE 00098A 301B 7F 0008 A CLR TCSR CLEAR OCF 00099A 301E DD 0B A STD OUTCMP SET OUTPUT COMPARE 00100A 3020 86 40 A LDAA #\$40 NOW WAIT FOR OCF 00101 00102A 3022 95 08 A EPRO04 BITA TCSR 00103A 3024 27 FC 3022 BEQ EPRO04 NOT YET 00104A 3026 38 PULX SETUP FOR NEXT ONE 00105A 3027 08 INX NEXT 00106A 3028 9C 82 A CPX IMEND MAYBE DONE 00107A 302A 23 D9 3005 BLS EPRO02 NOT YET 00108A 302C 86 FF A LDAA #\$FF REMOVE VPP, INHIBIT LATCH 00109A 302E 97 14 A STAA EPMCNT EPROM CAN NOW BE READ 00110A 3030 38 PULX RESTORE PNTR 00110A 3030 38 PULX RESTORE PNTR 00110A 3030 39 RTS THAT'S ALL | | | | | Α | | LDAA | X | • | | 00089A 3010 08 | 00087A | 3000 | DE | 84 | Α | | LDX | PNTR | GET WHERE TO PUT IT | | 00090A 3011 DF 84 A STX PNTR ALL SET FOR NEXT 00091A 3013 86 FC A LDAA #\$FC ENABLE EPROM POWER (VPP) 00092A 3015 97 14 A STAA EPMCNT PPC=0, PLC=0 00093 00094 * NOW WAIT FOR 50 MSEC TIMEOUT USING OUTPUT COMPARE. 00095 00096A 3017 DC 86 A LDD WAIT GET CYCLE COUNTER 00097A 3019 D3 09 A ADDD TIMER BUMP CURRENT VALUE 00098A 301B 7F 0008 A CLR TCSR CLEAR OCF. 00099A 301E DD 0B A STD OUTCMP SET OUTPUT COMPARE 00100A 3020 86 40 A LDAA #\$40 NOW WAIT FOR OCF 00101 00102A 3022 95 08 A EPRO04 BITA TCSR 00103A 3024 27 FC 3022 BEQ EPRO04 NOT YET 00104A 3026 38 PULX SETUP FOR NEXT ONE 00105A 3027 08 INX NEXT 00106A 3028 9C 82 A CPX IMEND MAYBE DONE 00107A 302A 23 D9 3005 BLS EPRO02 NOT YET 00108A 302C 86 FF A LDAA #\$FF REMOVE VPP, INHIBIT LATCH 00109A 302E 97 14 A STAA EPMCNT EPROM CAN NOW BE READ 00110A 3030 38 PULX RESTORE PNTR 00112A 3033 39 RTS THAT'S ALL | | | | 00 | Α | | STAA | X | STASH AND LATCH | | 00091A 3013 86 FC A LDAA #\$FC ENABLE EPROM POWER (VPP) 00092A 3015 97 14 A STAA EPMCNT PPC=0, PLC=0 00093 00094 * NOW WAIT FOR 50 MSEC TIMEOUT USING OUTPUT COMPARE. 00095 00096A 3017 DC 86 A LDD WAIT GET CYCLE COUNTER 00097A 3019 D3 09 A ADDD TIMER BUMP CURRENT VALUE 00098A 301B 7F 0008 A CLR TCSR CLEAR OCF 00099A 301E DD 0B A STD OUTCMP SET OUTPUT COMPARE 00100A 3020 86 40 A LDAA #\$40 NOW WAIT FOR OCF 00101 00102A 3022 95 08 A EPRO04 BITA TCSR 00103A 3024 27 FC 3022 BEQ EPRO04 NOT YET 00104A 3026 38 PULX SETUP FOR NEXT ONE 00105A 3027 08 INX NEXT 00106A 3028 9C 82 A CPX IMEND MAYBE DONE 00107A 302A 23 D9 3005 BLS EPRO02 NOT YET 00108A 302C 86 FF A LDAA #\$FF REMOVE VPP, INHIBIT LATCH 00109A 302E 97 14 A STAA EPMCNT EPROM CAN NOW BE READ 00110A 3030 38 PULX RESTORE PNTR 00112A 3033 39 RTS THAT'S ALL | | | | | | | | | | | 00092A 3015 97 14 A STAA EPMCNT PPC=0, PLC=0 00093 00094 | | | | | | | | | | | 00093 00094 | | | | | | | | , | • | | NOW WAIT FOR 50 MSEC TIMEOUT USING OUTPUT COMPARE. | | 301. | 9/ | 14 | A | | SIAA | EPMCNI | PPC=0, PLC=0 | | 00095 00096A 3017 DC 86 A LDD WAIT GET CYCLE COUNTER 00097A 3019 D3 09 A ADDD TIMER BUMP CURRENT VALUE 00098A 301B 7F 0008 A CLR TCSR CLEAR OCF 00099A 301E DD 0B A STD OUTCMP SET OUTPUT COMPARE 00100A 3020 86 40 A LDAA #\$40 NOW WAIT FOR OCF 00101 00102A 3022 95 08 A EPRO04 BITA TCSR 00103A 3024 27 FC 3022 BEQ EPRO04 NOT YET 00104A 3026 38 PULX SETUP FOR NEXT ONE 00105A 3027 08 INX NEXT 00106A 3028 9C 82 A CPX IMEND MAYBE DONE 00107A 302A 23 D9 3005 BLS EPRO02 NOT YET 00108A 302C 86 FF A LDAA #\$FF REMOVE VPP, INHIBIT LATCH 00109A 302E 97 14 A STAA EPMCNT EPROM CAN NOW BE READ 00110A 3030 38 PULX RESTORE PNTR 00112A 3033 39 RTS THAT'S ALL | | | | | | * NOW 1 | WATT FO | R 50 MSEC | TIMEOUT USING OUTPUT COMPARE. | | 00097A 3019 D3 09 A ADDD TIMER BUMP CURRENT VALUE 00098A 301B 7F 0008 A CLR TCSR CLEAR OCF 00099A 301E DD 0B A STD OUTCMP SET OUTPUT COMPARE 00100A 3020 86 40 A LDAA #\$40 NOW WAIT FOR OCF 00101 00102A 3022 95 08 A EPR004 BITA TCSR O0103A 3024 27 FC 3022 BEQ EPR004 NOT YET 00104A 3026 38 PULX SETUP FOR NEXT ONE SETUP FOR NEXT ONE 00105A 3027 08 INX NEXT NEXT 00106A 3028 9C 82 A CPX IMEND MAYBE DONE O0107A 302A 23 D9 3005 BLS EPR002 NOT YET 00108A 302C 86 FF A LDAA #\$FF REMOVE VPP, INHIBIT LATCH O0109A 3030 38 PULX RESTORE PNTR 00110A 3030 38 PULX RESTORE PNTR RESTORE PNTR 00111A 3031 DF 84 A STX PNTR THAT'S ALL 00113 END | | | | | | 2,0,, | | | | | 00098A 301B 7F 0008 A CLR TCSR CLEAR OCF 00099A 301E DD 0B A STD OUTCMP SET OUTPUT COMPARE 00100A 3020 86 40 A LDAA #\$40 NOW WAIT FOR OCF 00101 00102A 3022 95 08 A EPR004 BITA TCSR 00103A 3024 27 FC 3022 BEQ EPR004 NOT YET SETUP FOR NEXT ONE 00105A 3026 38 PULX SETUP FOR NEXT ONE NEXT 00106A 3028 9C 82 A CPX IMEND MAYBE DONE NOT YET 00107A 302A 23 D9 3005 BLS EPR002 NOT YET NOT YET 00108A 302C 86 FF A LDAA #\$FF REMOVE VPP, INHIBIT LATCH CO109A 3030 38 PULX RESTORE PNTR 00110A 3030 38 PULX RESTORE PNTR RESTORE PNTR 00111A 3031 DF 84 A STX PNTR THAT'S ALL 00112A 3033 39 RTS THAT'S ALL THAT'S ALL | 00096A | 3017 | 7 DC | 86 | Α | | LDD | WAIT | GET CYCLE COUNTER | | 00099A 301E DD 0B A STD OUTCMP SET OUTPUT COMPARE 00100A 3020 86 40 A LDAA #\$40 NOW WAIT FOR OCF 00101 00102A 3022 95 08 A EPR004 BITA TCSR 00103A 3024 27 FC 3022 BEQ EPR004 NOT YET 00104A 3026 38 PULX SETUP FOR NEXT ONE 00105A 3027 08 INX NEXT NEXT 00106A 3028 9C 82 A CPX IMEND MAYBE DONE 00107A 302A 23 D9 3005 BLS EPR002 NOT YET 00108A 302C 86 FF A LDAA #\$FF REMOVE VPP, INHIBIT LATCH 00110A 3030 38 PULX RESTORE PNTR | 00097A | 3019 | 9 D3 | 09 | Α | | ADDD | TIMER | BUMP CURRENT VALUE | | 00100A 3020 86 40 A LDAA #\$40 NOW WAIT FOR OCF 00101 00102A 3022 95 08 A EPR004 BITA TCSR 00103A 3024 27 FC 3022 BEQ EPR004 NOT YET SETUP FOR NEXT ONE 00104A 3026 38 PULX SETUP FOR NEXT ONE NEXT 00105A 3027 08 INX NEXT NEXT 00106A 3028 9C 82 A CPX IMEND MAYBE DONE NOT YET 00107A 302A 23 D9 3005 BLS EPR002 NOT YET NOT YET 00108A 302C 86 FF A LDAA #\$FF REMOVE VPP, INHIBIT LATCH CO109A 3030 38 PULX RESTORE PNTR 00110A 3030 38 PULX RESTORE PNTR RESTORE PNTR 00111A 3031 DF 84 A STX PNTR THAT'S ALL 00112A 3033 39 RTS END THAT'S ALL | | | | | 8 A | | CLR | TCSR | | | 00101 00102A 3022 95 08 A EPR004 BITA TCSR 00103A 3024 27 FC 3022 BEQ EPR004 NOT YET 00104A 3026 38 PULX SETUP FOR NEXT ONE 00105A 3027 08 INX NEXT 00106A 3028 9C 82 A CPX IMEND MAYBE DONE 00107A 302A 23 D9 3005 BLS EPR002 NOT YET 00108A 302C 86 FF A LDAA #\$FF REMOVE VPP, INHIBIT LATCH 00109A 302E 97 14 A STAA EPMCNT EPROM CAN NOW BE READ 00110A 3030 38 PULX RESTORE PNTR 00112A 3033 39 RTS THAT'S ALL 00113 | | | | | | | | | | | 00102A 3022 95 08 A EPR004 BITA TCSR 00103A 3024 27 FC 3022 BEQ EPR004 NOT YET 00104A 3026 38 PULX SETUP FOR NEXT ONE 00105A 3027 08 INX NEXT 00106A 3028 9C 82 A CPX IMEND MAYBE DONE 00107A 302A 23 D9 3005 BLS EPR002 NOT YET 00108A 302C 86 FF A LDAA #\$FF REMOVE VPP, INHIBIT LATCH 00109A 302E 97 14 A STAA EPMCNT EPROM CAN NOW BE READ 00110A 3030 38 PULX RESTORE PNTR 00112A 3033 39 RTS THAT'S ALL 00113 | | 3020 | ) 86 | 40 | Α | | LDAA | #\$40 | NOW WAIT FOR OCF | | 00103A 3024 27 FC 3022 BEQ EPR004 NOT YET 00104A 3026 38 PULX SETUP FOR NEXT ONE 00105A 3027 08 INX NEXT 00106A 3028 9C 82 A CPX IMEND MAYBE DONE 00107A 302A 23 D9 3005 BLS EPR002 NOT YET 00108A 302C 86 FF A LDAA #\$FF REMOVE VPP, INHIBIT LATCH 00109A 302E 97 14 A STAA EPMCNT EPROM CAN NOW BE READ 00110A 3030 38 PULX RESTORE PNTR 00111A 3031 DF 84 A STX PNTR 00112A 3033 39 RTS THAT'S ALL 00113 END | | 30.2 | 2 05 | 0.8 | ٨ | EDDUU/ | RTTA | TCCD | | | 00104A 3026 38 | | | | | | EI ROO4 | | | NOT YET | | 00105A 3027 08 INX NEXT 00106A 3028 9C 82 A CPX IMEND MAYBE DONE 00107A 302A 23 D9 3005 BLS EPR002 NOT YET 00108A 302C 86 FF A LDAA #\$FF REMOVE VPP, INHIBIT LATCH 00109A 302E 97 14 A STAA EPMCNT EPROM CAN NOW BE READ 00110A 3030 38 PULX RESTORE PNTR RESTORE PNTR 00111A 3031 DF 84 A STX PNTR 00112A 3033 39 RTS THAT'S ALL THAT'S ALL 00113 END | | | | | 3022 | | • | 21 110 0 . | | | 00107A 302A 23 D9 3005 BLS EPRO02 NOT YET 00108A 302C 86 FF A LDAA #\$FF REMOVE VPP, INHIBIT LATCH 00109A 302E 97 14 A STAA EPMCNT EPROM CAN NOW BE READ 00110A 3030 38 PULX RESTORE PNTR 00111A 3031 DF 84 A STX PNTR 00112A 3033 39 RTS THAT'S ALL 00113 | 00105A | 302 | 7 08 | | | | | | | | 00108A 302C 86 FF A LDAA #\$FF REMOVE VPP, INHIBIT LATCH 00109A 302E 97 14 A STAA EPMCNT EPROM CAN NOW BE READ 00110A 3030 38 PULX RESTORE PNTR 00111A 3031 DF 84 A STX PNTR 00112A 3033 39 RTS THAT'S ALL 00113 END | | | | | | | CPX | IMEND | MAYBE DONE | | 00109A 302E 97 14 A STAA EPMCNT EPROM CAN NOW BE READ 00110A 3030 38 PULX RESTORE PNTR 00111A 3031 DF 84 A STX PNTR 00112A 3033 39 RTS THAT'S ALL 00113 END | | | | | 3005 | | | | | | 00110A 3030 38 | | | | | | | | • | | | 00111A 3031 DF 84 A STX PNTR<br>00112A 3033 39 RTS THAT'S ALL<br>00113 END | | | | | A | | | EPMCNT | | | 00112A 3033 39 RTS THAT'S ALL 00113 END | | | | | ٨ | | | PMTP | KESTUKE PNIK | | 00113 END | | | | | A | | | 7 14 7 17 | THAT'S ALL | | | 00113 | | | | | | | | | | | TOTAL | ERRO! | RS 0 | 0000 | 00 | 000 | | | | # **OUTLINE DIMENSIONS** ### L SUFFIX CERAMIC PACKAGE CASE 715-06 | | MILLIN | METERS | INCHES | | | | |-----|--------|--------|-----------|-------|--|--| | DIM | MIN | MAX | MIN | MAX | | | | Α | 50.29 | 51.31 | 1.980 | 2.020 | | | | В | 14.94 | 15.34 | 0.588 | 0.604 | | | | C | 3.05 | 4.06 | 0.120 | 0.160 | | | | D | 0.38 | 0.53 | 0.015 | 0.021 | | | | F | 0.76 | 1.40 | 0.030 | 0.055 | | | | G | 2.54 | BSC | 0.100 BSC | | | | | Н | 0.76 | 1.78 | 0.030 | 0.070 | | | | J | 0.20 | 0.33 | 0.008 | 0.013 | | | | K | 2.54 | 4.19 | 0.100 | 0.165 | | | | L | 14.99 | 15.49 | 0.590 | 0.610 | | | | M | _ | 100 | _ | 100 | | | | N | 1.02 | 1.52 | 0.040 | 0.060 | | | #### NOTES: - LEADS, TRUE POSITIONED WITHIN 0.25 mm (0.010) DIA (AT SEATING PLANE), AT MAX MAT'L CONDITION. - 2. DIMENSION "L" TO CENTER OF LEADS WHEN FORMED PARALLEL. #### **IMPORTANT NOTICE** Devices made with mask numbers T7A and CB4 may generate multiple framing error flags in response to unframed data. These devices will eventually synchronize correctly after a framing error; but valid, framed data following an unframed byte may generate false framing error flags. 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. # **MOTOROLA** Semiconductor Products Inc. 3501 ED BLUESTEIN BLVD., AUSTIN, TEXAS 78721 • A SUBSIDIARY OF MOTOROLA INC.