MC68HC705J1A/D Rev. 1

# HC05

## MC68HC705J1A

## TECHNICAL DATA



- GENERAL DESCRIPTION 1
  - MEMORY 2
- CENTRAL PROCESSING UNIT (CPU) 3
  - **INTERRUPTS** 4
    - RESETS 5
  - LOW POWER MODES 6
  - INPUT/OUTPUT PORTS 7
  - MULTIFUNCTION TIMER 8
    - USER EPROM 9
    - INSTRUCTION SET 10
  - ELECTRICAL SPECIFICATIONS 11
  - **MECHANICAL SPECIFICATIONS** 12

### MC68HC705J1A HCMOS MICROCONTROLLER UNIT

Motorola reserves the right to make changes without further notice to any products herein. Motorola makes no warranty, representation or guarantee regarding the suitability of its products for any particular purpose, nor does Motorola assume any liability arising out of the application or use of any product or circuit, and specifically disclaims any and all liability, including without limitation consequential or incidental damages. "Typical" parameters can and do vary in different applications. All operating parameters, including "Typicals" must be validated for each customer application by customer's technical experts. Motorola does not convey any license under its patent rights nor the rights of others. Motorola products are not designed, intended, or authorized for use as components in systems intended for surgical implant into the body, or other applications intended to support or sustain life, or for any other application in which the failure of the Motorola product could create a situation where personal injury or death may occur. Should Buyer purchase or use Motorola products for any such unintended or unauthorized application, Buyer shall indemnify and hold Motorola and its officers, employees, subsidiaries, affiliates, and distributors harmless against all claims, costs, damages, and expenses, and reasonable attorney fees arising out of, directly or indirectly, any claim of personal injury or death associated with such unintended or unauthorized use, even if such claim alleges that Motorola and ( $\widehat{M}$ ) are registered trademarks of Motorola, Inc. Motorola, Inc. Sonal Deporting/Affirmative Action Employer.

© MOTOROLA INC., 1995

#### Paragraph

#### Title

Page

#### SECTION 1 GENERAL DESCRIPTION

| 1.1    | Introduction                                                             |
|--------|--------------------------------------------------------------------------|
| 1.2    | Features                                                                 |
| 1.3    | MCU Structure                                                            |
| 1.4    | Functional Pin Description 1-3                                           |
| 1.4.1  | $V_{DD}$ and $V_{SS}$                                                    |
| 1.4.2  | OSC1 and OSC2 1-4                                                        |
| 1.4.3  | Crystal Oscillator                                                       |
| 1.4.4  | Ceramic Resonator Oscillator 1-6                                         |
| 1.4.5  | RC Oscillator                                                            |
| 14.6   | External Clock                                                           |
| 1.4.7  | RESET                                                                    |
| 1.4.8  | IRQ/V <sub>PP</sub> (Maskable Interrupt Request/Programming Voltage) 1-7 |
| 1.4.9  | PA0 Through PA7 1-8                                                      |
| 1.4.10 | PB0 Through PB5 1-8                                                      |
|        |                                                                          |

#### **SECTION 2**

#### MEMORY

| 2.1 | Introduction         | -1 |
|-----|----------------------|----|
| 2.2 | Memory Map           | -1 |
|     | Input/Output Section |    |
|     | RAM 2                |    |
| 2.5 | EPROM                | -5 |
| 2.6 | COP Register         | -5 |

#### **SECTION 3**

#### **CENTRAL PROCESSING UNIT (CPU)**

| 3.1   | Introduction                | -1 |
|-------|-----------------------------|----|
| 3.1.1 | CPU Registers               | -1 |
| 3.1.2 | Accumulator                 | -2 |
| 3.1.3 | Index Register              | -2 |
| 3.1.4 | Stack Pointer               | -2 |
| 3.1.5 | Program Counter             | -2 |
| 3.1.6 | Condition Code Register 3   | -3 |
|       | Arithmetic/Logic Unit (ALU) |    |
|       |                             |    |

#### Paragraph

#### Title

#### Page

#### SECTION 4 INTERRUPTS

| 4.1   |                                                | 4-1 |
|-------|------------------------------------------------|-----|
| 4.2   | CPU Interrupt Processing                       | 4-1 |
| 4.3   | Reset Interrupt Sequence                       | 4-3 |
| 4.4   | Software Interrupt (SWI)                       | 4-3 |
| 4.5   | Hardware Interrupts                            | 4-3 |
| 4.6   | External Interrupt (IRQ)                       | 4-3 |
| 4.6.1 | IRQ Status/Control Register (ISCR)             | 4-5 |
| 4.6.2 | Optional External Interrupts (PA0 through PA3) | 4-6 |
| 4.6.3 | Timer Interrupts (TIMER)                       | 4-6 |

#### SECTION 5 RESETS

| 5.1   | Introduction                             | 5-1 |
|-------|------------------------------------------|-----|
| 5.2   | External Reset (RESET)                   | 5-1 |
| 5.3   | Internal Resets                          | 5-2 |
| 5.3.1 | Power-On Reset (POR)                     | 5-2 |
| 5.3.2 | Computer Operating Properly Reset (COPR) | 5-3 |
| 5.3.3 | Illegal Address Reset (ILADR)            | 5-3 |

#### SECTION 6 LOW POWER MOES

| 6.1   | Introduction                      | 6-1 |
|-------|-----------------------------------|-----|
| 6.2   | STOP Instruction                  | 6-1 |
| 6.2.1 | Stop Mode                         | 6-1 |
| 6.2.2 | Halt Mode                         | 6-3 |
|       | WAIT Instruction                  |     |
|       | Data-Retention Mode               |     |
| 6.5   | COP Watchdog Timer Considerations | 6-4 |

#### SECTION 7

#### **INPUT/OUTPUT PORTS**

| 7.1   | Introduction                       |
|-------|------------------------------------|
| 7.2   | Port A                             |
| 7.2.1 | Port A Data Register               |
| 7.2.2 | Port A Data Direction Register 7-2 |
| 7.2.3 | Port A Pulldown Register           |
| 7.2.4 | Port A LED Drive Capability 7-2    |

| Paragraph      |                             | Title Pag                             |     |  |  |
|----------------|-----------------------------|---------------------------------------|-----|--|--|
| 7.2.5<br>7.3   |                             |                                       |     |  |  |
| 7.3<br>7.3.1   | Port B Port B Data Register |                                       |     |  |  |
| 7.3.2          |                             |                                       |     |  |  |
| 7.3.3<br>7.4   | I/O Port Programming        |                                       |     |  |  |
| 7.4.1          | Pin Data Direction          |                                       | 7-4 |  |  |
| 7.4.2          | •                           |                                       |     |  |  |
| 7.4.3<br>7.4.4 | •                           |                                       |     |  |  |
| 7.4.5          |                             | ••••••••••••••••••••••••••••••••••••• |     |  |  |

#### SECTION 8 MULTIFUNCTION TIMER

| 8.1 | Introduction                             | 8-1 |
|-----|------------------------------------------|-----|
| 8.2 | Timer Status and Control Register (TSCR) | 8-2 |
| 8.3 | Timer Counter Register (TCNTR)           | 8-3 |
| 8.4 | COP Watchdog                             | 8-4 |

#### SECTION 9 USER EPROM

| 9.1   |                                    | 9-1 |
|-------|------------------------------------|-----|
| 9.2   | EPROM Erasing                      | 9-1 |
|       | EPROM Programming                  |     |
| 9.4   | EPROM Registers                    | 9-1 |
| 9.4.1 | EPROM Programming Register (EPROG) | 9-2 |
| 9.4.2 | Mask Option Register (MOR)         | 9-3 |
| 9.5   | MOR Programming                    | 9-5 |
|       |                                    |     |

#### SECTION 10 INSTRUCTION SET

| 10.1   | Introduction              | )-1 |
|--------|---------------------------|-----|
|        | Addressing Modes 10       |     |
|        | Inherent                  |     |
|        | Immediate                 |     |
|        | Direct                    |     |
|        | Extended                  |     |
|        | Indexed, No Offset 10     |     |
|        | Indexed, 8-Bit Offset 10  |     |
| 10.2.7 | Indexed, 16-Bit Offset 10 | )-3 |

| Paragraph | Title | Page                                         |
|-----------|-------|----------------------------------------------|
| •         |       | 10-3<br>10-4<br>10-5<br>10-5<br>10-7<br>10-7 |
|           |       |                                              |

#### SECTION 11 ELECTRICAL SPECIFICATIONS

| 11.1 | Introduction                      | 11-1 |
|------|-----------------------------------|------|
| 11.2 | Maximum Ratings                   | 11-1 |
| 11.3 | Thermal Characteristics           | 11-2 |
| 11.4 | Power Considerations              | 11-2 |
| 11.5 | DC Electrical Characteristics     | 11-3 |
| 11.6 | EPROM Programming Characteristics | 11-7 |
| 11.7 | Control Timing                    | 11-8 |

#### **SECTION 12**

#### **MECHANICAL SPECIFICATIONS**

| 12.1 | Introduction                | 12-1 |
|------|-----------------------------|------|
| 12.2 | PDIP Package (Case 738-03)  | 12-1 |
| 12.3 | SOIC Package (Case 751D-04) | 12-2 |

#### LIST OF FIGURES

| Figure                                 | Title                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | Page                     |
|----------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|
| 1-1<br>1-2<br>1-3<br>1-4<br>1-5<br>1-6 | Block Diagram       Pin Assignments         Pin Assignments       Bypassing Layout Recommendation         Crystal Connections with Feedback Resistor Mask Option       Crystal Connections with Feedback Resistor Mask Option         Crystal Connections without Feedback Resistor Mask Option       Crystal Connections with Feedback Resistor Mask Option         Crystal Connections without Feedback Resistor Mask Option       Crystal Connections with Feedback Resistor Mask Option | 1-3<br>1-4<br>1-5        |
| 1-7                                    | Mask OptionConnections without Feedback Resistor                                                                                                                                                                                                                                                                                                                                                                                                                                            |                          |
| 1-8                                    | Mask Option                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                          |
| 2-1<br>2-2<br>2-3                      | Memory Map<br>I/O Registers \$0000-\$000F<br>I/O Registers \$0010-\$001F                                                                                                                                                                                                                                                                                                                                                                                                                    | 2-3                      |
| 3-1<br>3-2<br>3-3<br>3-4<br>3-5<br>3-6 | Programming Model                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | 3-2<br>3-2<br>3-2<br>3-3 |
| 4-1<br>4-2<br>4-3                      | Interrupt Processing Flowchart<br>IRQ Function Block Diagram<br>IRQ Status and Control Register                                                                                                                                                                                                                                                                                                                                                                                             | 4-3                      |
| 5-1<br>5-2                             | Reset Block Diagram Power-On Reset and External Timing Diagram                                                                                                                                                                                                                                                                                                                                                                                                                              |                          |
| 6-1                                    | Stop/Halt/Wait Flowcharts                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 6-2                      |
| 7-1<br>7-2                             | Port A I/O Circuitry<br>Port B I/O Circuitry                                                                                                                                                                                                                                                                                                                                                                                                                                                |                          |
| 8-1<br>8-2<br>8-3<br>8-4               | Multifunction Timer Block DiagramTimer Status/Control RegisterTimer Counter RegisterCOP Watchdog Timer Location                                                                                                                                                                                                                                                                                                                                                                             | 8-2<br>8-3               |
| 9-1<br>9-2                             | EPROM Programming Register                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                          |

#### LIST OF FIGURES

| Figure | Title                                                     | Page  |
|--------|-----------------------------------------------------------|-------|
| 11-1   | PA0-PA7, PB0-PB5 Typical High-Side Driver Characteristics | 11-5  |
| 11-2   | PA0-PA3, PB0-PB5 Typical Low-Side Driver Characteristics  | 11-5  |
| 11-3   | PA4-PA7 Typical Low-Side Driver Characteristics           | 11-6  |
| 11-4   | Typical Operating I <sub>DD</sub> (25°C)                  | 11-6  |
| 11-5   | Typical Wait Mode I <sub>DD</sub> (25°C)                  | 11-7  |
| 11-6   | External Interrupt Timing                                 | 11-9  |
| 11-7   | Stop Mode Recovery Timing                                 | 11-9  |
| 11-8   | Power-On Reset Timing                                     | 11-10 |
| 11-9   | External Reset Timing                                     | 11-10 |

#### LIST OF TABLES

| Title                                                                                                                                                                                                                        | Page                                     |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------|
| Vector Address for Interrupts and Reset                                                                                                                                                                                      | 4-2                                      |
| COP Watchdog Timer Recommendations                                                                                                                                                                                           | 6-4                                      |
| Port A I/O Pin Functions                                                                                                                                                                                                     |                                          |
| Real-Time Interrupt Rate Selection.                                                                                                                                                                                          | 8-3                                      |
| Register/Memory Instructions .<br>Read-Modify-Write Instructions .<br>Jump and Branch Instructions .<br>Bit Manipulation Instructions .<br>Control Instructions .<br>Instruction Set Summary .<br>Opcode Map .               |                                          |
| Maximum Ratings .<br>Thermal Characteristics .<br>DC Electrical Characteristics ( $V_{DD} = 5 V$ ).<br>DC Electrical Characteristics ( $V_{DD} = 3.3 V$ ) .<br>EPROM Programming Characteristics .<br>Control Timing (5 V) . |                                          |
|                                                                                                                                                                                                                              | Vector Address for Interrupts and Reset. |

#### SECTION 1 GENERAL DESCRIPTION

#### **1.1 Introduction**

The Motorola MC68HC705J1A is an EPROM version of the MC68HC05J1A microcontroller in the M68HC05 Family of microcontrollers. The HC05 CPU core has been enhanced with a 15-stage multifunctional timer and is available in a 20-pin package with 64 bytes of RAM, 1240 bytes of user EPROM, and input/output (I/O).

#### 1.2 Features

- Low Cost, HC05 Core
- 20-Pin Package
- 1240 Bytes of User EPROM, Including Eight Bytes of User Vectors
- 64 Bytes of User RAM
- 15-Stage Multifunction Timer Including:
  - 8-Bit Free-Running Counter
  - Four-Stage Selectable Real-Time Interrupt Generator
- 14 Bidirectional I/O Lines Including:
  - 10 mA Sink Capability on Four I/O Pins
  - MOR (Mask Option Register) and Software Programmable Pulldowns on All I/O pins
  - MOR Selectable Interrupt on Four I/O Pins (Keyboard Scan Feature)
- MOR Selectable Sensitivity on IRQ Interrupt (Edge- and Level-Sensitive or Edge-Sensitive Only)
- Software Mask and Request Bit for IRQ Interrupt
- On-Chip Oscillator (Crystal/Ceramic Resonator or RC Oscillator)
- MOR Selectable Parallel Oscillator Bias Resistor (Approximately 2 MΩ)
- MOR Selectable Computer Operating Properly (COP) Watchdog System
- Power Saving Stop and Wait Mode Instructions (MOR Selectable STOP Instruction Conversion to HALT)
- Illegal Address Reset
- Internal Steering Diode and Pullup Resistor on RESET Pin to V<sub>DD</sub>

#### 1.3 MCU Structure

Figure 1-1 shows the structure of the MC68HC705J1A.





#### NOTE

A line over a signal name indicates an active low signal. For example, RESET is active high and RESET is active low.

#### NOTE

Any reference to voltage, current, or frequency specified in the following sections will refer to the nominal values. The exact values and their tolerances or limits are specified in **SECTION 11 ELECTRICAL SPECIFICATIONS.** 

#### **1.4 Functional Pin Description**

Figure 1-2 shows the MC68HC705J1A pin assignments for both the plastic dual-inline package (PDIP) and the small outline integrated circuit (SOIC) package.

A description of the general function of each pin is given in the following paragraphs. Where applicable, reference is made to other sections for more detailed information.



Figure 1-2. Pin Assignments

#### 1.4.1 $V_{DD}$ and $V_{SS}$

Power is supplied to the MCU through  $V_{DD}$  and  $V_{SS}$ .  $V_{DD}$  is the positive supply, and  $V_{SS}$  is ground. The MCU operates from a single power supply.

Very fast signal transitions occur on the MCU pins. The short rise and fall times place very high short-duration current demands on the power supply. To prevent noise problems, special care should be taken to provide good power supply bypassing at the MCU. As shown in Figure 1-3, this can be accomplished by using bypass capacitors with good high-frequency characteristics that are positioned as close to the MCU as possible. Bypassing requirements vary, depending on how heavily the MCU pins are loaded.



Figure 1-3. Bypassing Layout Recommendation

#### 1.4.2 OSC1 and OSC2

The OSC1 and OSC2 pins are the connections for the on-chip oscillator. The OSC1 and OSC2 pins can accept the following sets of components:

- 1. A crystal as shown in Figure 1-4 and Figure 1-5
- 2. A ceramic resonator as shown in Figure 1-6 and Figure 1-7
- 3. An RC oscillator
- 4. An external clock signal as shown in Figure 1-8

The frequency,  $f_{osc}$ , of the oscillator or external clock source is divided by two to produce the internal operating frequency,  $f_{op}$ . An internal 2 M $\Omega$  resistor may be selected between OSC1 and OSC2 by a programmable mask option.

#### **Crystal Oscillator**

Figure 1-4 and Figure 1-5 show a typical crystal oscillator circuit for an AT-cut, parallel resonant crystal. Follow the crystal supplier's recommendations, as the crystal parameters determine the external component values required to provide reliable start-up and maximum stability. The load capacitance values used in the oscillator circuit design should include all stray layout capacitances.

To minimize output distortion, mount the crystal and capacitors as close as possible to the pins. An internal start-up resistor of approximately 2 M $\Omega$  is provided between OSC1 and OSC2 for the crystal type oscillator as a programmable mask option.

#### NOTE

Use an AT-cut crystal and not an AT-strip crystal. The MCU may overdrive an AT-strip crystal.



Figure 1-4. Crystal Connections with Feedback Resistor Mask Option



Figure 1-5. Crystal Connections without Feedback Resistor Mask Option

**GENERAL DESCRIPTION** 

#### **Ceramic Resonator Oscillator**

In cost-sensitive applications, a ceramic resonator can be used in place of the crystal. The circuit shown in Figure 1-6 or Figure 1-7 can be used for a ceramic resonator. The resonator manufacturer's recommendations should be followed, as the resonator parameters determine the external component values required for maximum stability and reliable starting. The load capacitance values used in the oscillator circuit design should include all stray capacitances. The ceramic resonator and components should be mounted as close as possible to the pins for start-up stabilization and to minimize output distortion. An internal start-up resistor of approximately 2 M $\Omega$  is provided between OSC1 and OSC2 for the ceramic resonator-type oscillator as a MOR programmable mask option.



Figure 1-6. Ceramic Resonator Connections with Feedback Resistor Mask Option



Figure 1-7. Ceramic Resonator Connections without Feedback Resistor Mask Option

**GENERAL DESCRIPTION** 

#### **RC Oscillator**

The RC oscillator option is not yet available but will be in the near future. Please consult the factory for availability schedule.

#### External Clock

An external clock from another CMOScompatible device can be connected to the OSC1 input, with the OSC2 input not connected, as shown in Figure 1-8. This configuration is possible regardless of whether the crystal/ceramic resonator or the RC oscillator is enabled.



#### Figure 1-8. External Clock Connections

#### 1.4.3 **RESET**

This pin can be used as an input to reset the MCU to a known start-up state by pulling it to the low state. It functions as an output to indicate that an internal COP watchdog or illegal address reset has

occurred. An internal resistor to  $V_{DD}$  pulls the RESET pin high. When power is removed, the RESET pin has a steering diode to discharge any voltage on the pin to  $V_{DD}$ . The RESET pin contains an internal Schmitt trigger to improve its noise immunity as an input. Refer to **SECTION 5 RESETS**.

#### NOTE

The resistor and steering diode are not available on the MC68HC05J1A (ROM version of this device).

#### 1.4.4 IRQ/V<sub>PP</sub> (Maskable Interrupt Request/Programming Voltage)

This input pin drives the asynchronous IRQ interrupt function of the CPU. The IRQ interrupt function has a MOR bit to provide either only negative edge-sensitive triggering or both negative edge-sensitive and low level-sensitive triggering. If the option is selected to include level-sensitive triggering, the IRQ/V<sub>PP</sub> input requires an external resistor to V<sub>DD</sub> for "wired-OR" operation, if desired. If the IRQ/V<sub>PP</sub> pin is not used, it must be tied to the V<sub>DD</sub> supply. The IRQ/V<sub>PP</sub> pin contains an internal Schmitt trigger as part of its input to improve noise immunity. The voltage on this pin may affect the mode of operation and should not exceed V<sub>DD</sub>. See **SECTION 4 INTERRUPTS** for more details on the interrupts.

**GENERAL DESCRIPTION** 

Each of the PA0 through PA3 I/O pins may be connected as an OR function with the IRQ interrupt function by a MOR bit. This capability allows keyboard scan applications where the transitions or levels on the I/O pins will behave the same as the IRQ/V<sub>PP</sub> pin, except for the inverted phase. The edge or level sensitivity selected by a separate MOR bit for the IRQ/V<sub>PP</sub> pin also applies to the I/O pins OR'ed to create the IRQ signal.

The  $\overline{IRQ}/V_{PP}$  pin is also used for programming voltage when programming the user EPROM and MOR.

#### 1.4.5 PA0 Through PA7

These eight I/O lines comprise port A, a general-purpose bidirectional I/O port. See **7.2 Port A** for more details on port A.

#### 1.4.6 PB0 Through PB5

These six I/O lines comprise port B, a general-purpose bidirectional I/O port. See **7.3 Port B** for more details on port B.

#### SECTION 2 MEMORY

#### 2.1 Introduction

This section describes the organization of the on-chip memory.

#### 2.2 Memory Map

The CPU can address 2 Kbytes of memory space. The EPROM portion of memory holds the program instructions, fixed data, user-defined vectors, and interrupt service routines. The RAM portion of memory holds variable data. I/O registers are memory-mapped so that the CPU can access their locations in the same way that it accesses all other memory locations. See Figure 2-1.

#### 2.3 Input/Output Section

The first 32 addresses of the memory space, \$0000–\$001F, comprise the I/O section. These are the addresses of the I/O control registers, status registers, and data registers.

One I/O register is located outside the 32-byte I/O section: the computer operating properly (COP) register is mapped at \$07F0.

#### 2.4 RAM

The 64 addresses from \$00C0 to \$00FF serve as both the user RAM and the stack RAM. The CPU uses five RAM bytes to save all CPU register contents before processing an interrupt. During a subroutine call, the CPU uses two bytes to store the return address. The stack pointer decrements during pushes and increments during pulls.

#### NOTE

Be careful when using nested subroutines or multiple interrupt levels. The CPU may overwrite data in the RAM during a subroutine or during the interrupt stacking operation.

#### Figure 2-1. Memory Map

\*Writing to bit 0 of \$07F0 clears the COP watchdog.

| _      |          |                 | 1   |                                       | _      |
|--------|----------|-----------------|-----|---------------------------------------|--------|
| \$0000 |          |                 |     | PORT A DATA REGISTER                  | \$0000 |
|        |          |                 |     | PORT B DATA REGISTER                  | \$0001 |
|        | I/O REG  | GISTERS         |     | UNUSED                                | \$0002 |
|        |          | YTES            |     | UNUSED                                | \$0003 |
|        |          |                 |     | PORT A DATA DIRECTION REGISTER        | \$0004 |
|        |          |                 |     | PORT B DATA DIRECTION REGISTER        | \$0005 |
| \$001F |          |                 |     | UNUSED                                | \$0006 |
| \$0020 | LINI     | ISED            | Ν   | UNUSED                                | \$0007 |
|        |          | BYTES           |     | TIMER STATUS AND CONTROL REGISTER     | \$0008 |
| \$00BF |          |                 |     | TIMER COUNTER REGISTER                | \$0009 |
| \$00C0 |          |                 |     | IRQ STATUS AND CONTROL REGISTER       | \$000  |
|        |          | $\uparrow$      |     | UNUSED                                | \$000E |
|        | USER     | STACK           |     | UNUSED                                | \$0000 |
|        | RAM      | RAM<br>64 BYTES |     | UNUSED                                | \$000  |
|        | 64 BYTES |                 |     | UNUSED                                | \$000E |
|        |          | $\downarrow$    |     | UNUSED                                | \$000F |
| \$00FF |          |                 |     | PORT A PULLDOWN REGISTER              | \$0010 |
| \$0100 |          |                 |     | PORT B PULLDOWN REGISTER              | \$0011 |
|        |          | ISED<br>BYTES   |     | UNUSED                                | \$0012 |
| \$02FF | 512 0    | 11123           |     | UNUSED                                | \$0013 |
| \$0300 |          |                 |     | UNUSED                                | \$0014 |
|        |          |                 |     | UNUSED                                | \$0015 |
|        |          |                 |     | UNUSED                                | \$0016 |
|        |          |                 |     | UNUSED                                | \$0017 |
|        |          |                 |     | EPROM PROGRAMMING REGISTER            | \$0018 |
|        |          |                 |     | UNUSED                                | \$0019 |
|        |          |                 |     | UNUSED                                | \$001A |
|        |          |                 |     | UNUSED                                | \$001E |
|        |          | EPROM           |     | UNUSED                                | \$0010 |
|        | 1,232    | BYTES           |     | UNUSED                                | \$001  |
|        |          |                 |     | UNUSED                                | \$001E |
|        |          |                 |     | RESERVED                              | \$001F |
|        |          |                 | N N | RECERCED                              |        |
|        |          |                 |     | COP REGISTER*                         | \$07F0 |
| \$07CF |          |                 |     | MASK OPTION REGISTER                  | \$07F1 |
| \$07D0 |          |                 |     | RESERVED                              | \$07F2 |
|        |          |                 |     | RESERVED                              | \$07F3 |
|        | UNIMPLE  | MENTED          |     | RESERVED                              | \$07F4 |
|        | 30 B'    | YTES            |     | RESERVED                              | \$07F5 |
|        |          |                 |     | RESERVED                              | \$07F6 |
| \$07ED |          |                 |     | RESERVED                              | \$07F7 |
| \$07EE |          |                 |     | TIMER VECTOR (HIGH BYTE)              | \$07F8 |
| \$07EF | IEST ROM | — 2 BYTES       |     | TIMER VECTOR (LOW BYTE)               | \$07F9 |
| \$07F0 |          |                 | í l | EXTERNAL INTERRUPT VECTOR (HIGH BYTE) | \$07FA |
| -      |          |                 |     | EXTERNAL INTERRUPT VECTOR (LOW BYTE)  | \$07FE |
|        |          | ECTORS          |     | SOFTWARE INTERRUPT VECTOR (HIGH BYTE) | \$07FC |
|        |          | ROM)            |     | SOFTWARE INTERRUPT VECTOR (LOW BYTE   | \$07FE |
|        | 16 B'    | YTES            |     | RESET VECTOR (HIGH BYTE)              | \$07FE |
| \$07FF |          |                 |     |                                       | \$07FF |
| \$07FF |          |                 |     | RESET VECTOR (LOW BYTE)               | \$0/F  |

| ADDR           | REGISTER              | READ<br>WRITE | Bit 7 | 6     | 5     | 4      | 3     | 2     | 1     | Bit 0 |
|----------------|-----------------------|---------------|-------|-------|-------|--------|-------|-------|-------|-------|
| \$0000         | PORT A DATA           | READ          | PA7   | PA6   | PA5   | PA4    | PA3   | PA2   | PA1   | PA0   |
| φ0000          | PORT A                | WRITE         |       | 1 70  |       | 1 /14  |       | 1 772 |       |       |
| \$0001         | PORT B DATA           | READ          | 0     | 0     | PB5   | PB4    | PB3   | PB2   | PB1   | PB0   |
| Ψ <b>000</b> 1 | PORT B                | WRITE         |       |       | 105   | TUT    | 105   | I DZ  |       | TBO   |
| \$0002         | UNIMPLEMENTED         | READ          |       |       |       |        |       |       |       |       |
| \$000Z         |                       | WRITE         |       |       |       |        |       |       |       |       |
| \$0003         | UNIMPLEMENTED         | READ          |       |       |       |        |       |       |       |       |
| <b>\$0000</b>  |                       | WRITE         |       |       |       |        |       |       |       |       |
| \$0004         | PORT A DATA DIRECTION | READ          | DDRA7 | DDRA6 | DDRA5 | DDRA4  | DDRA3 | DDRA2 | DDRA1 | DDRA0 |
| <i>φ</i> 0004  | DDRA                  | WRITE         | DURA  | DDRAU | DDRAJ | DDRA4  | DDRAS | DDRAZ | DUNAT | DDRAU |
| \$0005         | PORT B DATA DIRECTION | READ          | 0     | 0     | DDRB5 | DDRB4  | DDRB3 | DDRB2 | DDRB1 | DDRB0 |
| \$0005         | DDRB                  |               |       |       |       | DUND4  | DDRD3 | DDKDZ |       | DDRDU |
| \$0006         | 0006 UNIMPLEMENTED    |               |       |       |       |        |       |       |       |       |
| \$0000         |                       | WRITE         |       |       |       |        |       |       |       |       |
| \$0007         | UNIMPLEMENTED         | READ          |       |       |       |        |       |       |       |       |
| φ000 <i>1</i>  | UNIMPLEMENTED         | WRITE         |       |       |       |        |       |       |       |       |
| \$0008         | TIMER STATUS AND      | READ          | TOF   | RTIF  | TOFE  | DTIF   | 0     | 0     | RT1   | RT0   |
| \$0000         | CONTROL — TSCR        | WRITE         |       |       |       | E RTIE | TOFR  | RTIFR | KII   | KIU   |
| \$0009         | TIMER COUNTER         | READ          | TMR7  | TMR6  | TMR5  | TMR4   | TMR3  | TMR2  | TMR1  | TMR0  |
| φ000 <i>7</i>  | TCR                   | WRITE         |       |       |       |        |       |       |       |       |
| \$000A         | IRQ STATUS AND        | READ          | IRQE  | 0     | 0     | 0      | IRQF  | 0     | 0     | 0     |
| φ000A          | CONTROL — ISCR        | WRITE         |       |       |       | R      |       |       | IRQR  |       |
| \$000B         | UNIMPLEMENTED         | READ          |       |       |       |        |       |       |       |       |
| \$000D         |                       | WRITE         |       |       |       |        |       |       |       |       |
| \$000C         | UNIMPLEMENTED         | READ          |       |       |       |        |       |       |       |       |
| \$000C         |                       | WRITE         |       |       |       |        |       |       |       |       |
| ¢000D          | UNIMPLEMENTED         | READ          |       |       |       |        |       |       |       |       |
| \$000D         | UNIIVIPLEIVIENTED     | WRITE         |       |       |       |        |       |       |       |       |
| ¢000F          |                       | READ          |       |       |       |        |       |       |       |       |
| \$000E         | UNIMPLEMENTED         | WRITE         |       |       |       |        |       |       |       |       |
| ¢000           |                       | READ          |       |       |       |        |       |       |       |       |
| \$000F         | UNIMPLEMENTED         | WRITE         |       |       |       |        |       |       |       |       |

= Unimplemented

R = Reserved for factory test

#### Figure 2-2. I/O Registers \$0000-\$000F

MEMORY

| ADDR           | REGISTER             | READ<br>WRITE | Bit 7 | 6     | 5     | 4     | 3     | 2     | 1        | Bit 0 |
|----------------|----------------------|---------------|-------|-------|-------|-------|-------|-------|----------|-------|
| \$0010         | PORT A PULLDOWN      | READ          |       |       |       |       |       |       |          |       |
| φ <b>0010</b>  | REGISTER — PDRA      | WRITE         | PDIA7 | PDIA6 | PDIA5 | PDIA4 | PDIA3 | PDIA2 | PDIA1    | PDIA0 |
| \$0011         | PORT B PULLDOWN      | READ          |       |       |       |       |       |       |          |       |
| ψυστι          | REGISTER — PDRB      | WRITE         |       |       | PDIB5 | PDIB4 | PDIB3 | PDIB2 | PDIB1    | PDIB0 |
| \$0012         | UNIMPLEMENTED        | READ          |       |       |       |       |       |       |          |       |
| ψ001Z          |                      | WRITE         |       |       |       |       |       |       |          |       |
| \$0013         | UNIMPLEMENTED        | READ          |       |       |       |       |       |       |          |       |
| ψ <b>001</b> 3 |                      | WRITE         |       |       |       |       |       |       |          |       |
| \$0014         | UNIMPLEMENTED        | READ          |       |       |       |       |       |       |          |       |
| <b>φ</b> 0014  |                      | WRITE         |       |       |       |       |       |       |          |       |
| \$0015         | UNIMPLEMENTED        | READ          |       |       |       |       |       |       |          |       |
| \$0015         | \$0015 UNIMPLEMENTED | WRITE         |       |       |       |       |       |       |          |       |
| \$0016 UNIMP   | UNIMPLEMENTED        | READ          |       |       |       |       |       |       |          |       |
| \$0010         |                      |               |       |       |       |       |       |       |          |       |
| ¢0017          |                      | READ          |       |       |       |       |       |       |          |       |
| \$0017         | UNIMPLEMENTED        | WRITE         |       |       |       |       |       |       |          |       |
| \$0018         | EPROM PROGRAMMING    | READ          | 0     | 0     | 0     | 0     | 0     | ELAT  | MPGM     | EPGM  |
| \$0018         | EPROG                | WRITE         |       | R     | R     | R     | R     |       | IVIPGIVI | EPGIN |
| \$0010         |                      | READ          |       |       |       |       |       |       |          |       |
| \$0010         | UNIMPLEMENTED        | WRITE         |       |       |       |       |       |       |          |       |
| ¢001A          |                      | READ          |       |       |       |       |       |       |          |       |
| \$001A         | UNIMPLEMENTED        | WRITE         |       |       |       |       |       |       |          |       |
| ¢001D          |                      | READ          |       |       |       |       |       |       |          |       |
| \$001B         | UNIMPLEMENTED        | WRITE         |       |       |       |       |       |       |          |       |
| ¢0010          |                      | READ          |       |       |       |       |       |       |          |       |
| \$001C         | UNIMPLEMENTED        | WRITE         |       |       |       |       |       |       |          |       |
| #004D          |                      | READ          |       |       |       |       |       |       |          |       |
| \$001D         | UNIMPLEMENTED        | WRITE         |       |       |       |       |       |       |          |       |
| #004F          |                      | READ          |       |       |       |       |       |       |          |       |
| \$001E         | UNIMPLEMENTED        | WRITE         |       |       |       |       |       |       |          |       |
| \$001F         | RESERVED FOR TEST    | READ<br>WRITE | R     | R     | R     | R     | R     | R     | R        | R     |

2

= Unimplemented

R = Reserved for factory test

#### Figure 2-3. I/O Registers \$0010-\$001F

#### 2.5 EPROM

The EPROM is located in three areas of the memory map:

- Addresses \$0300-\$07CF contain 1232 bytes of user EPROM
- Addresses \$07F8–07FF contain 8 bytes of EPROM reserved for user vectors
- Address \$07F1 contains one byte of EPROM for mask option register

#### 2.6 COP Register

A write-only register location is provided at \$07F0 to reset the COP watchdog timer. See **8.4 COP Watchdog**.

SECTION 3 CENTRAL PROCESSING UNIT (CPU)

#### **3.1 Introduction**

This section describes the CPU registers.

#### 3.1.1 CPU Registers

Figure 3-1 shows the five CPU registers. CPU registers are not part of the memory map.



Figure 3-1. Programming Model

#### 3.1.2 Accumulator

The accumulator is a general-purpose 8-bit register. The CPU uses the accumulator to hold operands and results of arithmetic and non-arithmetic operations.



Figure 3-2. Accumulators

#### 3.1.3 Index Register

In the indexed addressing modes, the CPU uses the byte in the index register to determine the conditional address of the operand.

|       | Bit 7 | 6 | 5 | 4         | 3        | 2 | 1 | Bit 0 |
|-------|-------|---|---|-----------|----------|---|---|-------|
| Dogot |       |   |   | Upoffooto | hy Poort |   |   |       |

Reset:

Unaffected by Reset

#### Figure 3-3. Index Register

The 8-bit index register can also serve as a temporary data storage location.

#### 3.1.4 Stack Pointer

The stack pointer is a 16-bit register that contains the address of the next location on the stack. During a reset or after the reset stack pointer (RSP) instruction, the stack pointer is preset to \$00FF. The address in the stack pointer decrements as data is pushed onto the stack and increments as data is pulled from the stack.

|        | Bit 15 | 14 | 13 | 12 | 11 | 10 | 9 | 8 | 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
|--------|--------|----|----|----|----|----|---|---|---|---|---|---|---|---|---|-------|
|        | 0      | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0     |
| Reset: | 0      | 0  | 0  | 0  | 0  | 0  | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1     |

#### Figure 3-4. Stack Pointer

The ten most significant bits of the stack pointer are permanently fixed at 000000011, so the stack pointer produces addresses from \$00C0 to \$00FF. If subroutines and interrupts use more than 64 stack locations, the stack pointer wraps around to address \$00FF and begins writing over the previously stored data. A subroutine uses two stack locations; an interrupt uses five locations.

#### 3.1.5 Program Counter

The program counter is a 16-bit register that contains the address of the next instruction or operand to be fetched. The five most significant bits of the program counter are ignored internally and appear as 00000.

CENTRAL PROCESSING UNIT (CPU)

Normally, the address in the program counter automatically increments to the next sequential memory location every time an instruction or operand is fetched. Jump, branch, and interrupt operations load the program counter with an address other than that of the next sequential location.



Figure 3-5. Program Counter

#### 3.1.6 Condition Code Register

The condition code register is an 8-bit register whose three most significant bits are permanently fixed at 111. The condition code register contains the interrupt mask and four flags that indicate the results of the instruction just executed. The following paragraphs describe the functions of the condition code register.

|        | Bit 7      | 6     | 5 | 4 | 3 | 2 | 1 | Bit 0 |
|--------|------------|-------|---|---|---|---|---|-------|
|        | 1          | 1     | 1 | Н | I | Ν | С | Z     |
| Reset: | 1          | 1     | 1 | U | 1 | U | U | U     |
|        | U = Unaffe | ected |   |   |   |   |   |       |

Figure 3-6. Condition Code Register

#### Half-Carry Flag (H)

The CPU sets the half-carry flag when a carry occurs between bits 3 and 4 of the accumulator during an ADD or ADC operation. The half-carry flag is required for binary-coded decimal (BCD) arithmetic operations.

#### Interrupt Mask (I)

Setting the interrupt mask disables interrupts. If an interrupt request occurs while the interrupt mask is logic zero, the CPU saves the CPU registers on the stack, sets the interrupt mask, and then fetches the interrupt vector. If an interrupt request occurs while the interrupt mask is set, the interrupt request is latched. Normally, the CPU processes the latched interrupt as soon as the interrupt mask is cleared again.

A return from interrupt (RTI) instruction pulls the CPU registers from the stack, restoring the interrupt mask to its cleared state. After any reset, the interrupt mask is set and can be cleared only by a software instruction.

#### Negative Flag (N)

The CPU sets the negative flag when an arithmetic operation, logical operation, or data manipulation produces a negative result.

#### Carry/Borrow Flag (C)

The CPU sets the carry/borrow flag when an addition operation produces a carry out of bit 7 of the accumulator or when a subtraction operation requires a borrow. Some logical operations and data manipulation instructions also clear or set the carry/borrow flag.

#### Zero Flag (Z)

The CPU sets the zero flag when an arithmetic operation, logical operation, or data manipulation produces a result of \$00.

#### 3.2 Arithmetic/Logic Unit (ALU)

The ALU performs the arithmetic and logical operations defined by the instruction set.

The binary arithmetic circuits decode instructions and set up the ALU for the selected operation. Most binary arithmetic is based on the addition algorithm, carrying out subtraction as negative addition. Multiplication is not performed as a discrete operation but as a chain of addition and shift operations within the ALU. The multiply instruction (MUL) requires 11 internal clock cycles to complete this chain of operations.

#### SECTION 4 INTERRUPTS

#### 4.1 Introduction

The MCU can be interrupted four different ways:

- 1. Non-maskable Software Interrupt Instruction (SWI)
- 2. External Asynchronous Interrupt (IRQ)
- 3. Optional External Interrupt via IRQ on PA0 through PA3 (Enabled via MOR PIRQ Bit)
- 4. Internal Timer Interrupt

#### 4.2 CPU Interrupt Processing

Interrupts cause the processor to save register contents on the stack and to set the interrupt mask (I bit) to prevent additional interrupts. Unlike reset, hardware interrupts do not cause the current instruction execution to be halted, but are considered pending until the current instruction is complete.

If interrupts are not masked (I bit in the CCR is clear) and the corresponding interrupt enable bit is set, the processor will proceed with interrupt processing. Otherwise, the next instruction is fetched and executed. If an interrupt occurs the processor completes the current instruction, then stacks the current CPU register states, sets the I bit to inhibit further interrupts, and finally checks the pending hardware interrupts. If more than one interrupt is pending following the stacking operation, the interrupt with the highest vector location, shown in Table 4-1, will be serviced first. The SWI is executed in the same way as any other instruction, regardless of the I-bit state.

When an interrupt is to be processed, the CPU fetches the address of the appropriate interrupt software service routine from the vector table at locations \$07F8 through \$07FF. Refer to Table 4-1.

An RTI instruction is used to signify when the interrupt software service routine is completed. The RTI instruction causes the register contents to be recovered from the stack and normal processing to resume at the next instruction that was to be executed when the interrupt took place. Figure 4-1 shows the sequence of events that occur during interrupt processing.

**INTERRUPTS** 

| Register | Flag Name | Interrupts          | CPU Interrupt | Vector Address |
|----------|-----------|---------------------|---------------|----------------|
| N/A      | N/A       | Reset               | RESET         | \$07FE-\$07FF  |
| N/A      | N/A       | Software            | SWI           | \$07FC-\$07FD  |
| ISCR     | IRQF      | External Interrupt  | IRQ           | \$07FA-\$07FB  |
| TSCR     | TOF       | Timer Overflow      | TIMER         | \$07F8-\$07F9  |
| TSCR     | RTIF      | Real Time Interrupt | TIMER         | \$07F8-\$07F9  |

Table 4-1. Vector Address for Interrupts and Reset





#### 4.3 Reset Interrupt Sequence

The reset function is not in the strictest sense an interrupt; however, it is acted upon in a similar manner as shown in Figure 4-1. A low level input on the RESET pin or an internally generated RST signal causes the program to vector to its starting address which is specified by the contents of memory locations \$07FE and \$07FF. Also, the I bit in the condition code register is set and the MCU is configured to a known state as described in **SECTION 5 RESETS**.

#### 4.4 Software Interrupt (SWI)

The SWI is an executable instruction and a non-maskable interrupt since it is executed regardless of the state of the I bit in the CCR. As with any instruction, interrupts pending during the previous instruction will be serviced before the SWI opcode is fetched. The interrupt service routine address is specified by the contents of memory locations \$07FC and \$07FD.

#### 4.5 Hardware Interrupts

All hardware interrupts except reset are maskable by the I bit in the CCR. If the I bit is set, all hardware interrupts (internal and external) are disabled. Clearing the I bit enables the hardware interrupts. The two types of hardware interrupts are explained in the following paragraphs.

#### 4.6 External Interrupt (IRQ)

The  $\overline{IRQ}/V_{PP}$  pin provides an asynchronous interrupt to the CPU. A block diagram of the IRQ function is shown in Figure 4-2.





INTERRUPTS

The  $\overline{IRQ}/V_{PP}$  pin is one source of an IRQ interrupt. And, the PIRQ MOR bit can also enable the four lower port A pins (PA0 through PA3) to act as other IRQ interrupt sources. These sources are all combined into a single OR'ing function to be latched by the IRQ latch.

Any enabled IRQ interrupt source sets the IRQ latch on the falling edge of the  $\overline{IRQ/V_{PP}}$  pin or on the rising edge of a port A pin. If "edge-only" sensitivity is chosen by the level MOR bit, only the IRQ latch output can activate an IRQF flag which creates a request to the CPU to generate the IRQ interrupt sequence. This makes the IRQ interrupt sensitive to the following cases:

- 1. Falling edge on the  $\overline{IRQ}/V_{PP}$  pin
- 2. Rising edge on any PA0-PA3 pin with port IRQ enabled (via PIRQ).

As long as any one port A IRQ input or the IRQ input remains at the active level, the port A IRQ inputs and the IRQ input are effectively ignored. If level sensitivity is chosen, the active high state of the IRQ input can also activate an IRQF flag which creates an IRQ request to the CPU to generate the IRQ interrupt sequence. This makes the IRQ interrupt sensitive to the following cases:

- 1. Low level on the  $\overline{IRQ}/V_{PP}$  pin
- 2. Falling edge on the  $\overline{IRQ}/V_{PP}$  pin
- 3. High level on any PA0-PA3 pin with port IRQ enabled (via PIRQ)
- 4. Rising edge on any PA0-PA3 pin with IRQ enabled (via PIRQ)

The IRQE enable bit controls whether an active IRQF flag can generate an IRQ interrupt sequence. This interrupt is serviced by the interrupt service routine located at the address specified by the contents of \$07FA and \$07FB.

The IRQ latch is automatically cleared by entering the interrupt service routine. The user may also clear the IRQ latch by writing a logic one to the IRQR reset bit in the ISCR. Also, as long as the output state of the IRQF flag bit is active the CPU will continuously re-enter the IRQ interrupt sequence until the active state is removed or the IRQE enable bit is cleared.

#### 4.6.1 IRQ Status/Control Register (ISCR)

The IRQ interrupt function is controlled by the ISCR located at \$000A. All unused bits in the ISCR will read as logic zeros. The IRQF bit is cleared and IRQE bit is set by reset.



Figure 4-3. IRQ Status and Control Register

- IRQR IRQ Interrupt Reset
  - 1 = Clears the IRQ interrupt and IRQF bit
  - 0 = No effect on IRQ interrupt and IRQF bit
- IRQF IRQ Interrupt Request Flag
  - 1 = External interrupt request pending
  - 0 = No external interrupt request pending
- IRQE IRQ Interrupt Enable
  - 1 = IRQ interrupts enabled IRQF initiates the IRQ interrupt sequence
  - 0 = IRQ interrupts disabled IRQF does not initiate the IRQ interrupt sequence

Execution of the STOP or WAIT instructions causes the IRQE bit to be set to allow the external IRQ to exit these modes. In addition, reset also sets the I bit which masks all interrupt sources.

#### 4.6.2 Optional External Interrupts (PA0 through PA3)

The IRQ interrupt can also be triggered by the inputs on the PA0 through PA3 port pins if enabled by a single MOR bit, PIRQ. If enabled, the lower four bits of port A can activate the IRQ interrupt function, and the interrupt operation will be the same as for inputs to the  $\overline{IRQ}/V_{PP}$  pin. This MOR bit allows all of these input pins to be OR'ed with the input present on the  $\overline{IRQ}/V_{PP}$  pin. All PA0 through PA3 pins must be selected as a group as an additional IRQ interrupt. All the port A interrupt sources are also controlled by the IRQE enable bit.

#### NOTE

The BIH and BIL instructions will apply only to the level on the  $IRQ/V_{PP}$  pin itself, and not to the output of the logic OR function with the PA0 through PA3 pins. The state of the individual port A pins can be checked by reading the appropriate port A pins as inputs.

#### NOTE

If enabled, the PA0 through PA3 pins will cause an IRQ interrupt regardless of whether these pins are configured as inputs or outputs.

#### NOTE

The IRQ pin has an internal Schmitt trigger. The optional external interrupts (PA0–PA3) do not have internal Schmitt triggers.

#### 4.6.3 Timer Interrupts (TIMER)

The TIMER interrupt is generated by the multifunction timer when either a timer overflow or a real time interrupt has occurred as described in **SECTION 8 MULTIFUNCTION TIMER**. The interrupt flags and enable bits for the timer interrupts are located in the timer status and control register (TSCR) located at \$0008. The I bit in the CCR must be clear for the TIMER interrupt to be enabled. Either of these two interrupts will vector to the same interrupt service routine located at the address specified by the contents of memory locations \$07F8 and \$07F9.

**INTERRUPTS** 

#### SECTION 5 RESETS

#### **5.1 Introduction**

The MCU can be reset from four sources: one external input and three internal restart conditions. The RESET pin is an input with a Schmitt trigger as shown in Figure 5-1. It is also an output pin which indicates the occurrence of an internal reset condition. All the peripheral modules which drive external pins will be reset by the synchronous reset signal (RST) coming from a latch, which is synchronized to the PH2 bus clock and set by any of the four reset sources.





#### 5.2 External Reset (RESET)

The RESET pin is the only external source of a reset. This pin is connected to a Schmitt trigger input gate to provide an upper and lower threshold voltage separated by a minimum amount of hysteresis. This external reset occurs whenever the RESET pin is pulled below the lower threshold and remains in reset

until the RESET pin rises above the upper threshold. This active low I/O pin will generate the RST signal and reset the CPU and peripherals.

As shown in Figure 5-1, an internal resistor to  $V_{DD}$  pulls the RESET pin high. When power is removed, the RESET pin has a steering diode to discharge any voltage on the pin to  $V_{DD}$ .

#### NOTE

The resistor and steering diode are not available on the MC68HC05J1A (ROM version of this device).

#### NOTE

Activation of the RST signal is generally referred to as reset of the device, unless otherwise specified.

#### 5.3 Internal Resets

The three internally generated resets are the initial power-on reset function, the COP watchdog timer reset, and the illegal address detector reset.

#### 5.3.1 Power-On Reset (POR)

The internal POR is generated on power-up to allow the clock oscillator to stabilize. The POR will generate the RST signal which will reset the CPU. If any other reset function is active at the end of this delay, the RST signal will remain in the reset condition until the other reset condition(s) end.

A power-on reset occurs when a positive transition is detected on  $V_{DD}$ . The power-on reset function is strictly for power turn-on conditions and should not be used to detect drops in the power supply voltage (brown out). The power-on circuitry provides an oscillator stabilization delay of 4,064 (or 16, if the MOR[SOSCD] bit is set) internal processor bus clock cycles after the oscillator becomes active. If the external RESET pin is low at the end of this delay, the processor remains in the reset state until RESET goes high. The user must ensure that the voltage on  $V_{DD}$  has risen to a point where the MCU can operate properly by the time the 4,064 bus cycles have elapsed. If there is doubt, the external RESET pin should remain low until the voltage on  $V_{DD}$  has reached the specified minimum operating voltage.

#### 5.3.2 Computer Operating Properly Reset (COPR)

The internal COPR reset is generated automatically (if the COP is enabled) by a time-out of the COP watchdog timer. This time-out occurs if the counter in the COP watchdog timer is not reset (cleared) within a specific time by a software reset sequence. The COP watchdog timer can be enabled by the COPEN MOR bit. Refer to **8.4 COP Watchdog** for more information on this time-out feature.

The COPR will generate the RST signal which will reset the CPU and other peripherals. If the voltage at the  $\overline{IRQ}/V_{PP}$  pin is in the normal operating range (V<sub>SS</sub> to V<sub>DD</sub>), the MCU will enter single-chip mode when the COPR signal ends. If any other reset function is active at the end of the COPR reset signal, the RST signal will remain in the reset condition until the other reset condition(s) end.

#### 5.3.3 Illegal Address Reset (ILADR)

The internal ILADR reset is generated when an instruction opcode fetch occurs from an address which is not implemented in the RAM (00CO-00FF), internal test ROM (07EE-07EF), or EPROM (000-07CF, 07F8-07FF). The ILADR will generate the RST signal which will reset the CPU and other peripherals. If the voltage at the IRQ/V<sub>PP</sub> pin is in the normal operating range (V<sub>SS</sub> to V<sub>DD</sub>), the MCU will enter user mode when the illegal address reset signal ends. If any other reset function is active at the end of the ILADR reset signal, the RST signal will remain in the reset condition until the other reset condition(s) end.



- Internal timing signal and bus information not available externally.
   OSC1 line is not meant to represent frequency. It is only used to represent time.
   The next rising edge of the PH2 clock following the rising edge of RESET initiates the reset sequence.

# Figure 5-2. Power-On Reset and External Timing Diagram

#### SECTION 6 LOW POWER MODES

#### 6.1 Introduction

In user mode the MC68HC705J1A is capable of running in one of several low-power operational modes. The WAIT and STOP instructions provide two modes that reduce the power required for the MCU by stopping various internal clocks and/or the on-chip oscillator. The STOP and WAIT instructions are not normally used if the COP watchdog timer is enabled. A MOR bit is provided to convert the STOP instruction to a halt, which is a wait-like instruction that does not halt the COP watchdog timer but has a recovery delay. The flow of the stop, halt, and wait modes are shown in Figure 6-1.

#### 6.2 STOP Instruction

The STOP instruction can result in one of two modes of operation depending on the SWAIT bit in the MOR. One option is for the STOP instruction to operate like the stop in normal MC68HC05 Family members and place the device in the stop mode. The other option is for the STOP instruction to behave like a WAIT instruction (except that the restart time will involve a delay) and place the device in the halt mode.

#### 6.2.1 Stop Mode

Execution of the STOP instruction while enabled (as chosen by the MOR) places the MCU in its lowest power consumption mode. In the stop mode the internal oscillator is turned off, halting *all* internal processing, including the COP watchdog timer.

When the CPU enters stop mode, the interrupt flags (TOF and RTIF) and the interrupt enable bits (TOFE and RTIE) in the TSCR are cleared by internal hardware to remove any pending timer interrupt requests and to disable any further timer interrupts. Execution of the STOP instruction automatically clears the I bit in the condition code register and sets the IRQE enable bit in the IRQ status/control register so that the IRQ external interrupt is enabled. All other registers, including the other bits in the TSCR, and memory remain unaltered. All input/output lines remain unchanged.



Figure 6-1. Stop/Halt/Wait Flowcharts

The MCU can be brought out of the stop mode only by an IRQ external interrupt or an externally generated reset. When exiting the stop mode the internal oscillator will resume after a 4,064 (or 16, depending upon the MOR[SOSCD] bit) internal processor clock cycle oscillator stabilization delay.

LOW POWER MODES

#### NOTE

Execution of the STOP instruction with the SWAIT MOR bit cleared will cause the oscillator to stop and therefore disable the COP watchdog timer. If the COP watchdog timer is to be used, the stop mode should be changed to the halt mode by setting the appropriate MOR bit. See **6.5 COP Watchdog Timer Considerations** for more details.

#### 6.2.2 Halt Mode

Execution of the STOP instruction while SWAIT in the MOR is enabled places the MCU in a low-power mode, which consumes more power than the stop mode. In the halt mode the internal processor clock is halted, suspending all processor and internal bus activity. Internal timer clocks remain active, permitting interrupts to be generated from the timer or a reset to be generated from the COP watchdog timer. Execution of the STOP instruction automatically clears the I bit in the condition code register and sets the IRQE enable bit in the IRQ status/control register so that the IRQ external interrupt is enabled. All other registers, memory, and input/output lines remain in their previous states.

The halt mode may be exited when a timer interrupt, an external IRQ, or external reset occurs. When exiting the halt mode the internal processor clock will resume after a delay of one to 4,064 (or 16, depending upon the MOR[SOSCD] bit) internal processor clock cycles. This varied delay time is due to the halt mode testing the oscillator stabilization delay timer (a feature of the stop mode) which has been free-running (a feature of the wait mode).

#### NOTE

The halt mode is not intended for normal use, but is provided to keep the COP watchdog timer active should the STOP instruction opcode be inadvertently executed.

#### 6.3 WAIT Instruction

The WAIT instruction places the MCU in a low-power mode, which consumes less power than the run mode. In the wait mode the internal processor clock is halted, suspending all processor and internal bus activity. Internal timer clocks remain active, permitting interrupts to be generated from the timer or a reset to be generated from the COP watchdog timer. Execution of the WAIT instruction automatically clears the I bit in the condition code register and sets the IRQE enable bit in the IRQ status/control register so that the IRQ external interrupt is enabled. All other registers, memory, and input/output lines remain in their previous states.

If timer interrupts are enabled, a timer interrupt will cause the processor to exit the wait mode and resume normal operation. The timer may be used to generate a periodic exit from the wait mode. The wait mode may also be exited when an external IRQ or reset occurs.

#### 6.4 Data-Retention Mode

The contents of RAM and CPU registers are retained at supply voltages as low as 2.0 Vdc. This is called the data-retention mode where the data is held, but the device is not guaranteed to operate. The RESET pin must be held low during data-retention mode. More power is consumed in data-retention mode than in stop mode as internal clocks remain running.

#### 6.5 COP Watchdog Timer Considerations

If the COP watchdog timer is selected by the COP MOR bit, any execution of the STOP instruction (either intentional or inadvertent due to the CPU being disturbed) will cause the oscillator to halt and prevent the COP watchdog timer from timing out unless the stop to halt conversion feature is enabled. Therefore, it is recommended that the STOP instruction should be **converted** to a HALT operation if the COP watchdog timer is enabled (for additional information see **9.4.2 Mask Option Register (MOR)**).

If the COP watchdog timer is selected by the COP MOR bit, the COP will reset the MCU when it times out. Therefore, it is recommended that the COP watchdog should be **disabled** for a system that must have intentional uses of the wait mode for periods longer than the COP time-out period.

The recommended interactions and considerations for the COP watchdog timer, STOP instruction, and WAIT instruction are summarized in Table 6-1.

| IF the following                | conditions exist:                          | THEN the                                 |
|---------------------------------|--------------------------------------------|------------------------------------------|
| STOP Instruction                | WAIT Time                                  | COP Watchdog Timer should be as follows: |
| Converted to HALT<br>by MOR bit | WAIT Time <b>Less Than</b><br>COP Time-Out | Enable or Disable COP<br>by MOR Bit      |
| Converted to HALT<br>by MOR bit | WAIT Time <b>More Than</b><br>COP Time-Out | Disable COP<br>by MOR Bit                |
| Acts as STOP                    | Any Length<br>WAIT Time                    | Disable COP<br>by MOR Bit                |

#### Table 6-1. COP Watchdog Timer Recommendations

6

#### SECTION 7 INPUT/OUTPUT PORTS

#### 7.1 Introduction

In the user mode, there are 14 bidirectional I/O lines arranged as one 8-bit I/O port (port A) and one 6-bit I/O port (port B). The individual bits in these ports are programmable as either inputs or outputs under software control by the data direction registers (DDRs). Also, if enabled by a single MOR bit (PDI) all port A and port B I/O pins may have individual software programmable pulldown devices. Some port A (PA4-PA7) pins also have the additional properties of sinking higher current and the others (PA0-PA3) may function as additional IRQ interrupt input sources.

#### 7.2 Port A

Port A is an 8-bit bidirectional port which shares four of its pins with the IRQ interrupt system as shown in Figure 7-1. Each port A pin is controlled by the corresponding bits in a data direction register, a data register, and a pulldown register. The port A data register is located at address \$0000. The port A data direction register (DDRA) is located at address \$0004. The port A pulldown register (PDRA) is located at address \$0010. Reset clears the DDRA and the PDRA. The port A data register is unaffected by reset.





**INPUT/OUTPUT PORTS** 

# 7.2.1 Port A Data Register

Each port A I/O pin has a corresponding bit in the port A data register. When a port A pin is programmed as an output, the state of the corresponding data register bit determines the state of the output pin. When a port A pin is programmed as an input, any read of the port A data register will return the logic state of the corresponding I/O pin. The port A data register is unaffected by reset.

## 7.2.2 Port A Data Direction Register

Each port A I/O pin may be programmed as an input by clearing the corresponding bit in the DDRA or programmed as an output by setting the corresponding bit in the DDRA. The DDRA can be accessed at address \$0004. The DDRA is cleared by reset.

## 7.2.3 Port A Pulldown Register

All port A I/O pins may have software programmable pulldown devices enabled or disabled by the applicable MOR bit (PDI). If PDI is cleared, the pulldown is activated whenever the corresponding bit in the PDRA is clear. If the PDRA bit is set or the MOR PDI bit is set, the pulldown will be disabled. A pulldown on an I/O pin is activated only if the I/O pin is programmed as an input.

The PDRA is a write-only register. Any reads of location \$0010 will return undefined results. Since reset clears both the DDRA and the PDRA, all pins will initialize as inputs with the pulldown devices active (if enabled by PDI MOR bit being cleared).

# NOTE

Read-modify-write instructions should NOT be executed on registers with write-only bits.

# 7.2.4 Port A LED Drive Capability

The outputs for the upper four bits of port A (PA4, PA5, PA6, and PA7) are capable of sinking approximately 10 mA of current to  $V_{SS}$ .

# 7.2.5 Port A I/O Pin Interrupts

The inputs for the lower four bits of port A (PA0, PA1, PA2, and PA3) may be connected to the IRQ input of the CPU if enabled by the MOR bit, PIRQ. When connected as an alternate source of an IRQ interrupt, the port A input pins will behave the same as the  $\overline{IRQ}/V_{PP}$  pin itself, except that their active state is a logic

one or a rising edge. The  $\overline{IRQ}/V_{PP}$  pin has an active state that is a logic zero or a falling edge.

If MOR bits for both level sensitivity and port A interrupts are programmed to a logic one, the presence of a logic one or occurrence of a rising edge on any one of the lower four port A pins will cause an IRQ interrupt request. If the edge-only sensitivity is selected, the occurrence of a rising edge on any one of the lower four port A pins will cause an IRQ interrupt request. As long as any one port A IRQ input or the IRQ input remains at the active level, the port A IRQ inputs and the IRQ input are effectively ignored.

#### NOTE

<u>The</u> BIH and BIL instructions will apply only to the level on the IRQ/V<sub>PP</sub> pin itself, and not to the internal IRQ input to the CPU. Therefore BIH and BIL cannot be used to test the state of the lower four port A input pins as a group.

#### 7.3 Port B

Port B is a 6-bit bidirectional port which functions as shown in Figure 7-2. Each port B pin is controlled by the corresponding bits in a data direction register, a data register, and a pulldown register. The port B data register is located at address \$0001. The port B data direction register (DDRB) is located at address \$0005. The port B pulldown register (PDRB) is located at address \$0011. Reset clears the DDRB and the PDRB. The port B data register is unaffected by reset.



Figure 7-2. Port B I/O Circuitry

# 7.3.1 Port B Data Register

All port B I/O pins have a corresponding bit in the port B data register. When a port B pin is programmed as an output, the state of the corresponding data register bit determines the state of the output pin. When a port B pin is programmed as an input, any read of the port B data register will return the logic state of the corresponding I/O pin. The port B data register is unaffected by reset. Unused bits 6 and 7 will always read as logic zeros, and any write to these bits will be ignored. The port B data register is unaffected by reset.

#### 7.3.2 Port B Data Direction Register

Port B I/O pins may be programmed as an input by clearing the corresponding bit in the DDRB or programmed as an output by setting the corresponding bit in the DDRB. The DDRB can be accessed at address \$0005. Unused bits 6 and 7 will always read as logic zeros, and any write to these bits will be ignored. The DDRB is cleared by reset.

## 7.3.3 Port B Pulldown Register

All port B I/O pins may have software programmable pulldown devices enabled by PDI in the MOR. If the pulldown inhibit MOR bit is cleared, the pulldown is activated whenever the corresponding bit in the PDRB is clear. A pulldown on an I/O pin is activated only if the I/O pin is programmed as an input.

The PDRB is a write-only register. Any reads of location \$0011 will return undefined results. Since reset clears both the DDRB and the PDRB, all pins will initialize as inputs with the pulldown devices active (if MOR bit, PDI is cleared).

#### NOTE

Read-modify-write instructions should NOT be executed on registers with write-only bits.

#### 7.4 I/O Port Programming

All I/O pins can be programmed as inputs or outputs, with or without pulldown devices.

#### 7.4.1 Pin Data Direction

The direction of a pin is determined by the state of its corresponding bit in the associated port data direction register (DDR). A pin is configured as an output if its

**INPUT/OUTPUT PORTS** 

corresponding DDR bit is set to a logic one. A pin is configured as an input if its corresponding DDR bit is cleared to a logic zero.

The data direction bits DDRB0 through DDRB5 and DDRA0 through DDRA7 are read/write bits which can be manipulated with read-modify-write instructions. At power-on or reset, all DDRs are cleared which configures all port pins as inputs. If the pulldown inhibit MOR bit is cleared, all pins will initially power up with their software programmable pulldowns enabled.

#### 7.4.2 Output Pin

When an I/O pin is programmed as an output pin, the state of the corresponding data register bit will determine the state of the pin. The state of the data register bits can be altered by writing to address \$0000 for port A and address \$0001 for port B. Reads of the corresponding data register bit at address \$0000 or \$0001 will return the state of the data register bit (not the state of the I/O pin itself). Therefore, bit manipulation is possible on all pins programmed as outputs.

#### 7.4.3 Input Pin

When an I/O pin is programmed as an input pin, the state of the pin can be determined by reading the corresponding data register bit. Any writes to the corresponding data register bit for an input pin will be ignored.

If the corresponding bit in the pulldown register is clear (and the PDI MOR bit is cleared) the input pin will also have an activated pulldown device. Since the pulldown register bits are write-only, bit manipulation should not be used on these register bits.

#### 7.4.4 I/O Pin Transitions

A glitch can be generated on an I/O pin when changing it from an input to an output unless the data register is first pre-conditioned to the desired state before changing the corresponding DDR bit from a zero to a one.

#### 7.4.5 I/O Pin Truth Tables

Every pin on port A and port B may be programmed as an input or an output under software control as shown in Table 7-1 and Table 7-2. All port I/O pins may also have software programmable pulldown devices if selected by the appropriate MOR bit.

| DDRA | I/O Pin<br>Mode |      | ccesses to<br>RA at \$0010 | Accesses to<br>DDRA @ \$0004 |         | s to Data<br>@ \$0000 |
|------|-----------------|------|----------------------------|------------------------------|---------|-----------------------|
|      | WOde            | Read | Write                      | Read/Write                   | Read    | Write                 |
| 0    | In, Hi-Z        | U    | PDRA0-PDRA7                | DDRA0-DDRA7                  | I/O Pin | *                     |
| 1    | Out             | U    | PDRA0-PDRA7                | DDRA0-DDRA7                  | PA0–PA7 | PA0–PA7               |

# Table 7-1. Port A I/O Pin Functions

Note: U is undefined

\*Does not affect input, but stored to data register

# Table 7-2. Port A I/O Pin Functions

| DDRA | I/O Pin<br>Mode |      | cesses to<br>RB at \$0011 | Accesses to<br>DDRB @ \$0005 | Accesse<br>Register | s to Data<br>@ \$0001 |
|------|-----------------|------|---------------------------|------------------------------|---------------------|-----------------------|
|      | Mode            | Read | Write                     | Read/Write                   | Read                | Write                 |
| 0    | In, Hi-Z        | U    | PDRB0-PDRB5               | DDRB0-DDRB5                  | I/O Pin             | *                     |
| 1    | Out             | U    | PDRB0-PDRB5               | DDRB0-DDRB5                  | PA0–PA5             | PA0–PA5               |

Note: U is undefined

\*Does not affect input, but stored to data register

#### SECTION 8 MULTIFUNCTION TIMER

#### 8.1 Introduction

This section describes the operation of the multifunction timer and the COP watchdog. Figure 8-0? shows the organization of the timer subsystem.





MULTIFUNCTION TIMER

# 8.2 Timer Status and Control Register (TSCR)

The read/write timer status and control register contains the following bits:

- Timer Interrupt Enable Bits
- Timer Interrupt Flags
- Timer Interrupt Flag Reset Bits
- Timer Interrupt Rate Select Bits





#### TOF — Timer Overflow Flag

This read-only flag becomes set when the first eight stages of the counter roll over from \$FF to \$00. TOF generates a timer overflow interrupt request if TOIE is also set. Clear TOF by writing a logic one to the TOFR bit. Writing to TOF has no effect. Reset clears TOF.

RTIF — Real-Time Interrupt Flag

This read-only flag becomes set when the selected RTI output becomes active. RTIF generates a real-time interrupt request if RTIE is also set. Clear RTIF by writing a logic one to the RTIFR bit. Writing to RTIF has no effect. Reset clears RTIF.

#### TOIE — Timer Overflow Interrupt Enable

This read/write bit enables timer overflow interrupts.

- 1 = Timer overflow interrupts enabled
- 0 = Timer overflow interrupts disabled
- RTIE Real-Time Interrupt Enable

This read/write bit enables real-time interrupts

- 1 = Real-time interrupts enabled
- 0 = Real-time interrupts disabled
- TOFR Timer Overflow Flag Reset

Writing a logic one to this write-only bit clears the TOF bit. TOFR always reads as logic zero. Reset clears TOFR.

RTIFR — Real-Time Interrupt Flag Reset

Writing a logic one to this write-only bit clears the RTIF bit. RTIFR always reads as logic zero. Reset clears RTIFR.

RT1 and RT0 — Real-Time Interrupt Select Bits 1 and 0

These read/write bits select one of four real-time interrupt rates, as shown in Table 8-1. Because the selected RTI output drives the COP watchdog, changing the real-time interrupt rate also changes the counting rate of the COP watchdog. Reset sets RT1 and RT0.

# NOTE

Changing RT1 and RT0 when a COP timeout is imminent or uncertain may cause a real-time interrupt request to be missed or an additional real-time interrupt request to be generated. Clear the COP timer just before changing RT1 and RT0.

| RT1:RT0 | RTI Rate                          | RTI Period<br>(f <sub>OP</sub> = 2 MHz) | COP Timeout Period<br>(-0/+1 RTI Period) | Minimum COP Timeout<br>Period (f <sub>OP</sub> = 2 MHz) |
|---------|-----------------------------------|-----------------------------------------|------------------------------------------|---------------------------------------------------------|
| 0 0     | $f_{OP} \div 2^{14}$              | 8.2 ms                                  | $7 \times RTI$ Period                    | 57.3 ms                                                 |
| 0 1     | $f_{OP} \div 2^{15}$              | 16.4 ms                                 | $7 \times RTI$ Period                    | 114.6 ms                                                |
| 1 0     | f <sub>OP</sub> ÷ 2 <sup>16</sup> | 32.8 ms                                 | $7 \times RTI$ Period                    | 229.3 ms                                                |
| 11      | $f_{OP} \div 2^{17}$              | 65.5 ms                                 | $7 \times RTI$ Period                    | 458.7 ms                                                |

# Table 8-1. Real-Time Interrupt Rate Selection

# 8.3 Timer Counter Register (TCNTR)

A 15-stage ripple counter is the core of the timer. The value of the first eight stages is readable at any time from the read-only timer counter register shown in Table 8-1?.



Figure 8-3. Timer Counter Register

Power on clears the entire counter chain and begins clocking the counter. After 4,064 (or 16, if the MOR[SOSCD] bit is set) cycles, the power-on reset circuit is released, clearing the counter again and allowing the MCU to come out of reset.

A timer overflow function at the eighth counter stage allows a timer interrupt every 1,024 internal clock cycles.

#### 8.4 COP Watchdog

Four counter stages at the end of the timer make up the MOR selectable computer operating properly (COP) watchdog. See Figure 8-1?. The COP watchdog is a software error detection system that automatically times out and resets the MCU if not cleared periodically by a program sequence. Writing a logic zero to bit 0 of the COP register clears the COP watchdog and prevents a COP reset.



#### COPC — COP Clear

This write-only bit resets the COP watchdog. Reading address \$07F0 returns undefined results.

#### NOTE

The STOP instruction turns off the COP watchdog. In applications that depend on the COP watchdog, the STOP instruction can be disabled via the SWAIT bit in the MOR.

8-4

#### SECTION 9 USER EPROM

#### 9.1 Introduction

The user EPROM consists of 1232 bytes of user EPROM from \$0300 to \$07CF and 8 bytes of user vectors EPROM from \$07F8 to \$07FF.

The mask option register (MOR) is an additional EPROM byte provided to control various functions as described in **9.4.2 Mask Option Register (MOR)**.

#### 9.2 EPROM Erasing

The MC68HC705J1A can be erased by the exposure to a high-intensity ultraviolet (UV) light with a wavelength of 2537 angstroms. The recommended dose (UV intensity multiplied by exposure time) is 15 Ws/cm<sup>2</sup>. UV lamps without shortwave filters should be used, and the EPROM device should be positioned about one inch from the UV lamp.

#### NOTE

Unlike many commercial EPROMs, an erased EPROM byte will read as \$00. All unused locations should be programmed as logic zeros.

#### 9.3 EPROM Programming

The M68HC705JICS board is available from Motorola for programming the on-chip EPROM and the MOR.

#### 9.4 EPROM Registers

Two registers are associated with the EPROM: the EPROM programming register (EPROG) and the mask option register (MOR). The EPROG register controls the actual programming of the EPROM bytes and the MOR. The MOR register controls six mask options found on the ROM version of this MCU (MC68HC05J1A) with an additional option for EPROM array security and for short oscillator recovery delay.

# 9.4.1 EPROM Programming Register (EPROG)

This register is used to program the EPROM array and the MOR. Only the ELAT, MPGM, and EPGM bits are available in user mode. Figure 9-1 shows the location of each bit in the EPROG register and the state of these bits coming out of reset. All the bits in the EPROG register are cleared by reset.



Figure 9-1. EPROM Programming Register

EPGM — EPROM Program Control

The EPGM bit cannot be set unless the ELAT bit is already set. Whenever the ELAT bit is cleared the EPGM bit is also cleared. Both the EPGM and the ELAT bit cannot be set using the same write instruction. Any attempt to set both the EPGM and ELAT bit on the same write instruction cycle will result in the ELAT bit being set and the EPGM bit being cleared. The EPGM bit is a read-write bit and can be read at any time. The EPGM bit is cleared by reset.

1 = Programming voltage ( $\overline{IRQ}/V_{PP}$  pin) is applied to the EPROM array

0 = Programming voltage ( $\overline{IRQ}/V_{PP}$  pin) is not applied to the EPROM array

#### MPGM — MOR Program Control

The MPGM bit is cleared by reset. See **Section 9.5** for MOR programming information.

- 1 = Programming voltage ( $\overline{IRQ}/V_{PP}$  pin) is applied to the MOR
- 0 = Programming voltage ( $\overline{IRQ}/V_{PP}$  pin) is not applied to the MOR

ELAT — EPROM Latch Control

Whenever the ELAT bit is cleared the EPGM bit is also cleared. Both the EPGM and the ELAT bits cannot be set using the same write instruction. Any attempt to set both the EPGM and ELAT bit on the same write instruction cycle will result in the ELAT bit being set and the EPGM bit being cleared. The ELAT bit is a read-write bit and can be read at any time. The ELAT bit is cleared by reset.

- 1 = EPROM address and data bus configured for programming to the array. The address and data bus are latched in the EPROM array when a subsequent write to the array is made. Data in the EPROM array cannot be read
- 0 = EPROM address and data bus configured for normal reading of data from the array

To program a byte of EPROM, manipulate the EPROG register as follows:

- 1. Set the ELAT bit in the EPROG register
- 2. Write the desired data to the desired EPROM address
- Set the EPGM bit in the EPROG register for the specified programming time <sup>(t</sup><sub>EPGM</sub>)
- 4. Clear the ELAT and EPGM bits in the EPROG register

# 9.4.2 Mask Option Register (MOR)

The mask option register (MOR) is a byte of EPROM used to enable or disable six of the features controlled by mask options on the MC68HC05J1A (a ROM version of the MC68HC705J1A) in addition to EPROM security and short oscillator delay options. This structure does not contain any latches which may become corrupted by erratic supply voltages or CPU operation. The programmable options on the MC68HC705J1A are:

- 1. COP Watchdog Timer (Enable or Disable)
- 2. IRQ Triggering (Edge- or Edge- and Level-Sensitive)
- 3. Port A IRQ Interrupts (Enable or Disable)
- 4. Port Pulldown Resistors (Enable or Disable)
- 5. STOP Instruction Mode (Stop Mode or Halt Mode)
- 6. Crystal Oscillator Parallel Resistor (Enable or Disable)
- 7. EPROM Security (Enable or Disable)
- 8. Short Oscillator Delay Counter (Enable or Disable)





# COPEN — COP Watchdog Enable

- 1 = COP watchdog enabled. The COP will reset the MCU if the time-out period is reached before the COP watchdog timer is cleared by the application software and the voltage applied to the  $\overline{IRQ}/V_{PP}$  pin is between  $V_{SS}$  and  $V_{DD}$ . Clearing the COP bit will disable the COP watchdog timer regardless of the voltage applied to the  $\overline{IRQ}/V_{PP}$  pin
- 0 = COP Watchdog disabled

LEVEL — IRQ Edge Sensitivity

- 1 =  $\overline{IRQ}/V_{PP}$  pin sensitive to both the falling edge and the logic low level of the input signal on the  $\overline{IRQ}/V_{PP}$  pin
- $0 = \overline{IRQ}/V_{PP}$  pin will only be sensitive to the falling edge of the signal applied to the IRQ/V<sub>PP</sub> pin

PIRQ — Port A IRQ Interrupt Function

- 1 = Port A pins PA0-PA3 can function as IRQ interrupts
- 0 = Port A IRQ interrupts disabled
- SWPDI Port Pulldown Inhibit
  - 1 = Pulldowns inhibited regardless of the state of the software selectable pulldown registers
  - 0 = Port pins can have software selectable input pulldowns

SWAIT — STOP Instruction Mode

1 = The STOP instruction will initiate halt mode

0 = The STOP instruction will intiate stop mode

OSCRES — Oscillator Parallel Resistor

1 = Optional 2 M $\Omega$  parallel resistor in the oscillator circuit is enabled

0 = Optional oscillator resistor is disabled

# NOTE

The optional oscillator resistor is NOT recommended for devices that use the RC oscillator. For such devices, this bit should be programmed to a logic zero.

EPMSEC — EPROM Security Enable

- 1 = Access to the EPROM array in non-user modes is denied
- 0 = Access to the EPROM array in non-user modes is possible

SOSCD — Short Oscillator Delay Enable

This bit is provided to control the oscillator stabilization counter.

- 1 = POR/STOP recovery delay is 16 CPU cycles
- 0 = POR/STOP recovery delay is 4,064 CPU cycles

#### CAUTION

The 16-cycle delay option will work properly in devices with the RC oscillator. Check crystal/ceramic resonator specifications carefully before using this option with a crystal or ceramic resonator.

#### NOTE

This option is NOT available as a mask option on the MC68HC05J1A (ROM version of this device).

#### 9.5 MOR Programming

To program any bits in the MOR, the desired bit states must be written to the MOR and then the MPGM bit in the EPROG must be used. The following sequence will program the MOR:

- 1. Write the desired data to the MOR.
- 2. Set the MPGM bit in the EPROG.
- 3. Wait for the programming time  $(t_{MPGM})$ .
- 4. Clear the MPGM bit in the EPROG.

Once the MOR bits have been programmed, some of the options may experience glitches in operation following removal of the programming voltage. It is recommended that the part be reset before trying to verify the contents of the user EPROM or the MOR itself.

# SECTION 10 INSTRUCTION SET

#### **10.1 Introduction**

This section describes the M68HC705J1A addressing modes and instruction types.

#### **10.2 Addressing Modes**

The CPU uses eight addressing modes for flexibility in accessing data. The addressing modes define the manner in which the CPU finds the data required to execute an instruction. The eight addressing modes are the following:

- Inherent
- Immediate
- Direct
- Extended
- Indexed, no offset
- Indexed, 8-bit offset
- Indexed, 16-bit offset
- Relative

#### 10.2.1 Inherent

Inherent instructions are those that have no operand, such as return from interrupt (RTI) and stop (STOP). Some of the inherent instructions act on data in the CPU registers, such as set carry flag (SEC) and increment accumulator (INCA). Inherent instructions require no memory address and are one byte long.

#### 10.2.2 Immediate

Immediate instructions are those that contain a value to be used in an operation with the value in the accumulator or index register. Immediate instructions require no memory address and are two bytes long. The opcode is the first byte, and the immediate data value is the second byte.

**INSTRUCTION SET** 

#### 10.2.3 Direct

Direct instructions can access any of the first 256 memory addresses with two bytes. The first byte is the opcode, and the second is the low byte of the operand address. In direct addressing, the CPU automatically uses \$00 as the high byte of the operand address. BRSET and BRCLR are three-byte instructions that use direct addressing to access the operand and relative addressing to specify a branch destination.

#### 10.2.4 Extended

Extended instructions use only three bytes to access any address in memory. The first byte is the opcode; the second and third bytes are the high and low bytes of the operand address.

When using the Motorola assembler, the programmer does not need to specify whether an instruction is direct or extended. The assembler automatically selects the shortest form of the instruction.

## 10.2.5 Indexed, No Offset

Indexed instructions with no offset are one-byte instructions that can access data with variable addresses within the first 256 memory locations. The index register contains the low byte of the conditional address of the operand. The CPU automatically uses \$00 as the high byte, so these instructions can address locations \$0000–\$00FF.

Indexed, no offset instructions are often used to move a pointer through a table or to hold the address of a frequently used RAM or I/O location.

# 10.2.6 Indexed, 8-Bit Offset

Indexed, 8-bit offset instructions are two-byte instructions that can access data with variable addresses within the first 511 memory locations. The CPU adds the unsigned byte in the index register to the unsigned byte following the opcode. The sum is the conditional address of the operand. These instructions can access locations \$0000–\$01FE.

Indexed 8-bit offset instructions are useful for selecting the kth element in an n-element table. The table can begin anywhere within the first 256 memory locations and could extend as far as location 510 (\$01FE). The k value is typically in the index register, and the address of the beginning of the table is in the byte following the opcode.

#### 10.2.7 Indexed, 16-Bit Offset

Indexed, 16-bit offset instructions are three-byte instructions that can access data with variable addresses at any location in memory. The CPU adds the unsigned byte in the index register to the two unsigned bytes following the opcode. The sum is the conditional address of the operand. The first byte after the opcode is the high byte of the 16-bit offset; the second byte is the low byte of the offset. These instructions can address any location in memory.

Indexed, 16-bit offset instructions are useful for selecting the kth element in an n-element table anywhere in memory.

As with direct and extended addressing the Motorola assembler determines the shortest form of indexed addressing.

#### 10.2.8 Relative

Relative addressing is only for branch instructions. If the branch condition is true, the CPU finds the conditional branch destination by adding the signed byte following the opcode to the contents of the program counter. If the branch condition is not true, the CPU goes to the next instruction. The offset is a signed, two's complement byte that gives a branching range of -128 to +127 bytes from the address of the next location after the branch instruction.

When using the Motorola assembler, the programmer does not need to calculate the offset, because the assembler determines the proper offset and verifies that it is within the span of the branch.

#### **10.3 Instruction Types**

The MCU instructions fall into the following five categories:

- Register/Memory Instructions
- Read-Modify-Write Instructions
- Jump/Branch Instructions
- Bit Manipulation Instructions
- Control Instructions

#### 10.3.1 Register/Memory Instructions

Most of these instructions use two operands. One operand is in either the accumulator or the index register. The CPU finds the other operand in memory. Table 10-1 lists the register/memory instructions.

| Instruction                                         | Mnemonic |
|-----------------------------------------------------|----------|
| Add Memory Byte and Carry Bit to Accumulator        | ADC      |
| Add Memory Byte to Accumulator                      | ADD      |
| AND Memory Byte with Accumulator                    | AND      |
| Bit Test Accumulator                                | BIT      |
| Compare Accumulator                                 | CMP      |
| Compare Index Register with Memory Byte             | СРХ      |
| EXCLUSIVE OR Accumulator with Memory Byte           | EOR      |
| Load Accumulator with Memory Byte                   | LDA      |
| Load Index Register with Memory Byte                | LDX      |
| Multiply                                            | MUL      |
| OR Accumulator with Memory Byte                     | ORA      |
| Subtract Memory Byte and Carry Bit from Accumulator | SBC      |
| Store Accumulator in Memory                         | STA      |
| Store Index Register in Memory                      | STX      |
| Subtract Memory Byte from Accumulator               | SUB      |

Table 10-1. Register/Memory Instructions

#### 10.3.2 Read-Modify-Write Instructions

These instructions read a memory location or a register, modify its contents, and write the modified value back to the memory location or to the register. The test for negative or zero instruction (TST) is an exception to the read-modify-write sequence because it does not write a replacement value. Table 10-2 lists the read-modify-write instructions.

| Instruction                    | Mnemonic |
|--------------------------------|----------|
| Arithmetic Shift Left          | ASL      |
| Arithmetic Shift Right         | ASR      |
| Clear Bit in Memory            | BCLR     |
| Set Bit in Memory              | BSET     |
| Clear                          | CLR      |
| Complement (One's Complement)  | СОМ      |
| Decrement                      | DEC      |
| Increment                      | INC      |
| Logical Shift Left             | LSL      |
| Logical Shift Right            | LSR      |
| Negate (Two's Complement)      | NEG      |
| Rotate Left through Carry Bit  | ROL      |
| Rotate Right through Carry Bit | ROR      |
| Test for Negative or Zero      | TST      |

Table 10-2. Read-Modify-Write Instructions

#### 10.3.3 Jump/Branch Instructions

Jump instructions allow the CPU to interrupt the normal sequence of the program counter. The unconditional jump instruction (JMP) and the jump to subroutine instruction (JSR) have no register operand. Branch instructions allow the CPU to interrupt the normal sequence of the program counter when a test condition is met. If the test condition is not met, the branch is not performed. All branch instructions use relative addressing.

Bit test and branch instructions cause a branch based on the state of any readable bit in the first 256 memory locations. These three-byte instructions use a combination of direct addressing and relative addressing. The direct address of the byte to be tested is in the byte following the opcode. The third byte is the signed offset byte. The CPU finds the conditional branch destination by adding the third byte to the program counter if the specified bit tests true. The bit to be tested and its condition (set or clear) is part of the opcode. The span of branching is from -128 to +127 from the address of the next location after the branch instruction. The CPU also transfers the tested bit to the carry/borrow bit of the condition code register. Table 10-3 lists the jump and branch instructions.

| Instruction                    | Mnemonic |
|--------------------------------|----------|
| Branch if Carry Bit Clear      | BCC      |
| Branch if Carry Bit Set        | BCS      |
| Branch if Equal                | BEQ      |
| Branch if Half-Carry Bit Clear | BHCC     |
| Branch if Half-Carry Bit Set   | BHCS     |
| Branch if Higher               | ВНІ      |
| Branch if Higher or Same       | BHS      |
| Branch if IRQ Pin High         | BIH      |
| Branch if IRQ Pin Low          | BIL      |
| Branch if Lower                | BLO      |
| Branch if Lower or Same        | BLS      |
| Branch if Interrupt Mask Clear | BMC      |
| Branch if Minus                | BMI      |
| Branch if Interrupt Mask Set   | BMS      |
| Branch if Not Equal            | BNE      |
| Branch if Plus                 | BPL      |
| Branch Always                  | BRA      |
| Branch if Bit Clear            | BRCLR    |
| Branch Never                   | BRN      |
| Branch if Bit Set              | BRSET    |
| Branch to Subroutine           | BSR      |
| Unconditional Jump             | JMP      |
| Jump to Subroutine             | JSR      |

#### Table 10-3. Jump and Branch Instructions

#### **10.3.4 Bit Manipulation Instructions**

The CPU can set or clear any writable bit in the first 256 bytes of memory. Port registers, port data direction registers, timer registers, and on-chip RAM locations are in the first 256 bytes of memory. The CPU can also test and branch based on the state of any bit in any of the first 256 memory locations. Bit manipulation instructions use direct addressing. Table 10-4 lists these instructions.

| Instruction         | Mnemonic |
|---------------------|----------|
| Clear Bit           | BCLR     |
| Branch if Bit Clear | BRCLR    |
| Branch if Bit Set   | BRSET    |
| Set Bit             | BSET     |

Table 10-4. Bit Manipulation Instructions

#### **10.3.5 Control Instructions**

These register reference instructions control CPU operation during program execution. Control instructions, listed in Table 10-5, use inherent addressing.

| Instruction                            | Mnemonic |
|----------------------------------------|----------|
| Clear Carry Bit                        | CLC      |
| Clear Interrupt Mask                   | CLI      |
| No Operation                           | NOP      |
| Reset Stack Pointer                    | RSP      |
| Return from Interrupt                  | RTI      |
| Return from Subroutine                 | RTS      |
| Set Carry Bit                          | SEC      |
| Set Interrupt Mask                     | SEI      |
| Stop Oscillator and Enable IRQ Pin     | STOP     |
| Software Interrupt                     | SWI      |
| Transfer Accumulator to Index Register | TAX      |
| Transfer Index Register to Accumulator | TXA      |
| Stop CPU Clock and Enable Interrupts   | WAIT     |

| Table 10-5. | Control | Instructions |
|-------------|---------|--------------|
|-------------|---------|--------------|

#### **10.4 Instruction Set Summary**

Table 10-6 is an alphabetical list of all M68HC05 instructions and shows the effect of each instruction on the condition code register.

| Source                                                             | Operation                                | Description                                     |   | Description Effect on CCR |   |   |   |                                                                                                          |                                  | Effect on CCR                                      |                                                                                                       | Address<br>Mode | Opcode<br>Operand |  | Cycles |
|--------------------------------------------------------------------|------------------------------------------|-------------------------------------------------|---|---------------------------|---|---|---|----------------------------------------------------------------------------------------------------------|----------------------------------|----------------------------------------------------|-------------------------------------------------------------------------------------------------------|-----------------|-------------------|--|--------|
| Form                                                               | operation                                |                                                 | Н | I                         | N | Z | С | Add                                                                                                      | 0<br>D                           | Ope                                                | 2<br>3<br>4<br>5<br>4<br>3<br>2<br>3<br>4<br>5<br>4<br>3<br>2<br>3<br>4<br>5<br>4<br>3<br>2<br>5<br>5 |                 |                   |  |        |
| ADC #opr<br>ADC opr<br>ADC opr<br>ADC opr,X<br>ADC opr,X<br>ADC ,X | Add with Carry                           | $A \gets (A) + (M) + (C)$                       | × |                           | × | × | × | IMM<br>DIR<br>EXT                                                                                        | A9<br>B9<br>C9<br>D9<br>E9<br>F9 | ii<br>dd<br>hh ll<br>ee ff<br>ff                   | 3<br>4<br>5<br>4                                                                                      |                 |                   |  |        |
| ADD #opr<br>ADD opr<br>ADD opr<br>ADD opr,X<br>ADD opr,X<br>ADD ,X | Add without Carry                        | $A \gets (A) + (M)$                             | × |                           | × | × | × | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX                                                                    | AB<br>BB<br>CB<br>DB<br>EB<br>FB | ii<br>dd<br>hh ll<br>ee ff<br>ff                   | 3<br>4<br>5<br>4                                                                                      |                 |                   |  |        |
| AND #opr<br>AND opr<br>AND opr<br>AND opr,X<br>AND opr,X<br>AND ,X | Logical AND                              | $A \leftarrow (A) \land (M)$                    | _ |                           | × | × |   | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX                                                                    | A4<br>B4<br>C4<br>D4<br>E4<br>F4 | ii<br>dd<br>hh ll<br>ee ff<br>ff                   | 3<br>4<br>5<br>4                                                                                      |                 |                   |  |        |
| ASL <i>opr</i><br>ASLA<br>ASLX<br>ASL <i>opr</i> ,X<br>ASL ,X      | Arithmetic Shift Left<br>(Same as LSL)   | C 0<br>b7 b0                                    |   |                           | × | × | × | DIR<br>INH<br>INH<br>IX1<br>IX                                                                           | 38<br>48<br>58<br>68<br>78       | dd<br>ff                                           | 5<br>3<br>3<br>6<br>5                                                                                 |                 |                   |  |        |
| ASR opr<br>ASRA<br>ASRX<br>ASR opr,X<br>ASR ,X                     | Arithmetic Shift Right                   |                                                 |   |                           | × | × | × | DIR<br>INH<br>INH<br>IX1<br>IX                                                                           | 37<br>47<br>57<br>67<br>77       | dd<br>ff                                           | 5<br>3<br>3<br>6<br>5                                                                                 |                 |                   |  |        |
| BCC rel                                                            | Branch if Carry Bit<br>Clear             | $PC \leftarrow (PC) + 2 + \mathit{rel} ? C = 0$ | - | _                         |   | _ | _ | REL                                                                                                      | 24                               | rr                                                 | 3                                                                                                     |                 |                   |  |        |
| BCLR n opr                                                         | Clear Bit n                              | Mn ← 0                                          | _ |                           |   |   |   | DIR (b0)<br>DIR (b1)<br>DIR (b2)<br>DIR (b3)<br>DIR (b3)<br>DIR (b4)<br>DIR (b5)<br>DIR (b6)<br>DIR (b7) | 13<br>15<br>17<br>19<br>1B<br>1D | dd<br>dd<br>dd<br>dd<br>dd<br>dd<br>dd<br>dd<br>dd | 5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5                                              |                 |                   |  |        |
| BCS rel                                                            | Branch if Carry Bit<br>Set (Same as BLO) | PC ← (PC) + 2 + <i>rel</i> ? C = 1              | - | _                         | - | - | - | REL                                                                                                      | 25                               | rr                                                 | 3                                                                                                     |                 |                   |  |        |
| BEQ <i>rel</i>                                                     | Branch if Equal                          | PC ← (PC) + 2 + <i>rel</i> ? Z = 1              | _ | _                         | _ | _ | _ | REL                                                                                                      | 27                               | rr                                                 | 3                                                                                                     |                 |                   |  |        |
| BHCC rel                                                           | Branch if Half-Carry<br>Bit Clear        | $PC \leftarrow (PC) + 2 + \mathit{rel} ? H = 0$ | - |                           | _ | _ | _ | REL                                                                                                      | 28                               | rr                                                 | 3                                                                                                     |                 |                   |  |        |

# Table 10-6. Instruction Set Summary

10

| Source                                                             | Operation                                   | Description                                                    |   |   | ect<br>CC |   | ı | Address<br>Mode                                                                                          | Opcode                           | Operand                                            | Cycles                                         |
|--------------------------------------------------------------------|---------------------------------------------|----------------------------------------------------------------|---|---|-----------|---|---|----------------------------------------------------------------------------------------------------------|----------------------------------|----------------------------------------------------|------------------------------------------------|
| Form                                                               | oporation                                   | Decemption                                                     | н | I | Ν         | z | С | Add                                                                                                      | odo                              | Ope                                                | Š                                              |
| BHCS rel                                                           | Branch if Half-Carry<br>Bit Set             | PC ← (PC) + 2 + <i>rel</i> ? H = 1                             | _ | _ | _         | _ | _ | REL                                                                                                      | 29                               | rr                                                 | 3                                              |
| BHI rel                                                            | Branch if Higher                            | $PC \leftarrow (PC) + 2 + \mathit{rel} ? C \lor Z = 0$         | — | — | _         | — | _ | REL                                                                                                      | 22                               | rr                                                 | 3                                              |
| BHS rel                                                            | Branch if Higher or<br>Same                 | $PC \leftarrow (PC) + 2 + \mathit{rel} ? C = 0$                | _ | _ | _         |   | _ | REL                                                                                                      | 24                               | rr                                                 | 3                                              |
| BIH rel                                                            | Branch if IRQ Pin<br>High                   | $PC \leftarrow (PC) + 2 + \mathit{rel} ? \ \overline{IRQ} = 1$ | _ | _ | _         |   | _ | REL                                                                                                      | 2F                               | rr                                                 | 3                                              |
| BIL rel                                                            | Branch if IRQ Pin<br>Low                    | $PC \leftarrow (PC) + 2 + \mathit{rel} ? \ \overline{IRQ} = 0$ | _ | _ | _         | _ | - | REL                                                                                                      | 2E                               | rr                                                 | 3                                              |
| BIT #opr<br>BIT opr<br>BIT opr<br>BIT opr,X<br>BIT opr,X<br>BIT ,X | Bit Test<br>Accumulator with<br>Memory Byte | (A) ∧ (M)                                                      |   |   | ×         | × | _ | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX                                                                    | A5<br>B5<br>C5<br>D5<br>E5<br>F5 | ii<br>dd<br>hh II<br>ee ff<br>ff<br>p              | 2<br>3<br>4<br>5<br>4<br>3                     |
| BLO rel                                                            | Branch if Lower<br>(Same as BCS)            | PC ← (PC) + 2 + <i>rel</i> ? C = 1                             | _ | _ | _         | _ | - | REL                                                                                                      | 25                               | rr                                                 | 3                                              |
| BLS rel                                                            | Branch if Lower or<br>Same                  | $PC \leftarrow (PC) + 2 + \mathit{rel} ? C \lor Z = 1$         | _ | _ | _         |   | _ | REL                                                                                                      | 23                               | rr                                                 | 3                                              |
| BMC rel                                                            | Branch if Interrupt<br>Mask Clear           | $PC \leftarrow (PC) + 2 + rel? I = 0$                          | _ | _ | _         |   | _ | REL                                                                                                      | 2C                               | rr                                                 | 3                                              |
| BMI <i>rel</i>                                                     | Branch if Minus                             | $PC \leftarrow (PC) + 2 + \mathit{rel} ? N = 1$                | _ | — | _         | — | _ | REL                                                                                                      | 2B                               | rr                                                 | 3                                              |
| BMS rel                                                            | Branch if Interrupt<br>Mask Set             | PC ← (PC) + 2 + <i>rel</i> ? I = 1                             |   | _ | _         |   | _ | REL                                                                                                      | 2D                               | rr                                                 | 3                                              |
| BNE <i>rel</i>                                                     | Branch if Not Equal                         | $PC \leftarrow (PC) + 2 + \mathit{rel} ? Z = 0$                | — | — | —         | — | _ | REL                                                                                                      | 26                               | rr                                                 | 3                                              |
| BPL rel                                                            | Branch if Plus                              | $PC \leftarrow (PC) + 2 + \mathit{rel} ? N = 0$                | — | — | —         | — | _ | REL                                                                                                      | 2A                               | rr                                                 | 3                                              |
| BRA <i>rel</i>                                                     | Branch Always                               | $PC \leftarrow (PC) + 2 + \mathit{rel} ? 1 = 1$                | — | — | —         | — | _ | REL                                                                                                      | 20                               | rr                                                 | 3                                              |
| BRCLR n opr rel                                                    | Branch if bit n clear                       | PC ← (PC) + 2 + <i>rel</i> ? Mn = 0                            |   |   |           |   | × | DIR (b0)<br>DIR (b1)<br>DIR (b2)<br>DIR (b3)<br>DIR (b3)<br>DIR (b4)<br>DIR (b5)<br>DIR (b5)<br>DIR (b7) | 05<br>07<br>09<br>0B<br>0D       | dd rr<br>dd rr<br>dd rr<br>dd rr                   | 5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5      |
| BRSET n opr rel                                                    | Branch if Bit n Set                         | PC ← (PC) + 2 + <i>rel</i> ? Mn = 1                            |   |   |           |   | × | DIR (b0)<br>DIR (b1)<br>DIR (b2)<br>DIR (b3)<br>DIR (b3)<br>DIR (b4)<br>DIR (b5)<br>DIR (b6)<br>DIR (b7) | 04<br>06<br>08<br>0A<br>0C       | dd rr<br>dd rr<br>dd rr<br>dd rr<br>dd rr<br>dd rr | 5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5 |
| BRN <i>rel</i>                                                     | Branch Never                                | $PC \leftarrow (PC) + 2 + \mathit{rel} ? 1 = 0$                |   | - | _         |   | - | REL                                                                                                      | 21                               | rr                                                 | 3                                              |

| Source                                                             | Operation                                       | Description                                                                                                                                                                                                                                             |   |   | ect<br>CCI |   | ١ | Address<br>Mode                                                                              | Opcode                                       | Operand                                            | Cycles                                         |
|--------------------------------------------------------------------|-------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|------------|---|---|----------------------------------------------------------------------------------------------|----------------------------------------------|----------------------------------------------------|------------------------------------------------|
| Form                                                               | opolation                                       | 2000.19.10.1                                                                                                                                                                                                                                            | Н | I | N          | Z | С | Add                                                                                          | 0<br>D                                       | Ope                                                | Š                                              |
| BSET n opr                                                         | Set Bit n                                       | Mn ← 1                                                                                                                                                                                                                                                  | _ |   |            |   |   | DIR (b0)<br>DIR (b1)<br>DIR (b2)<br>DIR (b3)<br>DIR (b4)<br>DIR (b5)<br>DIR (b5)<br>DIR (b7) | 10<br>12<br>14<br>16<br>18<br>1A<br>1C<br>1E | dd<br>dd<br>dd<br>dd<br>dd<br>dd<br>dd<br>dd<br>dd | 5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5<br>5 |
| BSR rel                                                            | Branch to<br>Subroutine                         | $\begin{array}{l} PC \leftarrow (PC) + 2;  push \; (PCL) \\ SP \leftarrow (SP) - 1;  push \; (PCH) \\ SP \leftarrow (SP) - 1 \\ PC \leftarrow (PC) + \mathit{rel} \end{array}$                                                                          | _ |   |            |   |   | REL                                                                                          | AD                                           | rr                                                 | 6                                              |
| CLC                                                                | Clear Carry Bit                                 | $C \leftarrow 0$                                                                                                                                                                                                                                        | — | — | —          | — | 0 | INH                                                                                          | 98                                           |                                                    | 2                                              |
| CLI                                                                | Clear Interrupt Mask                            | $I \leftarrow 0$                                                                                                                                                                                                                                        | — | 0 | —          | — | — | INH                                                                                          | 9A                                           |                                                    | 2                                              |
| CLR opr<br>CLRA<br>CLRX<br>CLR opr,X<br>CLR ,X                     | Clear Byte                                      | $\begin{array}{c} M \leftarrow \$00\\ A \leftarrow \$00\\ X \leftarrow \$00\\ M \leftarrow \$00\\ M \leftarrow \$00\\ M \leftarrow \$00 \end{array}$                                                                                                    | _ |   | 0          | 1 |   | DIR<br>INH<br>INH<br>IX1<br>IX                                                               | 3F<br>4F<br>5F<br>6F<br>7F                   | dd<br>ff                                           | 5<br>3<br>3<br>6<br>5                          |
| CMP #opr<br>CMP opr<br>CMP opr<br>CMP opr,X<br>CMP opr,X<br>CMP ,X | Compare<br>Accumulator with<br>Memory Byte      | (A) – (M)                                                                                                                                                                                                                                               | _ |   | ×          | × | × | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX                                                        | A1<br>B1<br>C1<br>D1<br>E1<br>F1             | ii<br>dd<br>hh II<br>ee ff<br>ff                   | 2<br>3<br>4<br>5<br>4<br>3                     |
| COM opr<br>COMA<br>COMX<br>COM opr,X<br>COM ,X                     | Complement Byte<br>(One's Complement)           | $\begin{array}{l} M \leftarrow (\overline{M}) = \$FF - (M) \\ A \leftarrow (\overline{A}) = \$FF - (M) \\ X \leftarrow (\overline{X}) = \$FF - (M) \\ M \leftarrow (\overline{M}) = \$FF - (M) \\ M \leftarrow (\overline{M}) = \$FF - (M) \end{array}$ | _ |   | ×          | × | 1 | DIR<br>INH<br>INH<br>IX1<br>IX                                                               | 33<br>43<br>53<br>63<br>73                   | dd<br>ff                                           | 5<br>3<br>3<br>6<br>5                          |
| CPX #opr<br>CPX opr<br>CPX opr<br>CPX opr,X<br>CPX opr,X<br>CPX ,X | Compare Index<br>Register with<br>Memory Byte   | (X) – (M)                                                                                                                                                                                                                                               | _ |   | ×          | × | 1 | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX                                                        | A3<br>B3<br>C3<br>D3<br>E3<br>F3             |                                                    | 2<br>3<br>4<br>5<br>4<br>3                     |
| DEC opr<br>DECA<br>DECX<br>DEC opr,X<br>DEC ,X                     | Decrement Byte                                  | $\begin{array}{l} M \leftarrow (M) - 1 \\ A \leftarrow (A) - 1 \\ X \leftarrow (X) - 1 \\ M \leftarrow (M) - 1 \\ M \leftarrow (M) - 1 \end{array}$                                                                                                     | _ |   | ×          | × |   | DIR<br>INH<br>INH<br>IX1<br>IX                                                               | 3A<br>4A<br>5A<br>6A<br>7A                   | dd<br>ff                                           | 5<br>3<br>3<br>6<br>5                          |
| EOR #opr<br>EOR opr<br>EOR opr<br>EOR opr,X<br>EOR opr,X<br>EOR ,X | EXCLUSIVE OR<br>Accumulator with<br>Memory Byte | $A \gets (A) \oplus (M)$                                                                                                                                                                                                                                |   |   | ×          | × |   | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX                                                        | A8<br>B8<br>C8<br>D8<br>E8<br>F8             | hh ll<br>ee ff<br>ff                               | 2<br>3<br>4<br>5<br>4<br>3                     |

| Source                                                             | Operation                               | Description                                                                                                                                                                                            |   |   | ect<br>CC | t oi<br>R | า | Address<br>Mode                       | Opcode                           | Operand                          | Cycles                     |
|--------------------------------------------------------------------|-----------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|-----------|-----------|---|---------------------------------------|----------------------------------|----------------------------------|----------------------------|
| Form                                                               | Operation                               | Description                                                                                                                                                                                            | н | I | Ν         | z         | С | Mo                                    | Opc                              | Opei                             | Cyc                        |
| INC opr<br>INCA<br>INCX<br>INC opr,X<br>INC ,X                     | Increment Byte                          | $\begin{array}{l} M \leftarrow (M) + 1 \\ A \leftarrow (A) + 1 \\ X \leftarrow (X) + 1 \\ M \leftarrow (M) + 1 \\ M \leftarrow (M) + 1 \end{array}$                                                    | _ |   | ×         | ×         |   | DIR<br>INH<br>INH<br>IX1<br>IX        | 3C<br>4C<br>5C<br>6C<br>7C       | dd<br>ff                         | 5<br>3<br>3<br>6<br>5      |
| JMP opr<br>JMP opr<br>JMP opr,X<br>JMP opr,X<br>JMP ,X             | Unconditional Jump                      | $PC \gets Jump \; Address$                                                                                                                                                                             |   |   |           |           |   | DIR<br>EXT<br>IX2<br>IX1<br>IX        | BC<br>C<br>D<br>C<br>EC<br>FC    | dd<br>hh ll<br>ee ff<br>ff       | 2<br>3<br>4<br>3<br>2      |
| JSR opr<br>JSR opr<br>JSR opr,X<br>JSR opr,X<br>JSR ,X             | Jump to Subroutine                      | $\begin{array}{l} PC \leftarrow (PC) + n \ (n = 1, 2,  or \ 3) \\ Push \ (PCL); \ SP \leftarrow (SP) - 1 \\ Push \ (PCH); \ SP \leftarrow (SP) - 1 \\ PC \leftarrow Conditional \ Address \end{array}$ |   |   |           |           |   | DIR<br>EXT<br>IX2<br>IX1<br>IX        | BD<br>C<br>D<br>D<br>ED<br>FD    | dd<br>hh ll<br>ee ff<br>ff       | 5<br>6<br>7<br>6<br>5      |
| LDA #opr<br>LDA opr<br>LDA opr<br>LDA opr,X<br>LDA opr,X<br>LDA ,X | Load Accumulator<br>with Memory Byte    | A ← (M)                                                                                                                                                                                                | _ |   | ×         | ×         |   | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX | A6<br>B6<br>C6<br>D6<br>E6<br>F6 | ii<br>dd<br>hh II<br>ee ff<br>ff | 2<br>3<br>4<br>5<br>4<br>3 |
| LDX #opr<br>LDX opr<br>LDX opr<br>LDX opr,X<br>LDX opr,X<br>LDX ,X | Load Index Register<br>with Memory Byte | X ← (M)                                                                                                                                                                                                |   |   | ×         | ×         |   | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX | AE<br>BE<br>CE<br>DE<br>EE<br>FE | ii<br>dd<br>hh II<br>ee ff<br>ff | 2<br>3<br>4<br>5<br>4<br>3 |
| LSL <i>opr</i><br>LSLA<br>LSLX<br>LSL <i>opr</i> ,X<br>LSL ,X      | Logical Shift Left<br>(Same as ASL)     |                                                                                                                                                                                                        |   |   | ×         | ×         | × | DIR<br>INH<br>INH<br>IX1<br>IX        | 38<br>48<br>58<br>68<br>78       | dd<br>ff                         | 5<br>3<br>3<br>6<br>5      |
| LSR <i>opr</i><br>LSRA<br>LSRX<br>LSR <i>opr</i> ,X<br>LSR ,X      | Logical Shift Right                     | $0 \rightarrow \boxed[b7]{b0} b0$                                                                                                                                                                      |   |   | 0         | ×         | × | DIR<br>INH<br>INH<br>IX1<br>IX        | 34<br>44<br>54<br>64<br>74       | dd<br>ff                         | 5<br>3<br>6<br>5           |
| MUL                                                                | Unsigned Multiply                       | $X:A \leftarrow (X) \times (A)$                                                                                                                                                                        | 0 | _ | -         | _         | 0 | INH                                   | 42                               |                                  | 11                         |
| NEG <i>opr</i><br>NEGA<br>NEGX<br>NEG <i>opr</i> ,X<br>NEG ,X      | Negate Byte<br>(Two's Complement)       | $\begin{array}{l} M \leftarrow -(M) = \$00 - (M) \\ A \leftarrow -(A) = \$00 - (A) \\ X \leftarrow -(X) = \$00 - (X) \\ M \leftarrow -(M) = \$00 - (M) \\ M \leftarrow -(M) = \$00 - (M) \end{array}$  | _ |   | ×         | ×         | × | DIR<br>INH<br>INH<br>IX1<br>IX        | 30<br>40<br>50<br>60<br>70       | ii<br>ff                         | 5<br>3<br>6<br>5           |

| Source                                                             | Operation                                                 | Description                                                                                                                                                                                                                     |    |   | ect<br>CCI |   | ו | Address<br>Mode                       | Opcode                           | Operand                          | Cycles                     |
|--------------------------------------------------------------------|-----------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|---|------------|---|---|---------------------------------------|----------------------------------|----------------------------------|----------------------------|
| Form                                                               | - Pointion                                                |                                                                                                                                                                                                                                 | н  | I | N          | z | С | Add<br>Mc                             | Opc                              | Ope                              | č                          |
| NOP                                                                | No Operation                                              |                                                                                                                                                                                                                                 | 1- | — | -          | — | - | INH                                   | 9D                               |                                  | 2                          |
| ORA #opr<br>ORA opr<br>ORA opr<br>ORA opr,X<br>ORA opr,X<br>ORA ,X | Logical OR<br>Accumulator with<br>Memory                  | $A \leftarrow (A) \lor (M)$                                                                                                                                                                                                     |    |   | ×          | × |   | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX | AA<br>BA<br>CA<br>DA<br>EA<br>FA | ii<br>dd<br>hh ll<br>ee ff<br>ff | 2<br>3<br>4<br>5<br>4<br>3 |
| ROL <i>opr</i><br>ROLA<br>ROLX<br>ROL <i>opr</i> ,X<br>ROL ,X      | Rotate Byte Left<br>through Carry Bit                     | b7 b0                                                                                                                                                                                                                           |    |   | ×          | × | × | DIR<br>INH<br>INH<br>IX1<br>IX        | 39<br>49<br>59<br>69<br>79       | dd<br>ff                         | 5<br>3<br>3<br>6<br>5      |
| ROR <i>opr</i><br>RORA<br>RORX<br>ROR <i>opr</i> ,X<br>ROR ,X      | Rotate Byte Right<br>through Carry Bit                    | b7 b0                                                                                                                                                                                                                           |    |   | ×          | × | × | DIR<br>INH<br>INH<br>IX1<br>IX        | 36<br>46<br>56<br>66<br>76       | dd<br>ff                         | 5<br>3<br>3<br>6<br>5      |
| RSP                                                                | Reset Stack Pointer                                       | $SP \gets \$00FF$                                                                                                                                                                                                               |    | _ | _          | _ | _ | INH                                   | 9C                               |                                  | 2                          |
| RTI                                                                | Return from Interrupt                                     | $\begin{array}{l} SP \leftarrow (SP) + 1;  Pull  (CCR) \\ SP \leftarrow (SP) + 1;  Pull  (A) \\ SP \leftarrow (SP) + 1;  Pull  (X) \\ SP \leftarrow (SP) + 1;  Pull  (PCH) \\ SP \leftarrow (SP) + 1;  Pull  (PCL) \end{array}$ | ×  | × | ×          | × | × | INH                                   | 80                               |                                  | 6                          |
| RTS                                                                | Return from<br>Subroutine                                 | $\begin{array}{l} SP \leftarrow (SP) + 1;  Pull \; (PCH) \\ SP \leftarrow (SP) + 1;  Pull \; (PCL) \end{array}$                                                                                                                 |    |   |            |   |   | INH                                   |                                  |                                  |                            |
| SBC #opr<br>SBC opr<br>SBC opr<br>SBC opr,X<br>SBC opr,X<br>SBC ,X | Subtract Memory<br>Byte and Carry Bit<br>from Accumulator | $A \gets (A) - (M) - (C)$                                                                                                                                                                                                       |    |   | ×          | × | × | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX | A2<br>B2<br>C2<br>D2<br>E2<br>F2 | ii<br>dd<br>hh ll<br>ee ff<br>ff | 2<br>3<br>4<br>5<br>4<br>3 |
| SEC                                                                | Set Carry Bit                                             | $C \leftarrow 1$                                                                                                                                                                                                                | —  | — | —          | — | 1 | INH                                   | 99                               |                                  | 2                          |
| SEI                                                                | Set Interrupt Mask                                        | l ← 1                                                                                                                                                                                                                           | _  | 1 | _          | — | _ | INH                                   | 9B                               |                                  | 2                          |
| STA opr<br>STA opr<br>STA opr,X<br>STA opr,X<br>STA ,X             | Store Accumulator in<br>Memory                            | M ← (A)                                                                                                                                                                                                                         |    |   | ×          | × |   | DIR<br>EXT<br>IX2<br>IX1<br>IX        | B7<br>C7<br>D7<br>E7<br>F7       | dd<br>hh II<br>ee ff<br>ff       | 4<br>5<br>6<br>5<br>4      |
| STOP                                                               | Stop Oscillator and<br>Enable IRQ Pin                     |                                                                                                                                                                                                                                 | _  | 0 | _          |   | _ | INH                                   | 8E                               |                                  | 2                          |
| STX opr<br>STX opr<br>STX opr,X<br>STX opr,X<br>STX ,X             | Store Index<br>Register In Memory                         | M ← (X)                                                                                                                                                                                                                         |    |   | ×          | × |   | DIR<br>EXT<br>IX2<br>IX1<br>IX        | BF<br>CF<br>DF<br>EF<br>FF       | dd<br>hh II<br>ee ff<br>ff       | 4<br>5<br>6<br>5<br>4      |

| Source                                                                                                                                                                                                            | Operation                                                                                                                                                                                                                                                                                                                                                                | Description                                                                                                                                                                                                                                                                                                                                                                 |                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | ec<br>CC                                                                                                                                            | t oi<br>R                                                                                                                         | n                                                          | Address<br>Mode                                                                                   | Opcode                           | Operand                          | Cycles                     |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------|---------------------------------------------------------------------------------------------------|----------------------------------|----------------------------------|----------------------------|
| Form                                                                                                                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                          |                                                                                                                                                                                                                                                                                                                                                                             | н                                    | I                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | N                                                                                                                                                   | z                                                                                                                                 | С                                                          | Add                                                                                               | op                               | Ope                              | Š                          |
| SUB #opr<br>SUB opr<br>SUB opr<br>SUB opr,X<br>SUB opr,X<br>SUB ,X                                                                                                                                                | Subtract Memory<br>Byte from<br>Accumulator                                                                                                                                                                                                                                                                                                                              | A ← (A) − (M)                                                                                                                                                                                                                                                                                                                                                               |                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | ×                                                                                                                                                   | ×                                                                                                                                 | ×                                                          | IMM<br>DIR<br>EXT                                                                                 | A0<br>B0<br>C0<br>D0<br>E0<br>F0 | ii<br>dd<br>hh II<br>ee ff<br>ff | 2<br>3<br>4<br>5<br>4<br>3 |
| SWI                                                                                                                                                                                                               | Software Interrupt                                                                                                                                                                                                                                                                                                                                                       | $\begin{array}{l} PC \leftarrow (PC) + 1;  Push  (PCL) \\ SP \leftarrow (SP) - 1;  Push  (PCH) \\ SP \leftarrow (SP) - 1;  Push  (X) \\ SP \leftarrow (SP) - 1;  Push  (A) \\ SP \leftarrow (SP) - 1;  Push  (CCR) \\ SP \leftarrow (SP) - 1;  I \leftarrow 1 \\ PCH \leftarrow  Interrupt  Vector  High  Byte \\ PCL \leftarrow  Interrupt  Vector  Low  Byte \end{array}$ |                                      | 1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                     | -                                                                                                                                 |                                                            | INH                                                                                               | 83                               |                                  | 10                         |
| ТАХ                                                                                                                                                                                                               | Transfer<br>Accumulator to<br>Index Register                                                                                                                                                                                                                                                                                                                             | X ← (A)                                                                                                                                                                                                                                                                                                                                                                     | _                                    | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                                                                     |                                                                                                                                   |                                                            | INH                                                                                               | 97                               |                                  | 2                          |
| TST opr<br>TSTA<br>TSTX<br>TST opr,X<br>TST ,X                                                                                                                                                                    | Test Memory Byte<br>for Negative or Zero                                                                                                                                                                                                                                                                                                                                 | (M) – \$00                                                                                                                                                                                                                                                                                                                                                                  |                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                     |                                                                                                                                   |                                                            | DIR<br>INH<br>INH<br>IX1<br>IX                                                                    | 3D<br>4D<br>5D<br>6D<br>7D       | dd<br>ff                         | 4<br>3<br>3<br>5<br>4      |
| ТХА                                                                                                                                                                                                               | Transfer Index<br>Register to<br>Accumulator                                                                                                                                                                                                                                                                                                                             | $A \gets (X)$                                                                                                                                                                                                                                                                                                                                                               | _                                    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |                                                                                                                                                     | _                                                                                                                                 | _                                                          | INH                                                                                               | 9F                               |                                  | 2                          |
| WAIT                                                                                                                                                                                                              | Stop CPU Clock<br>and Enable<br>Interrupts                                                                                                                                                                                                                                                                                                                               |                                                                                                                                                                                                                                                                                                                                                                             | _                                    | ×                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | :                                                                                                                                                   | _                                                                                                                                 | _                                                          | INH                                                                                               | 8F                               |                                  | 2                          |
| dd Direct add<br>dd rr Direct add<br>DIR Direct add<br>ee ff High and I<br>EXT Extended<br>ff Offset byte<br>H Half-carry<br>hh II High and I<br>I Interrupt n<br>ii Immediate<br>INH Inherent a<br>IX Indexed, f | ow flag<br>code register<br>ress of operand and relative of<br>ressing mode<br>ow bytes of offset in indexed,<br>addressing mode<br>a in indexed, 8-bit offset addre<br>flag<br>ow bytes of operand address<br>ask<br>o operand byte<br>addressing mode<br>ddressing mode<br>bot offset addressing mode<br>b-bit offset addressing mode<br>ic-bit offset addressing mode | 16-bit offset addressing rr<br>SP<br>essing X<br>Z                                                                                                                                                                                                                                                                                                                          | P P R R R S Ir Z Ir L L C N L If C S | rogr<br>rogr<br>rogr<br>elati<br>elati<br>tack<br>dex<br>ero<br>social<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>cogic<br>c | am (<br>am (<br>ive a<br>ive p<br>ive p<br>ive p<br>ive p<br>ive p<br>ive p<br>flag<br>diate<br>al O<br>al E.<br>ents<br>tion<br>w<br>aten<br>r cle | coun<br>coun<br>addre<br>progr<br>progr<br>nter<br>ister<br>k<br>ND<br>R<br>XCL <sup>1</sup><br>of<br>(two<br>ith<br>ated<br>ared | Iter h<br>Iter h<br>essin<br>am c<br>am c<br>USIV<br>'s co | wo bytes)<br>iigh byte<br>by byte<br>g mode<br>counter offs<br>counter offs<br>/E OR<br>mplement) |                                  |                                  |                            |

# INSTRUCTION SET

MC68HC705J1A Rev. 1.1

# Table 10-7. Opcode Map

|            | B<br>Manipi           | it<br>ulation       | Branch                     |                        | Read               | -Modify-      | Write               |                 | Con                        | trol              |                           |                   | Register                                  | /Memory             |                     |                          |            |
|------------|-----------------------|---------------------|----------------------------|------------------------|--------------------|---------------|---------------------|-----------------|----------------------------|-------------------|---------------------------|-------------------|-------------------------------------------|---------------------|---------------------|--------------------------|------------|
|            | DIR                   | DIR                 | REL                        | DIR                    | INH                | INH           | IX1                 | IX              | INH                        | INH               | ІММ                       | DIR               | EXT                                       | IX2                 | IX1                 | IX                       |            |
| MSB<br>LSB | 0                     | 1                   | 2                          | 3                      | 4                  | 5             | 6                   | 7               | 8                          | 9                 | A                         | В                 | С                                         | D                   | E                   | F                        | MSB<br>LSB |
| 0          | 5<br>BRSET0<br>3 DIR  | BSET0<br>2 DIR      | BRA<br>2 REL               | NEG<br>2 DIR           | NEGA<br>1 INH      | NEGX 1 INH    | NEG<br>2 IX1        | NEG 1 IX        | 9<br>RTI<br>1 INH          |                   |                           | 3<br>SUB<br>2 DIR | 4<br>SUB<br>3 EXT                         |                     | 4<br>SUB<br>2 IX1   | SUB 1 IX                 | 0          |
| 1          | 5<br>BRCLR0<br>3 DIR  | BCLR0<br>2 DIR      | BRN<br>2 REL               |                        |                    |               |                     |                 | RTS<br>1 INH               |                   | CMP<br>2 IMM              | CMP<br>2 DIR      | 4<br>3 EXT                                |                     |                     | CMP IX                   | 1          |
| 2          | BRSET1<br>3 DIR       | BSET1<br>2 DIR      | BHI<br>2 REL               |                        | 11<br>MUL<br>1 INH |               |                     |                 |                            |                   | SBC <sup>2</sup><br>2 IMM |                   | 3 SBC 4<br>3 EXT                          |                     |                     | SBC IX                   | 2          |
| 3          | 5<br>BRCLR1<br>3 DIR  |                     | BLS<br>2 REL               | COM 2 DIR              | COMA<br>1 INH      |               | 2 COM 1X1           | COM IX          | 10<br>SWI<br>1 INH         |                   | CPX<br>2 IMM              |                   | CPX 4<br>3 EXT                            |                     |                     | CPX 3<br>1 IX            | 3          |
| 4          | BRSET2<br>3 DIR       | BSET2<br>2 DIR      | BCC<br>2 REL               | LSR<br>2 DIR           | LSRA<br>1 INH      | LSRX 1 INH    | 6<br>2 ISR<br>1X1   | LSR 1 IX        |                            |                   | AND<br>2 IMM              |                   | AND<br>3 EXT                              |                     |                     | AND 1 IX                 | 4          |
| 5          | BRCLR2<br>3 DIR       | BCLR2<br>2 DIR      | BCS/BLO<br>2 REL           |                        |                    |               |                     |                 |                            |                   | BIT<br>2 IMM              |                   | 4<br>BIT<br>3 EXT                         |                     | BIT 2 IX1           | BIT 3<br>1 IX            | 5          |
| 6          | 5<br>BRSET3<br>3 DIR  | BSET3<br>2 DIR      | BNE<br>2 REL               | ROR<br>2 DIR           | RORA<br>1 INH      | RORX 1 INH    |                     |                 |                            |                   | LDA<br>2 IMM              | LDA<br>2 DIR      | LDA<br>3 EXT                              |                     |                     | LDA 1 IX                 | 6          |
| 7          | 5<br>BRCLR3<br>3 DIR  | BCLR3<br>2 DIR      | BEQ<br>2 REL               | ASR<br>2 DIR           |                    |               | ASR 2 IX1           | ASR 1 IX        |                            | TAX<br>1 INH      |                           | STA 2 DIR         | STA<br>3 EXT                              |                     | 5<br>2 IX1          | STA 1 IX                 | 7          |
| 8          | BRSET4<br>3 DIR       |                     | BHCC <sup>3</sup><br>2 REL | 2 DIR                  | 1 INH              |               | ASL/LSL<br>2 IX1    | ASL/LSL<br>1 IX |                            | CLC<br>1 INH      | EOR<br>2 IMM              |                   | EOR<br>3 EXT                              |                     | EOR 2 IX1           | EOR 1 IX                 | 8          |
| 9          | 5<br>BRCLR4<br>3 DIR  |                     | BHCS<br>2 REL              | ROL<br>2 DIR           |                    |               | 8 ROL<br>2 IX1      | ROL 1 IX        |                            | SEC<br>1 INH      | ADC<br>2 IMM              |                   | ADC<br>3 EXT                              |                     | ADC<br>2 IX1        | ADC 1 IX                 | 9          |
| А          | BRSET5<br>3 DIR       | BSET5<br>2 DIR      | 3<br>BPL<br>2 REL          | DEC<br>2 DIR           | DECA<br>1 INH      | DECX<br>1 INH | 0 DEC 1X1           | DEC 1 IX        |                            | CLI<br>1 INH      | ORA<br>2 IMM              | ORA<br>2 DIR      | ORA<br>3 EXT                              | 0RA<br>3 IX2        | ORA 2 IX1           | ORA 1 IX                 | А          |
| В          | BRCLR5<br>3 DIR       | BCLR5<br>2 DIR      | BMI<br>2 REL               |                        |                    |               |                     |                 |                            | SEI<br>1 INH      | ADD<br>2 IMM              | ADD<br>2 DIR      | ADD<br>3 EXT                              | ADD<br>3 IX2        | 4<br>ADD<br>2 IX1   | ADD 3<br>1 IX            | В          |
| С          | BRSET6<br>3 DIR       | BSET6<br>2 DIR      | BMC<br>2 REL               | INC<br>2 DIR           | INCA<br>1 INH      | INCX          | INC IX1             | INC 1 IX        |                            | 2<br>RSP<br>1 INH |                           | 2<br>JMP<br>2 DIR | 3<br>JMP<br>3 EXT                         | 4<br>3 IX2          | 3<br>JMP<br>2 IX1   | 2<br>JMP<br>1 IX         | С          |
| D          | BRCLR6<br>3 DIR       | BCLR6<br>2 DIR      | BMS<br>2 REL               | TST<br>2 DIR           | 3<br>TSTA<br>1 INH | TSTX<br>1 INH | 5<br>2 TST 1X1      | TST 4<br>1 IX   |                            | NOP<br>1 INH      | 6<br>BSR<br>2 REL         | JSR<br>2 DIR      | 6<br>JSR<br>3 EXT                         | 7<br>JSR<br>3 IX2   | 6<br>JSR<br>2 IX1   | JSR<br>1 IX              | D          |
| E          | BRSET7<br>3 DIR       | BSET7<br>2 DIR      | BIL<br>2 REL               |                        |                    |               |                     |                 | STOP <sup>2</sup><br>1 INH |                   | LDX<br>2 IMM              | LDX<br>2 DIR      | LDX<br>3 EXT                              | LDX<br>3 IX2        | LDX 4<br>2 IX1      | LDX <sup>3</sup><br>1 IX | E          |
| F          | 5<br>BRCLR7<br>3 DIR  | 5<br>BCLR7<br>2 DIR | BIH<br>2 REL               | 5<br>CLR<br>2 DIR      | CLRA<br>1 INH      | CLRX<br>1 INH | 6<br>2 CLR<br>2 IX1 | CLR 1 IX        | 2<br>WAIT<br>1 INH         | 2<br>TXA<br>1 INH |                           | STX<br>2 DIR      | STX<br>3 EXT                              | 6<br>3 STX<br>3 IX2 | 5<br>2 STX<br>2 IX1 | STX 4<br>1 IX            | F          |
|            | INH = Inf<br>IMM = Im |                     |                            | = Relativ              |                    | et            |                     |                 |                            |                   | MSB                       | 0                 | MSB of Ope                                | code in Hex         | adecimal            |                          |            |
|            | DIR = Dii<br>EXT = Ex | rect                | IX1                        | = Indexed<br>= Indexed | d, 8-Bit O         | ffset         |                     | LSB of C        | Opcode in H                | exadecimal        | 0                         | BRSET0            | Number of Cy<br>Opcode Mn<br>Number of By | iemonic             | ng Mode             |                          |            |

#### SECTION 11 ELECTRICAL SPECIFICATIONS

#### **11.1 Introduction**

This section contains electrical and timing specifications.

#### **11.2 Maximum Ratings**

This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields; however, it is advised that normal precautions be taken to avoid application of any voltage higher than maximum-rated voltages to this high-impedance circuit. For proper operation, it is recommended that  $V_{IN}$  and  $V_{OUT}$  be constrained to the range  $V_{SS} \leq (V_{IN} \text{ or } V_{OUT}) \leq V_{DD}$ . Reliability of operation is enhanced if unused inputs are connected to an appropriate logic voltage level (for example, either  $V_{SS}$  or  $V_{DD}$ ). Internal I/O pulldowns may be used.

| Rating                                                                          | Symbol           | Value                                  | Unit |
|---------------------------------------------------------------------------------|------------------|----------------------------------------|------|
| Supply Voltage                                                                  | V <sub>DD</sub>  | -0.3 to +7.0                           | V    |
| Input Voltage                                                                   | V <sub>IN</sub>  | $V_{SS}$ –0.3 to $V_{DD}$ +0.3         | V    |
| IRQ/V <sub>PP</sub> Pin                                                         | V <sub>IN</sub>  | $V_{SS}$ –0.3 to 2V <sub>DD</sub> +0.3 | V    |
| Current Drain Per Pin Excluding V <sub>DD</sub> , V <sub>SS</sub> , and PA4–PA7 | I                | 25                                     | mA   |
| Storage Temperature Range                                                       | T <sub>STG</sub> | -65 to +150                            | °C   |

Table 11-1. Maximum Ratings\*

\*Voltages are referenced to V<sub>SS</sub>

#### **11.3 Thermal Characteristics**

| Rating                                                                              | Symbol                                                    | Value                                                      | Unit         |
|-------------------------------------------------------------------------------------|-----------------------------------------------------------|------------------------------------------------------------|--------------|
| Thermal Resistance<br>MC68HC705J1AP <sup>(1)</sup><br>MC68HC705J1ADW <sup>(2)</sup> | $\begin{array}{c} A_{A} \\ \theta_{A} \end{array} \theta$ | 60<br>60                                                   | °C/W<br>°C/W |
| Operating Temperature Range<br>MC68HC705J1A (Standard)<br>MC68HC705J1A (Extended)   | Τ <sub>Α</sub>                                            | T <sub>L</sub> to T <sub>H</sub><br>0 to +70<br>-40 to +85 | °C           |

#### Table 11-2. Thermal Characteristics

NOTES:

1. P = Plastic dual-in-line package (PDIP)

2. DW = Small outline integrated circuit (SOIC)

#### **11.4 Power Considerations**

The average chip-junction temperature, T<sub>J.</sub> can be obtained in °C from:

$$T_{J} = T_{A} + (P_{D} \times \theta_{JA})$$
(1)

where:

T<sub>A</sub> = Ambient temperature, °C

 $\theta_{JA}$  = Package thermal resistance, junction -to-ambient, °C/W

 $\mathsf{P}_\mathsf{D} = \mathsf{P}_\mathsf{INT} + \mathsf{P}_\mathsf{I/O}$ 

 $P_{INT} = I_{DD} \times V_{DD}$  watts (chip internal power)

 $P_{I/O}$  = Power dissipation on input and output pins (user-determined)

For most applications,  $P_{I/O} \ll P_{INT}$  and can be neglected.

The following is an approximate relationship between  $P_D$  and  $T_J$  (neglecting  $P_{I/O}$ ):

$$P_{\rm D} = K + (T_{\rm J} + 273^{\circ}{\rm C})$$
(2)

Solving equations (1) and (2) for K gives:

$$K = P_D \times (T_A + 273^{\circ}C) + \theta_{JA} \times (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$ .

11

#### **11.5 DC Electrical Characteristics**

| Characteristic                                                                                                                         | Symbol                              | Min                     | Typ <sup>(2)</sup> | Max                 | Unit     |
|----------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|-------------------------|--------------------|---------------------|----------|
| Output Voltage<br>$I_{LOAD} = 10.0 \ \mu A$<br>$I_{LOAD} = 10.0 \ \mu A$                                                               | V <sub>ol</sub><br>V <sub>oh</sub>  | <br>V <sub>DD</sub> 0.1 |                    | 0.1                 | V<br>V   |
| Output High Voltage<br>(I <sub>LOAD</sub> = -0.8 mA) PA0-PA7, PB0-PB5                                                                  | V <sub>OH</sub>                     | V <sub>DD</sub> -0.8    | _                  | _                   | V        |
| Output Low Voltage<br>$(I_{LOAD} = 1.6 \text{ mA}) \text{ PA0-PA3}, \text{ PB0-PB5}$<br>$(I_{LOAD} = 10.0 \text{ mA}) \text{ PA4-PA7}$ | V <sub>ol</sub><br>V <sub>ol</sub>  | _                       | _                  | 0.4<br>0.4          | V<br>V   |
| Input High Voltage<br>PA0-PA7, PB0-PB5, IRQ/V <sub>PP</sub> , RESET, OSC1                                                              | V <sub>IH</sub>                     | $0.7 \times V_{DD}$     | _                  | V <sub>DD</sub>     | V        |
| Input Low Voltage<br>PA0-PA7, PB0-PB5, IRQ/V <sub>PP</sub> , RESET, OSC1                                                               | V <sub>IL</sub>                     | V <sub>ss</sub>         | _                  | $0.2 \times V_{DD}$ | V        |
| Supply Current<br>Run <sup>(4)</sup><br>Wait <sup>(3, 4, 5, 7)</sup><br>Stop <sup>(5, 6)</sup>                                         | I <sub>DD</sub><br>I <sub>DD</sub>  |                         | 3.5<br>0.45        | 6.0<br>2.75         | mA<br>mA |
| 25°C<br>-40°C to +85°C                                                                                                                 | I <sub>DD</sub><br>I <sub>DD</sub>  |                         | 0.2<br>2.0         | 10<br>20            | μΑ<br>μΑ |
| I/O Ports Hi-Z Leakage Current<br>PA0-PA7, PB0-PB5 (without individual pulldown activated)                                             | I <sub>IL</sub>                     | _                       | _                  | ±10                 | μA       |
| Input Pulldown Current<br>PA0-PA7, PB0-PB5 (with individual pulldown activated)                                                        | I <sub>IL</sub>                     | 40                      | 80                 | 200                 | μA       |
| Input Pullup Current<br>RESET                                                                                                          | I <sub>IL</sub>                     | -15                     | -35                | -80                 | μA       |
| Input Current <sup>(8)</sup><br>RESET, IRQ/V <sub>PP</sub> , OSC1                                                                      | I <sub>IN</sub>                     | _                       | _                  | ±1                  | μA       |
| Capacitance<br><u>Ports (as Input or Output)</u><br><u>RESET, IRQ/V<sub>PP</sub>, OSC1, OSC2</u>                                       | C <sub>OUT</sub><br>C <sub>IN</sub> | _                       |                    | 12<br>8             | pF<br>pF |
| Crystal/Ceramic Resonator Oscillator Mode Internal Resistor<br>OSC1 to OSC2                                                            | R <sub>OSC</sub>                    | 1.0                     | 2.0                | 3.0                 | MΩ       |

# Table 11-3. DC Electrical Characteristics $(V_{DD} = 5 V)^{(1)}$

NOTES:

1.  $V_{DD}$  = 5.0 Vdc  $\pm$  10%,  $V_{SS}$  = 0 Vdc,  $T_A$  = –40°C to +85°C, unless otherwise noted

2. Typical values reflect average measurements at midpoint of voltage range, 25°C.

3. Wait I<sub>DD</sub>: Only timer system active.

Run (Operating) I<sub>DD</sub>, Wait I<sub>DD</sub>: Measured using external square wave clock source (f<sub>OP</sub> = 2.1 MHz), all inputs 0.2 V from rail; no dc loads, less than 50 pF on all outputs, C<sub>L</sub> = 20 pF on OSC2.

5. Wait, Stop I<sub>DD</sub>: All ports configured as inputs, V<sub>IL</sub> = 0.2 V, V<sub>IH</sub> = V<sub>DD</sub> -0.2 V.

6. Stop I<sub>DD</sub> measured with OSC1 =  $V_{SS}$ .

7. Wait  $I_{DD}$  is affected linearly by the OSC2 capacitance.

8. Only input high current rated to +1  $\mu$ A on RESET.

| Characteristic                                                                                 | Symbol                              | Min                     | Typ <sup>(2)</sup> | Max                 | Unit     |
|------------------------------------------------------------------------------------------------|-------------------------------------|-------------------------|--------------------|---------------------|----------|
| Output Voltage<br>$I_{LOAD} = 10.0 \ \mu A$<br>$I_{LOAD} = 10.0 \ \mu A$                       | V <sub>ol</sub><br>V <sub>oh</sub>  | <br>V <sub>DD</sub> 0.1 |                    | 0.1                 | V<br>V   |
| Output High Voltage<br>(I <sub>LOAD</sub> = -0.2 mA) PA0-PA7, PB0-PB5                          | V <sub>OH</sub>                     | V <sub>DD</sub> 0.3     | _                  | _                   | V        |
| Output Low Voltage<br>$(I_{LOAD} = 0.4mA)$ PA0-PA3, PB0-PB5<br>$(I_{LOAD} = 5.0mA)$ PA4-PA7    | V <sub>ol</sub><br>V <sub>ol</sub>  | _                       | _                  | 0.3<br>0.3          | V<br>V   |
| Input High Voltage<br>PA0-PA7, PB0-PB5, IRQ/V <sub>PP</sub> , RESET, OSC1                      | V <sub>IH</sub>                     | $0.7 \times V_{DD}$     | _                  | V <sub>DD</sub>     | V        |
| Input Low Voltage<br>PA0-PA7, PB0-PB5, IRQ/V <sub>PP</sub> , RESET, OSC1                       | V <sub>IL</sub>                     | V <sub>ss</sub>         | _                  | $0.2 \times V_{DD}$ | V        |
| Supply Current<br>Run <sup>(4)</sup><br>Wait <sup>(3, 4, 5, 7)</sup><br>Stop <sup>(5, 6)</sup> | I <sub>DD</sub><br>I <sub>DD</sub>  | _                       | 1.2<br>0.25        | 4.0<br>1.5          | mA<br>mA |
| 25°C<br>−40°C to +85°C                                                                         | I <sub>DD</sub><br>I <sub>DD</sub>  | _                       | 0.1<br>1           | 5<br>10             | μΑ<br>μΑ |
| I/O Ports Hi-Z Leakage Current<br>PA0-PA7, PB0-PB5 (without individual pulldown activated)     | I <sub>IL</sub>                     | _                       |                    | ±10                 | μA       |
| Input Pulldown Current<br>PA0-PA7, PB0-PB5 (with individual pulldown activated)                | I <sub>IL</sub>                     | 15                      | 30                 | 100                 | μA       |
| Input Pullup Current<br>RESET                                                                  | I <sub>IL</sub>                     | -10                     | -20                | -40                 | μA       |
| Input Current <sup>(8)</sup><br>RESET, IRQ/V <sub>PP</sub> , OSC1                              | I <sub>IN</sub>                     | _                       | _                  | ±1                  | μΑ       |
| Capacitance<br>Ports (as Input or Output)<br>RESET, IRQ/V <sub>PP</sub> , OSC1, OSC2           | C <sub>OUT</sub><br>C <sub>IN</sub> | _                       |                    | 12<br>8             | pF<br>pF |
| Crystal/Ceramic Resonator Oscillator Mode Internal Resistor<br>OSC1 to OSC2                    | R <sub>OSC</sub>                    | 1.0                     | 2.0                | 3.0                 | MΩ       |

| Table 11-4. DC Electrical Characteristics (V <sub>DD</sub> : | = 3.3 V) <sup>(1</sup> | ) |
|--------------------------------------------------------------|------------------------|---|
|--------------------------------------------------------------|------------------------|---|

1. V\_{DD} = 3.3 Vdc  $\pm$  10%, V\_{SS} = 0 Vdc, T\_A = -40°C to +85°C, unless otherwise noted

2. Typical values reflect average measurements at midpoint of voltage range, 25°C.

3. Wait  $I_{DD}$ : Only timer system active.

-

 Run (Operating) I<sub>DD</sub>, Wait I<sub>DD</sub>: Measured using external square wave clock source (f<sub>OP</sub> = 1.0 MHz), all inputs 0.2 V from rail; no dc loads, less than 50 pF on all outputs, C<sub>L</sub> = 20 pF on OSC2.

5. Wait, Stop I<sub>DD</sub>: All ports configured as inputs,  $V_{IL}$  = 0.2 V,  $V_{IH}$  =  $V_{DD}$  -0.2 V.

6. Stop  $I_{DD}$  measured with OSC1 =  $V_{SS}$ .

7. Wait  $I_{DD}$  is affected linearly by the OSC2 capacitance.

8. Only input high current rated to +1  $\mu$ A on RESET.



- 1. At V<sub>DD</sub> = 5.0 V, devices are specified and tested for (V<sub>DD</sub> V<sub>OH</sub>)  $\leq$  800 mV @ I<sub>OL</sub> = -0.8 mA.
- 2. At V<sub>DD</sub> = 3.3 V, devices are specified and tested for (V<sub>DD</sub> V<sub>OH</sub>)  $\leq$  300 mV @ I<sub>OL</sub> = -0.2 mA.

Figure 11-1. PA0–PA7, PB0–PB5 Typical High-Side Driver Characteristics



NOTES:

1. At V<sub>DD</sub> = 5.0 V, devices are specified and tested for V<sub>OL</sub>  $\leq$  400 mV @ I<sub>OL</sub> = 1.6 mA. 2. At V<sub>DD</sub> = 3.3 V, devices are specified and tested for V<sub>OL</sub>  $\leq$  300 mV @ I<sub>OL</sub> = 0.4 mA.

#### Figure 11-2. PA0–PA3, PB0–PB5 Typical Low-Side Driver Characteristics



- 1. At V\_{DD} = 5.0 V, devices are specified and tested for V\_{OL}  $\leq$  400 mV @ I\_{OL} = 10.0 mA.
- 2. At  $V_{DD}$  = 3.3 V, devices are specified and tested for  $V_{OL} \le 300 \text{ mV} @ I_{OL} = 5.0 \text{ mA}.$

Figure 11-3. PA4–PA7 Typical Low-Side Driver Characteristics



#### NOTES:

- 1. At V<sub>DD</sub> = 5.0 V, devices are specified and tested for I<sub>DD</sub>  $\leq$  6.0 mA @ f<sub>OP</sub> = 2.1 MHz. 2. At V<sub>DD</sub> = 3.3 V, devices are specified and tested for I<sub>DD</sub>  $\leq$  4.0 mA @ f<sub>OP</sub> = 1.0 MHz.

Figure 11-4. Typical Operating I<sub>DD</sub> (25°C)

**ELECTRICAL SPECIFICATIONS** 



- 1. At V<sub>DD</sub> = 5.0 V, devices are specified and tested for I<sub>DD</sub>  $\leq$  2.75 mA @ f<sub>OP</sub> = 2.1 MHz. 2. At V<sub>DD</sub> = 3.3 V, devices are specified and tested for I<sub>DD</sub>  $\leq$  1.5 mA @ f<sub>OP</sub> = 1.0 MHz.

# Figure 11-5. Typical Wait Mode I<sub>DD</sub> (25°C)

#### **11.6 EPROM Programming Characteristics**

| Table 11-5. EPROM Programming Characteristics <sup>(1)</sup> | Table 11-5. | EPROM | Programming | Characteristics <sup>(1)</sup> |
|--------------------------------------------------------------|-------------|-------|-------------|--------------------------------|
|--------------------------------------------------------------|-------------|-------|-------------|--------------------------------|

| Characteristic                             | Symbol                                 | Min    | Тур  | Max  | Unit     |
|--------------------------------------------|----------------------------------------|--------|------|------|----------|
| Programming Voltage<br>IRQ/V <sub>PP</sub> | V <sub>PP</sub>                        | 16.0   | 16.5 | 17.0 | V        |
| Programming Current<br>IRQ/V <sub>PP</sub> | I <sub>PP</sub>                        | _      | 3.0  | 10.0 | mA       |
| Programming Time<br>Per Array Byte<br>MOR  | t <sub>EPGM</sub><br>t <sub>MPGM</sub> | 4<br>4 | _    |      | ms<br>ms |

NOTE: 1. V<sub>DD</sub> = 5.0 Vdc  $\pm$  10%, V<sub>SS</sub> = 0 Vdc, T<sub>A</sub> = -40°C to +85°C, unless otherwise noted.

#### **11.7 Control Timing**

| Characteristic                                                   | Symbol            | Min | Max    | Unit             |  |
|------------------------------------------------------------------|-------------------|-----|--------|------------------|--|
| Frequency of Operation                                           |                   |     |        |                  |  |
| Crystal Oscillator Option                                        | fosc              | _   | 4.2    | MHz              |  |
| External Clock Source                                            | fosc              | DC  | 4.2    | MHz              |  |
| Internal Operating Frequency                                     |                   |     |        |                  |  |
| Crystal Oscillator (f <sub>OSC</sub> ÷ 2)                        | f <sub>OP</sub>   | _   | 2.1    | MHz              |  |
| External Clock (f <sub>OSC</sub> ÷ 2)                            | f <sub>OP</sub>   | DC  | 2.1    | MHz              |  |
| Cycle Time (1/f <sub>OP</sub> )                                  | t <sub>CYC</sub>  | 476 | —      | ns               |  |
| RESET Pulse Width Low                                            | t <sub>RL</sub>   | 1.5 | —      | t <sub>CYC</sub> |  |
| IRQ Interrupt Pulse Width Low (Edge-Triggered)                   | t <sub>ILIH</sub> | 1.5 | —      | t <sub>CYC</sub> |  |
| IRQ Interrupt Pulse Width (Edge and Level Triggered)             | t <sub>ILIL</sub> | 1.5 | Note 2 | t <sub>CYC</sub> |  |
| PA0 through PA3 Interrupt Pulse Width High (Edge-Triggered)      | t <sub>IHIL</sub> | 1.5 | —      | t <sub>CYC</sub> |  |
| PA0 through PA3 Interrupt Pulse Width (Edge and Level Triggered) | t <sub>IHIH</sub> | 1.5 | Note 2 | t <sub>CYC</sub> |  |
| OSC1 Pulse Width                                                 | t                 | 200 | —      | ns               |  |

# Table 11-6. Control Timing (5 V)<sup>(1)</sup>

NOTES:

1.  $V_{DD}$  = 5.0 Vdc  $\pm$  10%,  $V_{SS}$  = 0 Vdc,  $T_A$  = –40°C to +85°C, unless otherwise noted

 The maximum width t<sub>ILIL</sub> or t<sub>IHIH</sub> should not be more than the number of cycles it takes to execute the interrupt service routine plus 19 t<sub>CYC</sub> or the interrupt service routine will be re-entered.

| Table 11-7. Control Timing (3.3 V) <sup>(1)</sup> |  |
|---------------------------------------------------|--|
|                                                   |  |

| Characteristic                                                   | Symbol            | Min  | Max    | Unit             |
|------------------------------------------------------------------|-------------------|------|--------|------------------|
| Frequency of Operation                                           |                   |      |        |                  |
| Crystal Oscillator Option                                        | fosc              | —    | 2.0    | MHz              |
| External Clock Source                                            | fosc              | DC   | 2.0    | MHz              |
| Internal Operating Frequency                                     |                   |      |        |                  |
| Crystal Oscillator (f <sub>OSC</sub> ÷ 2)                        | f <sub>OP</sub>   | —    | 1.0    | MHz              |
| External Clock (f <sub>OSC</sub> ÷ 2)                            | f <sub>OP</sub>   | DC   | 1.0    | MHz              |
| Cycle Time (1/f <sub>OP</sub> )                                  | t <sub>CYC</sub>  | 1000 | -      | ns               |
| RESET Pulse Width Low                                            | t <sub>RL</sub>   | 1.5  | —      | t <sub>CYC</sub> |
| IRQ Interrupt Pulse Width Low (Edge-Triggered)                   | t <sub>ILIH</sub> | 1.5  | -      | t <sub>CYC</sub> |
| IRQ Interrupt Pulse Width (Edge and Level Triggered)             | t <sub>ILIL</sub> | 1.5  | Note 2 | t <sub>CYC</sub> |
| PA0 through PA3 Interrupt Pulse Width High (Edge-Triggered)      | t <sub>IHIL</sub> | 1.5  | —      | t <sub>CYC</sub> |
| PA0 through PA3 Interrupt Pulse Width (Edge and Level Triggered) | t <sub>IHIH</sub> | 1.5  | Note 2 | t <sub>CYC</sub> |
| OSC1 Pulse Width                                                 | t                 | 400  | _      | ns               |

NOTES:

1.  $V_{DD}$  = 3.3 Vdc ± 10%,  $V_{SS}$  = 0 Vdc,  $T_A$  = -40°C to +85°C, unless otherwise noted

2. The maximum width t<sub>ILIL</sub> or t<sub>IHIH</sub> should not be more than the number of cycles it takes to execute the interrupt service routine plus 19 t<sub>CYC</sub> or the interrupt service routine will be re-entered.







1. Internal clocking from OSC1 pin.

2. Edge-triggered external interrupt mask option.

Edge- and level-triggered external interrupt mask option.
 Reset vector shown as example.

# Figure 11-7. Stop Mode Recovery Timing



1. Power-on reset threshold is typically between 1 V and 2 V.

2. Internal clock, internal address bus, and internal data bus are not available externally.





#### NOTES:

1. Internal clock, internal address bus, and internal data bus are not available externally.

2. The next rising edge of the internal clock after the rising edge of RESET initiates the reset sequence.

#### Figure 11-9. External Reset Timing

#### SECTION 12 MECHANICAL SPECIFICATIONS

#### **12.1 Introduction**

This section gives the dimensions of the plastic dual in-line package (PDIP) and the small outline integrated circuit (SOIC) package.

#### 12.2 PDIP Package (Case 738-03)



#### 12.3 SOIC Package (Case 751D-04)



- NOTES: 1. DIMENSIONING AND TOLERANCING PER

1. DIMENSIONING AND TOLERANCING PER ANSI Y14.5M, 1982.
 2. CONTROLLING DIMENSION: MILLIMETER.
 3. DIMENSIONS A AND B DO NOT INCLUDE MOLD PROTRUSION.
 4. MAXIMUM MOLD PROTRUSION 0.150 (0.006) PER SIDE.
 5. DIMENSION D DOES NOT INCLUDE DAMBAR PROTRUSION. ALLOWABLE DAMBAR PROTRUSION. SHALL BE 0.13 (0.005) TOTAL IN EXCESS OF D DIMENSION AT MAXIMUM MATERIAL CONDITION.

|     | MILLIM     | ETERS      | INC       | HES        |
|-----|------------|------------|-----------|------------|
| DIM | MIN        | MAX        | MIN       | MAX        |
| Α   | 12.65      | 12.95      | 0.499     | 0.510      |
| В   | 7.40       | 7.60       | 0.292     | 0.299      |
| С   | 2.35       | 2.65       | 0.093     | 0.104      |
| D   | 0.35       | 0.49       | 0.014     | 0.019      |
| F   | 0.50       | 0.90       | 0.020     | 0.035      |
| G   | 1.27 BSC   |            | 0.050 BSC |            |
| J   | 0.25       | 0.32       | 0.010     | 0.012      |
| K   | 0.10       | 0.25       | 0.004     | 0.009      |
| М   | <b>0</b> ° | <b>7</b> ° | 0°        | <b>7</b> ° |
| Р   | 10.05      | 10.55      | 0.395     | 0.415      |
| R   | 0.25       | 0.75       | 0.010     | 0.029      |