

### **Freescale Semiconductor**

Order this document by MC68HC05D9/D Rev 3.0



# MC68HC05D9 MC68HC05D24 MC68HC05D32 MC68HC705D32

**HCMOS Microcontroller Unit** 

**TECHNICAL DATA** 

© Freescale Semiconductor, Inc., 2004. All rights reserved.



For More Information On This Product, Go to: www.freescale.com





# **List of Sections**

| List of Sections 3                           |
|----------------------------------------------|
| Table of Contents    5                       |
| Introduction                                 |
| Operating Modes and Pin Descriptions         |
| Central Processing Unit (CPU)                |
| Resets and Interrupts 43                     |
| Memory and Registers 53                      |
| Input/Output Ports 57                        |
| 16-bit Programmable TImer                    |
| Serial Communications Interface (SCI)        |
| Pulse Width Modulator (PWM)                  |
| Electrical Specifications                    |
| Mechanical Data and Ordering Information 111 |
| Features Specific to the MC68HC05D24 117     |
| Features Specific to the MC68HC05D32 121     |

© Motorola, Inc., 1998



List of Sections

| Features Specific to the MC68HC705D32 | 125 |
|---------------------------------------|-----|
| Glossary                              | 135 |
| Index                                 | 147 |
| Literature Updates                    | 153 |



# **Table of Contents**

List of Sections

Table of Contents

| Introduction                               | Contents                                                                                                                                                     |
|--------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operating Modes<br>and Pin<br>Descriptions | Contents13Operating Modes13Software-selectable options16Pin Descriptions17                                                                                   |
| Central Processing<br>Unit (CPU)           | Contents23Introduction24CPU Registers24Arithmetic/Logic Unit (ALU)27Instruction Set Overview28Addressing Modes28Instruction Types31Instruction Set Summary36 |
| Resets and<br>Interrupts                   | Contents                                                                                                                                                     |
| Memory and<br>Registers                    | Contents.53Introduction.53RAM.53ROM.54Registers.54                                                                                                           |



### Table of Contents

| Input/Output Ports                          | Contents.57Introduction.57Input/output programming.57Ports A, B and C.59Port D.59Port registers.60Other port considerations.61                                                                          |
|---------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 16-bit<br>Programmable<br>TImer             | Contents.63Introduction.63Counter.65Timer functions.67Timer during WAIT mode.72Timer during STOP mode.73Timer state diagrams.73                                                                         |
| Serial<br>Communications<br>Interface (SCI) | Contents.79Introduction.79Overview and features.80Functional description.81Data format.83Receiver wake-up operation.84Receive data (RDI).85Start bit detection.86Transmit data (TDO).89SCI registers.89 |
| Pulse Width<br>Modulator (PWM)              | Contents.99Introduction.99PWM counter.99PWM registers.100                                                                                                                                               |
| Electrical<br>Specifications                | Contents103Introduction103Maximum ratings103Thermal characteristics and power considerations103DC electrical characteristics106Control timing107                                                        |



| Mechanical Data<br>and Ordering<br>Information | Contents111Mechanical Data112Ordering information115                                                                                 |
|------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------|
| Features Specific to the MC68HC05D24           | Contents117Introduction117Memory map and registers117Programming model117                                                            |
| Features Specific to the MC68HC05D32           | Contents121Introduction121Memory map and registers121Programming model121                                                            |
| Features Specific to<br>the<br>MC68HC705D32    | Contents125Introduction125Operating mode selection125Pin descriptions126Memory127MC68HC705D32 EPROM description130Bootloader mode132 |
| Glossary                                       |                                                                                                                                      |
| Index                                          |                                                                                                                                      |
| Literature Updates                             | Literature Distribution Centers153Customer Focus Center154Mfax154Freescale SPS World Marketing World Wide Web Server154              |

MC68HC05D9 Rev 3.0





### Introduction

### Contents

| Seneral description | . 9 |
|---------------------|-----|
| eatures             | 10  |

### **General description**

The MC68HC05D9, with 16K bytes of masked ROM, is a member of the Freescale M68HC05 family of advanced HCMOS 8-bit single chip microcomputers. Based around the industry standard M68HC05 CPU core and its familiar, efficient instruction set, this device includes five 6-bit pulse width modulation (PWM) channels, a serial communications interface (SCI), computer operating properly (COP) watchdog timer, high current output port capable of driving LEDs and a 16-bit timer with input capture and output compare.

Devices similar to the MC68HC05D9 are described in a set of appendices at the back of this book.

| Device       | Appendix | Differences from MC68HC05D9 |
|--------------|----------|-----------------------------|
| MC68HC05D24  | А        | 24K bytes of ROM            |
| MC68HC05D32  | В        | 32K bytes of user           |
| MC68HC705D32 | С        | 32K bytes of EPROM          |

MC68HC05D9 Rev 3.0

1-intro



### Features

- 15920 bytes of masked User ROM (plus 10 bytes for User vectors) on the MC68HC05D9
  - or 24112 bytes of masked User ROM (plus 10 bytes for vectors) on the MC68HC05D24
  - or 32304 bytes of masked User ROM (plus 10 bytes for vectors) on the MC68HC05D32
  - or 32304 bytes of User EPROM (plus 10 bytes for vectors) on the MC68HC705D32
- 239 bytes of self-check ROM (including self-check vectors) on the three mask-programmable ROM devices; 239 bytes of bootloader ROM (including bootloader vectors) on the MC68HC705D32
- 352 bytes of RAM
- Memory-mapped I/O
- 31 bidirectional I/O Lines
- Fully static operation
- On-chip oscillator with crystal/ceramic resonator
- 16-bit capture/compare timer sub-system
- Five 6-bit pulse width modulation channels operating at 30 kHz
- High current LED drive output port (port B)
- Asynchronous serial communications interface (SCI) system
- Power saving STOP, WAIT and data-retention modes
- Single 3.0 to 5.5 Volt supply (2 Volt data retention mode)
- Computer operating properly (COP) watchdog timer with clock monitor
- Software programmable external interrupt sensitivity





| Device       | Non volatile memory                                                                                                         |  |  |
|--------------|-----------------------------------------------------------------------------------------------------------------------------|--|--|
| MC68HC05D9   | <ul> <li>15920 bytes User ROM (plus 10 bytes for vectors)</li> <li>239 bytes self-check ROM (including vectors)</li> </ul>  |  |  |
| MC68HC05D24  | <ul> <li>24112 bytes User ROM (plus 10 bytes for vectors)</li> <li>239 bytes self-check ROM (including vectors)</li> </ul>  |  |  |
| MC68HC05D32  | <ul> <li>32304 bytes User ROM (plus 10 bytes for vectors)</li> <li>239 bytes self-check ROM (including vectors)</li> </ul>  |  |  |
| MC68HC705D32 | <ul> <li>32304 bytes User EROM (plus 10 bytes for vectors)</li> <li>239 bytes self-check ROM (including vectors)</li> </ul> |  |  |

### Figure 1. Functional block diagram



MC68HC05D9 Rev 3.0

4-intro

#### Introduction For More Information On This Product, Go to: www.freescale.com

### **Operating Modes and Pin Descriptions**

### Contents

| Operating Modes             | 13 |
|-----------------------------|----|
| Single chip mode            | 14 |
| Self-check mode             | 14 |
| Software-selectable options | 16 |
| Option register             | 16 |
| Pin Descriptions            | 17 |
| VDD and VSS                 | 19 |
| VPP                         |    |
| OSC1/OSC2                   |    |
| RESET                       | 21 |
| IRQ                         | 21 |
| ТСАР                        | 21 |
| PA0–PA7                     | 21 |
| PB0–PB7                     | 21 |
| PC0–PC7                     | 22 |
| PD0–PD7                     | 22 |
| PD0/RDI                     | 22 |
| PD1/TDO                     | 22 |
| PD2–PD5, PD7/PWM0–PWM4      | 22 |
| PD6/TCMP                    | 22 |
|                             |    |

### **Operating Modes**

The MCU has two modes of operation: single chip mode and self-check mode. The mode of operation is determined by the voltage level present on the IRQ pin when the device is brought out of reset (see Table 2).



### **Operating Modes and Pin Descriptions**

# **Single chip mode** This is the normal operating mode of the MCU. In this mode the device functions as a self-contained microcomputer with all on-board peripherals available to the user, including the four 8-bit I/O ports.

**CAUTION:** For the MC68HC705D32 all vectors are fetched from EPROM (locations \$3FF6-\$3FFF or \$7FF6-\$7FFF) in single chip mode; therefore, the EPROM must be programmed (via the bootloader mode) before the device is powered up in single chip mode.

Single chip mode is entered on the rising edge of RESET if the voltage level on the IRQ pin is within the normal operating range.

| IRQ <sup>(1)</sup>                 | RESET | TCAP            | Mode        |
|------------------------------------|-------|-----------------|-------------|
| V <sub>SS</sub> to V <sub>DD</sub> |       | Don't care      | Single chip |
| 2 V <sub>DD</sub>                  |       | V <sub>DD</sub> | Self-check  |

### Table 2. Operating mode entry conditions

1. The voltage level on the IRQ pin should be maintained for at least 7x t<sub>CYC</sub> after the rising edge of the reset signal to guarantee proper mode selection.

# **Self-check mode** The MCU contains, in masked ROM at locations \$3F00 to \$3FDE (or \$7F00 to \$7FDE), a program that checks the integrity of the device with a minimum of support hardware (see Figure 2). To enter self-check mode, a voltage equal to 2x V<sub>DD</sub> must be present on the IRQ pin when the device is brought out of reset.

**NOTE:** The TCAP pin must be tied to  $V_{DD}$  to ensure correct selection of the self-check mode. Failure to do so could result in unpredictable operation.





Figure 2. Self-check circuit diagram (for 40-pin DIL package)

The self-check program indicates the results of its tests by outputting a 4-bit code on the lower four bits of port C (PC0–3). The fault codes are detailed in Table 3.

| PC3 | PC2 | PC1 | PC0 | Result    |
|-----|-----|-----|-----|-----------|
| 1   | 0   | 0   | 1   | Bad I/O   |
| 1   | 0   | 1   | 0   | Bad RAM   |
| 1   | 0   | 1   | 1   | Bad timer |

| Table 3. Self-check mode fault indicat | ion |
|----------------------------------------|-----|
|----------------------------------------|-----|



Semiconductor, Inc.

reescale

**Freescale Semiconductor, Inc.** 

### **Operating Modes and Pin Descriptions**

| 1         | 1 | 0 | 0 | Bad SCI               |
|-----------|---|---|---|-----------------------|
| 1         | 1 | 0 | 1 | Bad ROM               |
| 1         | 1 | 1 | 0 | Bad PWM               |
| 1         | 1 | 1 | 1 | Bad interrupts or IRQ |
| Flashing  |   |   |   | Good device           |
| All other |   |   |   | Bad device            |

### Table 3. Self-check mode fault indication

'0' denotes LED on; '1' denotes LED off

### Software-selectable options

Option register The option register (OPTION) is a user-writable register located at \$3FDF on the MC68HC05D9 (\$7FDF on the MC68HC05D24 and MC68HC05D32). It allows the user to configure the memory map and the external interrupt IRQ.



Figure 3. Options register (OPTION)

*RAM0* 

- This bit maps 48 bytes of either RAM or ROM into the memory map from \$0020 to \$004F. This bit is readable and writable at all times, allowing the user software to switch back and forth between RAM and ROM when necessary. Reset clears this bit.
  - 1 = Maps 48 bytes of RAM into the memory map starting at address \$0020.
  - 0 = Maps 48 bytes of ROM/EPROM into the memory map starting at address \$0020.



| RAM1 | This bit maps 128 bytes of either RAM or ROM/EPROM into the memory map from \$0100 to \$017F. This bit is readable and writable at all times, allowing the user software to switch back and forth between RAM and ROM/EPROM when necessary. Reset clears this bit. |
|------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|      | <ul> <li>1 = Maps 128 bytes of RAM into the memory map starting at address \$0100.</li> <li>0 = Maps 128 bytes of ROM/EPROM into the memory map starting at address \$0100.</li> </ul>                                                                             |
| IRQ  | This bit selects the external interrupt IRQ sensitivity. This bit is not readable and can only be written once after reset. Reset sets this bit.<br>1 = Edge-and-level sensitive interrupt selected.<br>0 = Edge sensitive only option is selected.                |

### **Pin Descriptions**

**Figure 4** shows the pin-out for this family of devices for the 40-pin plastic dual-in-line package (PDIP) and the 44-pin plastic leadless chip-carrier (PLCC).

5-pins



Semiconductor, Inc

٩

reescal

### **Operating Modes and Pin Descriptions**



### Figure 4. Pin assignments for MC68HC05D9 packages

MC68HC05D9 Rev 3.0

6-pins



VDD and VSSPower is supplied to the microcomputer via these two pins. VDD is the<br/>positive supply and VSS is ground.

It is in the nature of CMOS designs that very fast signal transitions occur on the MCU pins. These short rise and fall times place very high short-duration current demands on the power supply. To prevent noise problems, special care must be taken to provide good power supply by-passing at the MCU. By-pass capacitors should have good high-frequency characteristics and be as close to the MCU as possible. By-passing requirements vary, depending on how heavily the MCU pins are loaded.

### OSC1/OSC2

These pins provide control input for an on-chip clock oscillator circuit. A crystal, ceramic resonator or external clock signal connected to these pins provides the oscillator clock. The oscillator frequency is divided by 2 to provide the internal bus frequency.

CrystalThe circuit shown in Figure 5(a) is recommended when using a crystal.<br/>The internal oscillator is designed to interface with an AT-cut<br/>parallel-resonant quartz crystal resonator in the frequency range<br/>specified for  $f_{osc}$  (see Control timing). Use of an external CMOS<br/>oscillator is recommended when crystals outside the specified ranges<br/>are to be used. The crystal and components should be mounted as close<br/>as possible to the input pins to minimise output distortion and start-up<br/>stabilization time.

Ceramic resonator A ceramic resonator may be used instead of a crystal in cost-sensitive applications. The circuit in **Figure 5**(a) is recommended when using a ceramic resonator. **Figure 5**(d) lists the recommended capacitance and feedback resistance values. The manufacturer of the particular ceramic

7-pins



### **Operating Modes and Pin Descriptions**

resonator being considered should be consulted for specific information. .





| Crystal              |         |         |      |  |  |  |
|----------------------|---------|---------|------|--|--|--|
|                      | 2MHz    | 4MHz    | Unit |  |  |  |
| R <sub>S</sub> (max) | 400     | 75      | Ω    |  |  |  |
| C <sub>0</sub>       | 5       | 7       | pF   |  |  |  |
| C <sub>1</sub>       | 8       | 12      | nF   |  |  |  |
| C <sub>OSC1</sub>    | 15 – 40 | 15 – 30 | pF   |  |  |  |
| C <sub>OSC2</sub>    | 15 – 30 | 15 – 25 | pF   |  |  |  |
| R <sub>P</sub>       | 10      | 10      | MΩ   |  |  |  |
| Q                    | 30 000  | 40 000  | —    |  |  |  |

| 2 – 4 MHz | Unit                                  |  |  |  |  |
|-----------|---------------------------------------|--|--|--|--|
| 10        | Ω                                     |  |  |  |  |
| 40        | pF                                    |  |  |  |  |
| 4.3       | pF                                    |  |  |  |  |
| 30        | pF                                    |  |  |  |  |
| 30        | pF                                    |  |  |  |  |
| 1 – 10    | MΩ                                    |  |  |  |  |
| 1250      | —                                     |  |  |  |  |
|           | 10<br>40<br>4.3<br>30<br>30<br>1 - 10 |  |  |  |  |

Ceramic resonator

(d) Crystal and ceramic resonator parameters

Figure 5. Oscillator connections



Operating Modes and Pin Descriptions Pin Descriptions

External clockAn external clock should be applied to the OSC1 input with the OSC2 pin<br/>not connected, as shown in Figure 5(c). The t<sub>OXOV</sub> specification does<br/>not apply when using an external clock input. The equivalent<br/>specification of the external clock source should be used in lieu of t<sub>OXOV</sub>.

**RESET** This pin is used to apply an active low reset signal to the MCU. Applying a logic zero to this pin forces the device to a known start-up state. An external RC circuit can be connected to this pin to generate a power-on reset (POR). In this case, the time constant must be chosen high enough (minimum 100 ms) to allow the oscillator circuit to stabilise. This input has an internal Schmitt trigger to improve noise immunity. When a reset condition occurs internally, i.e. from the COP watchdog or clock monitor circuitry, this pin provides an active-low open drain output signal which may be used to reset external hardware.

IRQ Is an input pin for external interrupt sources. The interrupt type (edge or edge-and-level sensitive) can be selected via the option register.

TCAPAn external signal can be applied to this input pin to trigger an input<br/>capture event in the 16-bit timer. Input capture can be programmed to<br/>occur on either the rising edge or the falling edge of the signal applied to<br/>TCAP (see 16-bit Programmable TImer).

PA0-PA7Port A comprises eight bidirectional pins (PA0 to PA7). The direction and<br/>state of each pin is software programmable. All pins are configured as<br/>inputs during power-on or reset.

PB0–PB7Port B comprises eight bidirectional pins (PB0 to PB7). The direction and<br/>state of each pin is software programmable, and each pin can drive one<br/>LED load. All pins are configured as inputs during power-on or reset.

9-pins



### **Operating Modes and Pin Descriptions**

| PCO-PC7                   | Port C comprises eight bidirectional pins (PC0 to PC7). The direction and state of each pin is software programmable. All pins are configured as inputs during power-on or reset.                                                                                                                                                                                                                                                         |
|---------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PD0–PD7                   | Port D comprises seven bidirectional pins (PD0 to PD5, PD7), with each<br>pin supporting one of the on-chip hardware functions. PD6 is dedicated<br>to the TCMP pin and is always an output, therefore a read of bit 6 of the<br>port D data register will always return the value on the TCMP pin.                                                                                                                                       |
| PD0/RDI                   | When the SCI is enabled, this pin is configured as the high-impedance receive data input pin and the SCI becomes active. When the SCI is disabled, this pin is configured as a normal I/O port pin.                                                                                                                                                                                                                                       |
| PD1/TDO                   | When the SCI is enabled, this pin is configured as the transmit data output pin and the SCI becomes active. When the SCI is disabled, this pin is configured as a normal I/O port pin.                                                                                                                                                                                                                                                    |
| PD2–PD5,<br>PD7/PWM0–PWM4 | When the associated PWM enable bits in the PWM mode register are set, these pins are configured to output the PWM signals. When the PWM channels are disabled, these pins are configured as normal I/O pins.                                                                                                                                                                                                                              |
| PD6/TCMP                  | As an output, this pin is always configured to support the output compare<br>function in the 16-bit timer. Consequently, there is no corresponding<br>data direction register bit associated with this pin. Reading the<br>associated bit in the port D data register always returns the<br>instantaneous value present on the pin, whether this is caused by the<br>output compare function or by an external signal applied to the pin. |

MC68HC05D9 Rev 3.0

10-pins



# Central Processing Unit (CPU)

### Contents

| Introduction                   |
|--------------------------------|
| CPU Registers                  |
| Accumulator                    |
| Index Register                 |
| Stack Pointer                  |
| Program Counter                |
| Condition Code Register        |
| Arithmetic/Logic Unit (ALU)    |
| Instruction Set Overview       |
| Addressing Modes               |
| Inherent                       |
| Immediate                      |
| Direct                         |
| Extended                       |
| Indexed, No Offset             |
| Indexed, 8-Bit Offset          |
| Indexed,16-Bit Offset          |
| Relative                       |
| Instruction Types              |
| Register/Memory Instructions   |
| Read-Modify-Write Instructions |
| Jump/Branch Instructions       |
| Bit Manipulation Instructions  |
| Control Instructions           |
| Instruction Set Summary        |



### Introduction

This chapter describes the CPU registers and the HC05 instruction set.

### **CPU Registers**

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



Figure 6. Programming Model

# 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.







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



Figure 8. Index Register

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

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 |   |   |   |   |   |   |   |   |   |   |   |   |   |   | Bit 0 |
|-------|--------|---|---|---|---|---|---|---|---|---|---|---|---|---|---|-------|
|       | 0      | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 |   |   |   |   |   |       |
| Reset | 0      | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1     |

Figure 9. 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.



Semiconductor, Inc

reescale

**Freescale Semiconductor, Inc.** 

### **Central Processing Unit (CPU)**

Program CounterThe program counter is a 16-bit register that contains the address of the<br/>next instruction or operand to be fetched. The two most significant bits<br/>of the program counter are ignored internally.

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 10. Program Counter

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



Figure 11. Condition Code Register

### Half-Carry Flag

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

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**

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

### Zero Flag

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

### Carry/Borrow Flag

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.

### 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.



### **Instruction Set Overview**

The MCU instruction set has 62 instructions and uses eight addressing modes. The instructions include all those of the M146805 CMOS Family plus one more: the unsigned multiply (MUL) instruction. The MUL instruction allows unsigned multiplication of the contents of the accumulator (A) and the index register (X). The high-order product is stored in the index register, and the low-order product is stored in the accumulator.

### **Addressing Modes**

The CPU uses eight addressing modes for flexibility in accessing data. The addressing modes provide eight different ways for the CPU to find the data required to execute an instruction. The eight addressing modes are:

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

### 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 operand address and are one byte long.



- 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 operand address and are two bytes long. The opcode is the first byte, and the immediate data value is the second byte.
- Direct Direct instructions can access any of the first 256 memory locations 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.

#### Extended Extended instructions use three bytes and can 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 Freescale 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.

# Indexed, No Offset

Indexed instructions with no offset are 1-byte instructions that can access data with variable addresses within the first 256 memory locations. The index register contains the low byte of the effective 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.

### Indexed, 8-Bit Offset

Indexed, 8-bit offset instructions are 2-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 effective 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



### **Central Processing Unit (CPU)**

k value is typically in the index register, and the address of the beginning of the table is in the byte following the opcode.

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

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 Freescale assembler determines the shortest form of indexed addressing.

Relative

Relative addressing is only for branch instructions. If the branch condition is true, the CPU finds the effective 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 Freescale 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.



### **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

### Register/Memory Instructions

These instructions operate on CPU registers and memory locations. Most of them use two operands. One operand is in either the accumulator or the index register. The CPU finds the other operand in memory.

| 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 4. Register/Memory Instructions



### **Central Processing Unit (CPU)**

Read-Modify-WritThese instructions read a memory location or a register, modify itse Instructionscontents, and write the modified value back to the memory location or to<br/>the register.

**NOTE:** Do not use read-modify-write operations on write-only registers.

| ASL<br>ASR<br>BCLR <sup>(1)</sup><br>BSET <sup>(1)</sup><br>CLR |
|-----------------------------------------------------------------|
| BCLR <sup>(1)</sup><br>BSET <sup>(1)</sup>                      |
| BSET <sup>(1)</sup>                                             |
|                                                                 |
| CLR                                                             |
|                                                                 |
| COM                                                             |
| DEC                                                             |
| INC                                                             |
| LSL                                                             |
| LSR                                                             |
| NEG                                                             |
| ROL                                                             |
| ROR                                                             |
| TST <sup>(2)</sup>                                              |
|                                                                 |

### Table 5. Read-Modify-Write Instructions

1. Unlike other read-modify-write instructions, BCLR and BSET use only direct addressing.

2. TST is an exception to the read-modify-write sequence because it does not write a replacement value.



Jump/Branch 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.

The BRCLR and BRSET instructions cause a branch based on the state of any readable bit in the first 256 memory locations. These 3-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 effective 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.



### Central Processing Unit (CPU)

### Table 6. 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               | BHI      |
| 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      |



### Bit Manipulation Instructions

The CPU can set or clear any writable bit in the first 256 bytes of memory, which includes I/O registers and on-chip RAM locations. The CPU can also test and branch based on the state of any bit in any of the first 256 memory locations.

### Table 7. Bit Manipulation Instructions

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

### Control Instructions

These instructions act on CPU registers and control CPU operation during program execution.

### **Table 8. Control Instructions**

| 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     |  |  |  |



### **Instruction Set Summary**

| Source<br>Form                                                     | Operation                             | Description                                            |    | Eff<br>( | ec<br>CC |    | n       | Address<br>Mode                                                                                                      | Opcode                           | Operand                                            | Cycles                                         |
|--------------------------------------------------------------------|---------------------------------------|--------------------------------------------------------|----|----------|----------|----|---------|----------------------------------------------------------------------------------------------------------------------|----------------------------------|----------------------------------------------------|------------------------------------------------|
|                                                                    |                                       |                                                        | Н  | I        | N        | z  | С       | Add                                                                                                                  |                                  |                                                    |                                                |
| ADC #opr<br>ADC opr<br>ADC opr<br>ADC opr,X<br>ADC opr,X<br>ADC ,X | Add with Carry                        | A ← (A) + (M) + (C)                                    | ¢¢ |          | ¢¢       | ţ0 | ↓ ↓ ↓ ↓ | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX                                                                                | A9<br>B9<br>C9<br>D9<br>E9<br>F9 | ii<br>dd<br>hh II<br>ee ff<br>ff                   | 1 . 1                                          |
| ADD #opr<br>ADD opr<br>ADD opr<br>ADD opr,X<br>ADD opr,X<br>ADD ,X | Add without Carry                     | A ← (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 II<br>ee ff<br>ff                   |                                                |
| 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 II<br>ee ff<br>ff                   | 1 . 1                                          |
| ASL opr<br>ASLA<br>ASLX<br>ASL opr,X<br>ASL ,X                     | Arithmetic Shift Left (Same as LSL)   | C ←                                                    |    |          | ţ0       | \$ | \$      | 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 Clear             | $PC \leftarrow (PC) + 2 + \mathit{rel} ? C = 0$        | 1- | -        | 1-       | 1- | - -     | 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 (b5)<br>DIR (b6)<br>DIR (b7) | 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 |
| BCS rel                                                            | Branch if Carry Bit Set (Same as BLO) | PC ← (PC) + 2 + <i>rel</i> ? C = 1                     | 1- | -        |          |    | -       | REL                                                                                                                  | 25                               | rr                                                 | 3                                              |
| BEQ rel                                                            | Branch if Equal                       | PC ← (PC) + 2 + <i>rel</i> ? Z = 1                     | _  | _        | _        | -  | -       | REL                                                                                                                  | 27                               | rr                                                 | 3                                              |
| BHCC rel                                                           | Branch if Half-Carry Bit Clear        | $PC \leftarrow (PC) + 2 + \mathit{rel} ? H = 0$        | _  |          | _        | _  | _       | REL                                                                                                                  | 28                               | rr                                                 | 3                                              |
| BHCS rel                                                           | Branch if Half-Carry Bit Set          | PC ← (PC) + 2 + <i>rel</i> ? H = 1                     | _  | -        | -        | -  | -       | REL                                                                                                                  | 29                               | rr                                                 | 3                                              |
| BHI <i>rel</i>                                                     | Branch if Higher                      | $PC \leftarrow (PC) + 2 + \mathit{rel} ? C \lor Z = 0$ | -  |          | -        | -  | · -     | REL                                                                                                                  | 22                               | rr                                                 | 3                                              |

### **Table 9. Instruction Set Summary**

MC68HC05D9 Rev 3.0

23-cpu



| Source                                                             | Operation                             | Description                                                                                                                                                                | I  | Eff | ect<br>Cl |    | n  | Address<br>Mode                                                                                                      | Opcode                           | Operand                                                     | Cycles                                         |
|--------------------------------------------------------------------|---------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|-----|-----------|----|----|----------------------------------------------------------------------------------------------------------------------|----------------------------------|-------------------------------------------------------------|------------------------------------------------|
| Form                                                               | •                                     | •                                                                                                                                                                          | н  | I   | Ν         | z  | С  | Ado                                                                                                                  | 0<br>0                           | Ope                                                         | Š                                              |
| BHS rel                                                            | Branch if Higher or Same              | $PC \leftarrow (PC) + 2 + rel? C = 0$                                                                                                                                      | -  | _   | _         | —  | -  | REL                                                                                                                  | 24                               | rr                                                          | 3                                              |
| BIH rel                                                            | Branch if IRQ Pin High                | PC ← (PC) + 2 + <i>rel</i> ? IRQ = 1                                                                                                                                       | 1- | —   | _         | _  |    | REL                                                                                                                  | 2F                               | rr                                                          | 3                                              |
| BIL rel                                                            | Branch if IRQ Pin Low                 | $PC \leftarrow (PC) + 2 + rel ? 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 Accumulator with 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 |                                                             | 2<br>3<br>4<br>5<br>4<br>3                     |
| BLO rel                                                            | Branch if Lower (Same as BCS)         | $PC \leftarrow (PC) + 2 + \mathit{rel} ? C = 1$                                                                                                                            | -  | —   | —         | —  | —  | REL                                                                                                                  | 25                               | rr                                                          | 3                                              |
| BLS rel                                                            | Branch if Lower or Same               | $PC \leftarrow (PC) + 2 + \mathit{rel} ? C \lor Z = 1$                                                                                                                     | -  | —   | _         | _  | —  | REL                                                                                                                  | 23                               | rr                                                          | 3                                              |
| BMC rel                                                            | Branch if Interrupt Mask Clear        | $PC \leftarrow (PC) + 2 + \mathit{rel} ? I = 0$                                                                                                                            | -  | —   | —         | —  | _  | REL                                                                                                                  | 2C                               | rr                                                          | 3                                              |
| BMI <i>rel</i>                                                     | Branch if Minus                       | PC ← (PC) + 2 + <i>rel</i> ? N = 1                                                                                                                                         |    | -   |           | —  |    | REL                                                                                                                  | 2B                               | rr                                                          | 3                                              |
| BMS rel                                                            | Branch if Interrupt Mask Set          | $PC \leftarrow (PC) + 2 + \mathit{rel} ? I = 1$                                                                                                                            | -  | —   | _         | _  | —  | REL                                                                                                                  | 2D                               | rr                                                          | 3                                              |
| BNE rel                                                            | 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 rel                                                            | Branch Always                         | PC ← (PC) + 2 + <i>rel</i> ? 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 (b4)<br>DIR (b5)<br>DIR (b5)<br>DIR (b6)<br>DIR (b7)             | 03<br>05<br>07<br>09<br>0B<br>0D |                                                             | 5<br>5<br>5<br>5<br>5<br>5<br>5                |
| BRN rel                                                            | Branch Never                          | $PC \leftarrow (PC) + 2 + \mathit{rel} ? 1 = 0$                                                                                                                            | 1- | -   | _         |    |    | REL                                                                                                                  | 21                               | rr                                                          | 3                                              |
| 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 (b5)<br>DIR (b6)<br>DIR (b7) | 02<br>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<br>dd rr | 5<br>5<br>5<br>5<br>5<br>5<br>5<br>5           |
| BSET n opr                                                         | Set Bit n                             | Mn ← 1                                                                                                                                                                     |    |     |           |    |    | 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)             | 12<br>14<br>16<br>18<br>1A<br>1C | 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 Subroutine                  | $\begin{array}{c} 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 ← 0                                                                                                                                                                      | _  | —   |           | —  | 0  | INH                                                                                                                  | 98                               |                                                             | 2                                              |

#### Table 9. Instruction Set Summary (Continued)

24-cpu



## Central Processing Unit (CPU)

| Source                                                             | Operation                                 | Description                                                                                                                                                                                                                                               |    | Eff | eci<br>CC |     | n    | Address<br>Mode                       | Opcode                           | Operand                          | Cycles                     |
|--------------------------------------------------------------------|-------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|-----|-----------|-----|------|---------------------------------------|----------------------------------|----------------------------------|----------------------------|
| Form                                                               |                                           | Decemption                                                                                                                                                                                                                                                | н  | I   | Ν         | z   | С    | Add                                   | obc                              | Ope                              | ပ်                         |
| CLI                                                                | Clear Interrupt Mask                      | l ← 0                                                                                                                                                                                                                                                     | 1- | 0   | —         | -   | 1-   | 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 Accumulator with 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 (One's Complement)        | $\begin{split} M &\leftarrow (\overline{M}) = \$FF - (M) \\ A &\leftarrow (\overline{A}) = \$FF - (A) \\ X &\leftarrow (\overline{X}) = \$FF - (X) \\ M &\leftarrow (\overline{M}) = \$FF - (M) \\ M &\leftarrow (\overline{M}) = \$FF - (M) \end{split}$ | _  | _   | ¢¢        | ţ¢  | 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 Register with Memory Byte   | (X) – (M)                                                                                                                                                                                                                                                 | _  | _   | ¢¢        | 0\$ | \$\$ | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX | A3<br>B3<br>C3<br>D3<br>E3<br>F3 | ii<br>dd<br>hh II<br>ee ff<br>ff | 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 Accumulator with 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 | ii<br>dd<br>hh II<br>ee ff<br>ff | 2<br>3<br>4<br>5<br>4<br>3 |
| 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>CC<br>DC<br>EC<br>FC       | hh II<br>ee ff<br>ff             |                            |

## Table 9. Instruction Set Summary (Continued)

Semiconductor, Inc.

Freescale

MC68HC05D9 Rev 3.0

25-cpu



## Freescale Semiconductor, Inc.

| Source                                                             | Operation                            | Description                                                                                                                                                                                                  |   |   | eci<br>CC |    | n  | Address<br>Mode                       | Opcode                           | Operand                          | Cycles                |
|--------------------------------------------------------------------|--------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|-----------|----|----|---------------------------------------|----------------------------------|----------------------------------|-----------------------|
| Form                                                               |                                      |                                                                                                                                                                                                              | Н | I | N         | z  | С  | Add                                   | opo                              | Ope                              | ð                     |
| JSR opr<br>JSR opr<br>JSR opr,X<br>JSR opr,X<br>JSR ,X             | Jump to Subroutine                   | $\begin{array}{c} PC \leftarrow (PC) + n \ (n = 1,  2,  \text{or} \ 3) \\ Push \ (PCL); \ SP \leftarrow (SP) - 1 \\ Push \ (PCH); \ SP \leftarrow (SP) - 1 \\ PC \leftarrow Effective \ Address \end{array}$ | _ |   | _         |    |    | DIR<br>EXT<br>IX2<br>IX1<br>IX        | BD<br>CD<br>DD<br>ED<br>FD       | dd<br>hh II<br>ee ff<br>ff       |                       |
| LDA #opr<br>LDA opr<br>LDA opr<br>LDA opr,X<br>LDA opr,X<br>LDA ,X | Load Accumulator 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 |                       |
| LDX #opr<br>LDX opr<br>LDX opr<br>LDX opr,X<br>LDX opr,X<br>LDX ,X | Load Index Register 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 |                       |
| LSL opr<br>LSLA<br>LSLX<br>LSL opr,X<br>LSL ,X                     | Logical Shift Left (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 opr<br>LSRA<br>LSRX<br>LSR opr,X<br>LSR ,X                     | Logical Shift Right                  |                                                                                                                                                                                                              | _ |   | 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>3<br>6<br>5 |
| MUL                                                                | Unsigned Multiply                    | $X:A \leftarrow (X) \times (A)$                                                                                                                                                                              | 0 | _ | —         | _  | 0  | INH                                   | 42                               |                                  | 11                    |
| NEG opr<br>NEGA<br>NEGX<br>NEG opr,X<br>NEG ,X                     | Negate Byte (Two's Complement)       | $\begin{array}{c} 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       | dd<br>ff                         | 5<br>3<br>3<br>6<br>5 |
| NOP                                                                | No Operation                         |                                                                                                                                                                                                              | - |   | -         |    | -  | INH                                   | 9D                               |                                  | 2                     |
| ORA #opr<br>ORA opr<br>ORA opr<br>ORA opr,X<br>ORA opr,X<br>ORA ,X | Logical OR Accumulator with Memory   | $A \gets (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 II<br>ee ff<br>ff |                       |
| ROL <i>opr</i><br>ROLA<br>ROLX<br>ROL <i>opr</i> ,X<br>ROL ,X      | Rotate Byte Left through Carry Bit   | □<br>C<br>↓<br>b7<br>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 |

#### Table 9. Instruction Set Summary (Continued)



## Central Processing Unit (CPU)

#### Table 9. Instruction Set Summary (Continued)

| Source<br>Form                                                     | Operation                                              | Description                                                                                                                                                                                                                                                                                                                                                      |    |    | ect<br>CC |    | n  | Address<br>Mode                       | Opcode                           | Operand                          | Cycles                |
|--------------------------------------------------------------------|--------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|-----------|----|----|---------------------------------------|----------------------------------|----------------------------------|-----------------------|
| Form                                                               |                                                        |                                                                                                                                                                                                                                                                                                                                                                  | н  | I  | Ν         | Z  | С  | Add                                   | opo                              | Ope                              | Ž                     |
| ROR <i>opr</i><br>RORA<br>RORX<br>ROR <i>opr</i> ,X<br>ROR ,X      | Rotate Byte Right through Carry Bit                    |                                                                                                                                                                                                                                                                                                                                                                  | _  | _  | ¢¢        | \$ | \$ | 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 \leftarrow \$00FF$                                                                                                                                                                                                                                                                                                                                           | —  | _  | —         |    | —  | INH                                   | 9C                               |                                  | 2                     |
| RTI                                                                | Return from Interrupt                                  | $\begin{array}{c} 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                               |                                  | 9                     |
| RTS                                                                | Return from Subroutine                                 | $SP \leftarrow (SP) + 1; Pull (PCH)$ $SP \leftarrow (SP) + 1; Pull (PCL)$                                                                                                                                                                                                                                                                                        | _  | -  | -         |    | _  | INH                                   | 81                               |                                  | 6                     |
| SBC #opr<br>SBC opr<br>SBC opr<br>SBC opr,X<br>SBC opr,X<br>SBC ,X | Subtract Memory Byte and Carry Bit from<br>Accumulator | $A \leftarrow (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 II<br>ee ff<br>ff |                       |
| SEC                                                                | Set Carry Bit                                          | C ← 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 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       |                       |
| STOP                                                               | Stop Oscillator and 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 Register In Memory                         | $M \gets (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       | -                     |
| SUB #opr<br>SUB opr<br>SUB opr<br>SUB opr,X<br>SUB opr,X<br>SUB ,X | Subtract Memory Byte from Accumulator                  | $A \gets (A) - (M)$                                                                                                                                                                                                                                                                                                                                              | _  |    | \$        | \$ | \$ | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX | A0<br>B0<br>C0<br>D0<br>E0<br>F0 | ii<br>dd<br>hh II<br>ee ff<br>ff |                       |
| SWI                                                                | Software Interrupt                                     | $\begin{array}{c c} 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                               |                                  | 1(                    |
| ТАХ                                                                | Transfer Accumulator to Index Register                 | $X \leftarrow (A)$                                                                                                                                                                                                                                                                                                                                               | _  |    |           |    | _  | INH                                   | 97                               |                                  | 2                     |

MC68HC05D9 Rev 3.0

27-cpu

#### Central Processing Unit (CPU) For More Information On This Product, Go to: www.freescale.com



| Source Operation                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Description                                                                                        | I                                                              | Eff<br>C                               | eci<br>CC                |                            | n    | Address<br>Mode                | Opcode                     | Operand  | Cvcles           |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------|----------------------------------------------------------------|----------------------------------------|--------------------------|----------------------------|------|--------------------------------|----------------------------|----------|------------------|
| Form                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 2000.10.00                                                                                         | н                                                              | I                                      | N                        | Z                          | С    | Add                            | odo                        | Ope      | 2<br>S           |
| TST opr<br>TSTA<br>TSTX<br>TST opr,X<br>TST ,X<br>TST ,X                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | (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>5<br>4 |
| TXA Transfer Index Register to Accumulator                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | $A \gets (X)$                                                                                      | _                                                              | -                                      | _                        |                            | -    | - INH                          | 9F                         |          | 2                |
| WAIT Stop CPU Clock and Enable Interrupts                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |                                                                                                    | -                                                              | 0<br>◊                                 | _                        | -                          | -    | - INH                          | 8F                         |          | 2                |
| <ul> <li>C Carry/borrow flag</li> <li>CCR Condition code register</li> <li>d Direct address of operand</li> <li>dd rr Direct address of operand and relative offset of branch in</li> <li>DIR Direct addressing mode</li> <li>ee ff High and low bytes of offset in indexed, 16-bit offset addrest</li> <li>Extended addressing mode</li> <li>ff Offset byte in indexed, 8-bit offset addressing</li> <li>H Half-carry flag</li> <li>hh II High and low bytes of operand address in extended addres</li> <li>ii Immediate operand byte</li> <li>IMM Immediate addressing mode</li> <li>INH Inherent addressing mode</li> <li>IX Indexed, no offset addressing mode</li> <li>IX Indexed, 16-bit offset addressing mode</li> <li>IX Memory location</li> <li>N Negative flag</li> <li>n Any bit</li> </ul> | rel Relative prog<br>essing rr Relative prog<br>SP Stack pointer<br>X Index registe<br>Z Zero flag | nter<br>nter<br>ess<br>ram<br>ram<br>r<br>llue<br>LUS<br>o's o | r hig<br>r low<br>sing<br>n co<br>n co | v by<br>mo<br>unt<br>unt | rte<br>ode<br>er o<br>er o | offs |                                |                            |          |                  |

#### Table 9. Instruction Set Summary (Continued)

28-cpu



Central Processing Unit (C

| ndo-62                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                  |                  |                  |                  |                  |                  |                  |                       |                 |                  |                  |                  |                  |                  |                  | 0.5              | νэЯ        | 6D9 | 903               | MC68HC     |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|------------------|------------------|------------------|------------------|------------------|------------------|-----------------------|-----------------|------------------|------------------|------------------|------------------|------------------|------------------|------------------|------------|-----|-------------------|------------|
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | п                | т                | D                | c                | в                | A                | 9                | 8                     | 7               | 6                | 5                | 4                | ω                | 2                | -                | 0                | LSB        |     |                   |            |
| INH = Inhe<br>IMM = Imn<br>DIR = Dire<br>EXT = Ext                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | BRCLR7<br>3 DIR  | BRSET7           | BRCLR6<br>3 DIR  | BRSET6<br>3 DIR  | BRCLR5<br>3 DIR  | BRSET5<br>3 DIR  | BRCLR4<br>3 DIR  | BRSET4<br>3 DIR 2     | BRCLR3<br>3 DIR | BRSET3<br>3 DIR  | BRCLR2<br>3 DIR  | BRSET2<br>3 DIR  | BRCLR1<br>3 DIR  | BRSET1<br>3 DIR  | BRCLR0<br>3 DIR  | BRSET0<br>3 DIR  | 0          | DIR | Bit Manipulation  |            |
| INH = InherentREL = Relative<br>IMM = ImmediateIX = Indexed, No Offset<br>DIR = DirectIX1 = Indexed, 8-Bit Offset<br>EXT = ExtendedIX2 = Indexed, 16-Bit Offset                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | BCLR7<br>2 DIR 2 | BSET7<br>2 DIR 2 | BCLR6<br>2 DIR 2 | BSET6<br>2 DIR 2 | BCLR5<br>2 DIR 2 | BSET5<br>2 DIR 2 | BCLR4<br>2 DIR 2 | BSET4<br>2 DIR 2      | BCLR3           | BSET3            | BCLR2<br>2 DIR 2 | BSET2<br>2 DIR 2 | BCLR1<br>2 DIR 2 | BSET1<br>2 DIR 2 | BCLR0<br>2 DIR 2 | BSET0<br>2 DIR 2 | <u> </u>   | DR  | oulation          |            |
| <ul> <li>Relative</li> <li>Indexed,  </li> <li>lexed, 8-Bi</li> <li>Indexed, 8-Bi</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 2 BIH<br>2 REL 2 | P BIL 3<br>REL   | 2 BMS 3<br>REL 2 | 2 BMC 3<br>REL 2 | 2 BMI 3<br>REL   | BPL 3<br>REL 2   | BHCS<br>REL      | BHCC<br>REL           | BEQ<br>REL      | 2 BNE 3<br>REL 2 | BCS/BLO          | BCC 3<br>REL 2   | 2 BLS 3<br>REL 2 | BHI 3            | BRN 3<br>REL     |                  | N          | R   | Branch            |            |
| No Offset<br>It Offset<br>16-Bit Offs                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | CLR 5            | 1                | TST 4<br>DIR 1   |                  |                  | DEC 5            | ROL 5            | SL/LSL<br>DIR         | 10              |                  |                  |                  |                  |                  |                  | NEG 5            | ω          | ᄝ   |                   |            |
| set                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | CLRA 3           |                  | TSTA 3<br>INH 1  |                  |                  | DECA<br>INH 1    | ROLA 3           | ASLA/LSLA ASLX/LSLX   | ASRA 3          | RORA             |                  | LSRA 3<br>INH 1  | COMA 3<br>INH 1  |                  |                  | NEGA 3           |            | R   | Read-             |            |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | CLRX<br>INH2     |                  | TSTX<br>INH2     |                  |                  | DECX<br>INH 2    | ROLX             | ASLX/LSLX             | ASRX 3<br>INH 2 | RORX 3<br>INH 2  |                  | LSRX 3<br>INH 2  | COMX             |                  |                  | NEGX 3           | ъ          | NH  | Read-Modify-Write |            |
| 5                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | CLR 6            |                  | TST 5            | NC               |                  | DEC 6            | ROL 6            | ASL/LSL 4<br>12 IX1 1 | ASR<br>IX1      | ROR 6            |                  | LSR 6            | COM              |                  |                  | NEG 6            | 6          | IX  | rite              | Table      |
| LSB of Opcode in Hexadecimal                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | CLR 5            |                  | TST 4            | NC               |                  | DEC 5            | ROL 5            | ASL/LSL<br>1 IX       | ASR 5           | ROR 5            |                  | LSR 5            | COM 5            |                  |                  | NEG 5            | 7          | ×   |                   | 10.        |
| ode in Hex;                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | WAIT 2<br>INH 1  | STOP 2           | -                |                  | 1                |                  |                  | -                     | -               |                  |                  |                  | SWI 10           |                  | RTS 6            | RTI 9            | œ          | Ŧ   | Control           | Opcode Map |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | TXA 2<br>INH     | N                | NOP 2<br>INH 2   | RSP 2            | SEI 2<br>INH 2   | CLI 2<br>INH 2   | SEC 2<br>INH 2   | CLC 2<br>INH 2        | TAX 2           | 2                | 2                | N                | N                | 2                | N                | N                | 9          | H   | rol               | Мар        |
| o Kanala | N                |                  | BSR 6<br>REL 2   | 2                | ADD 2<br>IMM 2   | ORA 2<br>IMM 2   | ADC 2<br>IMM 2   | EOR 2                 |                 |                  | BIT 2<br>IMM 2   | AND 2<br>IMM 2   | CPX 2<br>IMM 2   | SBC 2<br>IMM 2   | CMP 2<br>IMM 2   | SUB 2<br>IMM 2   | Þ          | IMM |                   |            |
| 9<br>BRSET0<br>DIR                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | STX 4<br>DIR 3   |                  | JSR 5<br>DIR 3   |                  | ADD 3<br>DIR 3   | ORA 3<br>DIR 3   | ADC 3            | EOR 3<br>DIR 3        | STA 4<br>DIR 3  | LDA 3<br>DIR 3   |                  | AND 3<br>DIR 3   | CPX<br>D         | SBC 3<br>DIR 3   | CMP 3            | SUB              | œ          | ᄝ   |                   |            |
| MSB of Opcode in Hexadecim<br>Number of Cycles<br>Opcode Mnemonic<br>Number of Bytes/Addressing Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                  |                  | JSR 6<br>EXT 3   | JMP 3<br>EXT 3   | ADD 4<br>EXT 3   | ORA 4<br>EXT 3   | ADC 4<br>EXT 3   | EOR 4<br>EXT 3        | STA 5<br>EXT 3  |                  | BIT 4<br>EXT 3   | AND 4<br>EXT 3   | CPX<br>EXT 3     | SBC 4<br>EXT 3   | CMP 4<br>EXT 3   | SUB<br>EXT 3     | C          | EXT | Register/Memory   |            |
| ocode in H<br>Cycles<br>emonic<br>Sytes/Addre                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | STX IX2 2        |                  | JSR<br>IX2 2     | JMP 4<br>IX2 2   | ADD 5<br>IX2 2   | OR               | ADC 5            | EOR                   | STA             |                  | BIT<br>I>        | AND 5<br>IX2 2   | CPX 5<br>1X2 2   | SBC 5<br>IX2 2   | CMP 5<br>IX2 2   | SUB<br>IX2 2     | D          | IX2 | lemory            |            |
| MSB of Opcode in Hexadecimal<br>Number of Cycles<br>Opcode Mnemonic<br>Number of Bytes/Addressing Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | STX 5            |                  | JSR 6            | JMP 3<br>IX1 1   | ADD 4            | ORA 4            | ADC 4            | EOR 4                 | STA 5           |                  | BIT 4            | AND 4            | CPX 4            | SBC 4            | CMP 4            | SUB 4            | m          | X   |                   |            |
| <u></u>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | STX 4            |                  | JSR 5            | JMP              | ADD              | ORA 3            | ADC 3            | EOR 3                 | STA 4           | LDA 3            | ВІТ              | AND 3            | CPX 3            | SBC              | CMP 3            | SUB 3            |            | ×   |                   |            |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | п                | т                | Ū                | ი                | B                | A                | 9                | œ                     | 7               | 6                | υ                | 4                | ω                | N                | <u> </u>         | •                | MSB<br>LSB |     |                   |            |

**Freescale Semiconductor, Inc.** 

Central Processing Unit (CPU)

For More Information On This Product, Go to: www.freescale.com



## **Resets and Interrupts**

## Contents

| Resets                                  | 13 |
|-----------------------------------------|----|
| Power-on reset                          | 13 |
| RESET pin                               | 13 |
| Computer operating properly (COP) reset | 14 |
| Clock monitor reset                     | 15 |
| Interrupts                              | 17 |
| Non-maskable software interrupt (SWI)   | 18 |
| Maskable hardware interrupts.           | 18 |
| Hardware controlled interrupt sequence  | 19 |
| Low power modes                         | 50 |
| STOP                                    | 50 |
| WAIT                                    | 50 |
| Data retention mode                     | 50 |
|                                         |    |

#### Resets

The MCU can be reset in four ways: by the initial power-on reset function, by an active low input to the RESET pin, by a COP watchdog timer reset and by an internal clock monitor reset. See Figure 12.

#### Power-on reset

A power-on reset occurs when a positive transition is detected on VDD. 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. The power-on circuitry provides a stabilization delay ( $t_{PORL}$ ) from when the oscillator becomes active. If the external RESET pin is low at the end of this delay then the processor remains in the reset state until RESET goes high. The user must ensure that the voltage on VDD has risen to a point where the MCU can operate properly by the time  $t_{PORL}$  has elapsed.

1-resets



#### **Resets and Interrupts**

If there is doubt, the external RESET pin should remain low until the voltage on VDD has reached the specified minimum operating voltage. This may be accomplished by connecting an external RC-circuit to this pin to generate a power-on reset (POR). In this case, the time constant must be great enough (at least 100 ms) to allow the oscillator circuit to stabilise.

At power-up, the RESET pin is pulled active low by an internal open drain n-channel device driven from the power-on reset signal. This pin can be used as a reset output.

#### **RESET** pin

Semiconductor, Inc.

reescale

When the oscillator is running in a stable state, the MCU is reset when a logic zero is applied to the RESET input for a minimum period of 8 machine cycles ( $t_{CYC}$ ). This pin contains an internal Schmitt trigger as part of its input to improve noise immunity.







| Computer<br>operating properly<br>(COP) reset | The MCU contains a watchdog timer that automatically times out unless<br>it is reset within a specific time by a program reset sequence. If the COP<br>watchdog timer is allowed to timeout, a reset is generated which drives<br>the RESET pin low to reset the MCU and the external system. The<br>COPF flag in the COP control register (COPCR) is set whenever a COP<br>timeout or clock monitor reset occurs; this allows COP and clock monitor<br>resets to be distinguished from external and power-on resets.                                                           |
|-----------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                               | The COP reset function can be enabled by programming the COPE control bit in the COP control register. This bit can be written once only after reset, but can be read at any time. Control bits CM0 and CM1 in COPCR allow the user to select one of four COP timeout periods. <b>Table 11</b> shows the relationship between CM0 and CM1 and the timeout period for various system clock frequencies.                                                                                                                                                                          |
|                                               | The sequence for resetting the watchdog timer is as follows:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|                                               | <ul> <li>Write \$55 to the COP reset register (COPRST)</li> <li>Write \$AA to the COP reset register</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|                                               | Both writes must occur in this sequence prior to the timeout, but any number of instructions may be executed between the two writes.                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| Clock monitor<br>reset                        | The MCU contains a clock monitor circuit that measures the bus clock frequency ( $f_{OP}$ ). The clock monitor function is enabled by the CME control bit in COPCR. Upon detection of a slow or absent clock, the clock monitor circuit (if enabled by CME = 1) will cause a system reset to be generated. If the bus clock input rate is above approximately 200 kHz, then the clock monitor does not generate a reset. If the bus clock is lost or its frequency falls below 10 kHz, then a reset is generated, and the RESET pin is driven low to reset the external system. |
|                                               | Special considerations are needed when using STOP and the clock<br>monitor in the same system. Since the STOP function causes the clocks<br>to be halted, the clock monitor function will generate a reset sequence if<br>it is enabled prior to the STOP mode being entered. For systems that do<br>not expect nor want a STOP function, this interaction can be useful to<br>detect the unauthorized execution of a STOP instruction that could not<br>be detected by the COP watchdog system. On the other hand, in                                                          |
| 3-resets                                      | MC68HC05D9 Rev 3.0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |

Semiconductor, Inc.

reescale

**Freescale Semiconductor, Inc.** 

#### **Resets and Interrupts**

systems that use both the STOP and clock monitor functions, this interaction means that the CME bit must be written to zero just prior to executing a STOP instruction and should be written back to one as soon as the MCU resumes execution.

# COP control register (COPCR)



**NOTE:** Bits 5, 6 and 7 are not used; these bits always read zero.

COPF — Computer operating properly failure

The COPF flag in the COP control register is set whenever a COP timeout or clock monitor reset occurs; this allows COP and clock monitor resets to be distinguished from external and power-on resets. COPF is cleared by reading COPCR.

- 1 = COP or clock monitor reset has occurred
- 0 = COP or clock monitor reset has not occurred

CME — Clock monitor enable

This bit enables the clock monitor circuitry to generate a reset whenever the clock frequency falls below a specified level. CME can be read or written at any time.

1 = Clock monitor enabled

0 = Clock monitor disabled

COPE — Computer operating properly enable

This bit enables the COP circuitry to generate a reset whenever the COP timer times out. COPE can be read at any time, but can be written only once after reset.

1 = COP timeout enabled



0 = COP timeout disabled

CM1, CM0 — COP mode bits

The COP mode bits select one of four timeout durations for the COP timer. CM1 and CM0 are cleared by reset and can only be written once. Table 11 shows examples of COP timeout periods for several different bus frequencies ( $f_{OP}$ ).

| CM1 | СМО | f <sub>OP</sub> /2 <sup>15</sup><br>divided by | XTAL = 4.0MHz<br><sup>f</sup> op = 2.0MHz | XTAL = 3.5795MHz<br><sup>f</sup> op = 1.7897MHz | XTAL = 2.0MHz<br><sup>f</sup> op = 1.0MHz | XTAL = 1.0MHz<br><sup>f</sup> op = 0.5MHz |
|-----|-----|------------------------------------------------|-------------------------------------------|-------------------------------------------------|-------------------------------------------|-------------------------------------------|
| 0   | 0   | 1                                              | 16.38 ms                                  | 18.31 ms                                        | 32.77 ms                                  | 65.54 ms                                  |
| 0   | 1   | 4                                              | 65.54 ms                                  | 73.24 ms                                        | 131.07 ms                                 | 262.14 ms                                 |
| 1   | 0   | 16                                             | 262.14 ms                                 | 292.95 ms                                       | 524.29 ms                                 | 1.048 s                                   |
| 1   | 1   | 64                                             | 1.048 s                                   | 1.172 s                                         | 2.097 s                                   | 4.194 s                                   |

#### Interrupts

The MCU can be interrupted by four different sources, three maskable hardware interrupts and one non-maskable software interrupt:

- External signal on the IRQ pin
- 16-bit programmable timer
- Serial communications interface
- Software interrupt instruction (SWI)

Interrupts cause the processor to save the register contents on the stack and to set the interrupt mask (I-bit) to prevent additional interrupts. The RTI instruction (return from interrupt) causes the register contents to be recovered from the stack and normal processing to resume.

Unlike reset, hardware interrupts do not cause the current instruction execution to be halted, but are considered pending until the current instruction is complete. The current instruction is the one already fetched and being operated on. When the current instruction is complete, the processor checks all pending hardware interrupts. If interrupts are not

Semiconductor, Inc

eescale

masked (CCR I-bit clear) and the corresponding interrupt enable bit is set, the processor proceeds with interrupt processing; otherwise, the next instruction is fetched and executed.

If both an external interrupt and a timer interrupt are pending after an instruction execution, the external interrupt is serviced first.

**Table 12** shows the relative priority of all the possible interrupt sources.**Figure 14** shows the interrupt processing flow.

| Source                    | Register | Flags                    | Vector address | Priority |
|---------------------------|----------|--------------------------|----------------|----------|
| Reset                     | —        | —                        | \$3FFE, \$3FFF | highest  |
| COP/Clock monitor reset   | COPCR    | COPF                     | \$3FFE, \$3FFF | <b>▲</b> |
| Software interrupt (SWI)  |          | _                        | \$3FFC, \$3FFD |          |
| External interrupt (IRQ)  | —        | —                        | \$3FFA, \$3FFB |          |
| 16-bit programmable timer | TSR      | ICF, OFC, TOF            | \$3FF8, \$3FF9 |          |
| SCI                       | SCSR     | TDRE, TC, RDRF, IDLE, OR | \$3FF6, \$3FF7 | lowest   |

#### Table 12. Interrupt priorities

#### Non-maskable software interrupt (SWI)

The software interrupt (SWI) is an executable instruction and a non-maskable interrupt: it is executed regardless of the state of the I-bit in the CCR. If the I-bit is zero (interrupts enabled), SWI is executed after interrupts that were pending when the SWI was fetched, but before interrupts generated after the SWI was fetched. The SWI interrupt service routine address is specified by the contents of memory locations \$3FFC and \$3FFD (\$7FFC and \$7FFD on the MC68HC05D24, MC68HC05D32 and MC68HC705D32).

Maskable hardware interrupts If the interrupt mask bit (I-bit) of the CCR is set, all maskable interrupts (internal and external) are disabled. Clearing the I-bit enables interrupts.

**NOTE:** The internal interrupt latch is cleared in the first part of the interrupt service routine; therefore, one external interrupt pulse could be latched and serviced as soon as the I-bit is cleared.

MC68HC05D9 Rev 3.0

6-resets



External interruptThe interrupt request is latched immediately following the active edge or<br/>level on the IRQ pin. It is then synchronized internally and handled by<br/>the interrupt service routine, located at the address specified by the<br/>contents of \$3FFA and \$3FFB (\$7FFA and \$7FFB on the<br/>MC68HC05D24, MC68HC05D32 and MC68HC705D32). An IRQ<br/>interrupt will cause the MPU to exit from STOP mode.

16-bit programmable timer interrupt There are three different timer interrupt flags that cause a timer interrupt whenever they are set and enabled. The timer interrupt enable bits are located in the timer control register (TCR) and the timer interrupt flags are located in the timer status register (TSR). All three interrupts will vector to the same service routine, located at the address specified by the contents of memory locations \$3FF8 and \$3FF9 (\$7FF8 and \$7FF9 on the MC68HC05D24, MC68HC05D32 and MC68HC705D32).

Serial communications interface interrupt

There are five different SCI interrupt flags that cause an SCI interrupt whenever they are set and enabled. The SCI interrupt enable bits are located in the serial communication control register 2 (SCCR2) and the SCI interrupt flags are located in the serial communication status register (SCSR). All three interrupts will vector to the same service routine, located at the address specified by the contents of memory locations \$3FF6 and \$3FF7 (\$7FF6 and \$7FF7 on the MC68HC05D24, MC68HC05D32 and MC68HC705D32).

HardwareThe following three functions (RESET, STOP, and WAIT) are not in thecontrolledstrictest sense interrupts. However, they are acted upon in a similarinterruptmanner. Flowcharts for STOP and WAIT are shown in Figure 15.

- **RESET:** A reset condition causes the program to vector to its starting address, which is specified by the contents of memory locations \$3FFE (MSB) and \$3FFF (LSB). The I-bit in the condition code register is also set.
  - **STOP:** The STOP instruction causes the oscillator to be turned off and the processor to 'sleep' until an external interrupt (IRQ), if enabled, or a reset occurs.

7-resets

sequence

**WAIT:** The WAIT instruction causes all processor clocks to stop, but leaves the timer clock running. This 'rest' state of the processor can be cleared by reset, an external interrupt (IRQ), if enabled, or a timer or SCI interrupt. There are no special wait vectors for these individual interrupts.

#### Low power modes

**STOP** The STOP instruction places the MCU in its lowest power consumption mode. In STOP mode, the internal oscillator is turned off, halting all internal processing, including timer (and COP watchdog timer) operation.

During the STOP mode, all interrupt enable bits in TCR and SCCR2 are cleared by internal hardware to remove any pending timer or SCI interrupt requests and to disable any further interrupts from these sources. The timer prescaler is cleared. The I-bit in the CCR is cleared to enable external interrupts. All other bits, registers and memory contents remain unaltered. All input/output lines remain unchanged. The processor can be brought out of the STOP mode only by an external interrupt on (IRQ) or by a reset.

WAITThe WAIT instruction places the MCU in a low-power consumption<br/>mode, but the WAIT mode consumes more power than the STOP mode.All CPU action is suspended, but the timer remains active. Any enabled<br/>interrupt from the timer or the SCI can cause the MCU to exit the WAIT<br/>mode.

During the WAIT mode, the I-bit in the CCR is cleared to enable interrupts. All other registers, memory, and input/output lines remain in their previous state.

Data retentionThe contents of the RAM are retained at supply voltages as low as 2.0VmodeV<sub>DD</sub>. This is called the data retention mode, in which data is maintained<br/>but the device is not guaranteed to operate.







**Freescale Semiconductor, Inc.** 

9-resets

#### **Resets and Interrupts**



Figure 15. STOP and WAIT flowcharts

For lowest power consumption in data retention mode the device should be put into STOP mode before reducing the supply voltage, to ensure that all the clocks are stopped. If the device is not in STOP mode then it is recommended that RESET be held low whilst the power supply is outwith the normal operating range, to ensure that processing is suspended in an orderly manner.

Recovery from data retention mode, after the power supply has been restored, is by an external interrupt, or by pulling the RESET line high.



## **Memory and Registers**

#### Contents

| Introduction | <br> | <br> | 53 |
|--------------|------|------|----|
| RAM          | <br> | <br> | 53 |
| ROM          | <br> | <br> | 54 |
| Registers    | <br> | <br> | 54 |

#### Introduction

The MCU has a 16K byte memory map consisting of registers (for I/O, control and status), User RAM, user ROM, self-check ROM and reset and interrupt vectors as shown in Figure 16.

Two control bits in the option register (\$3FDF) allow the user to switch between RAM and ROM/EPROM, at any time, in two special areas of the memory map, \$0020–\$004F (48 bytes) and \$0100–\$017F (128 bytes).

### RAM

The main user RAM consists of 176 bytes at \$0050–\$00FF. This RAM array is always present in the memory map and includes a 64 byte stack area. The stack pointer can access 64 bytes of RAM in the range \$00FF to \$00C0.

**NOTE:** Using the stack area for data storage or temporary work locations requires care to prevent it from being overwritten due to stacking from an interrupt or subroutine call.

**Memory and Registers** 

Two additional RAM arrays are available at \$0020–\$004F (48 bytes) and \$0100–\$017F (128 bytes). These may be accessed at any time by setting the RAM0 and RAM1 bits, respectively, in the option register (see **Software-selectable options**).

#### ROM

Semiconductor, Inc.

reescale

The main user ROM/EPROM occupies 15744 bytes in the memory space from \$017F to \$3FFF. This array includes 15744 bytes of main User ROM, 128 bytes of User ROM that are mapped into the memory space when the RAM0 bit in the option register is cleared and the User reset and interrupt vectors (\$3FF6–\$3FFF). It also includes the self-check ROM and vectors and the option register.

Two additional ROM arrays are mapped into the address space at \$0020–\$004F (48 bytes) and \$0100–\$017F (128 bytes) when RAM0 and RAM1, respectively, in the option register are cleared (see **Software-selectable options**).

#### Registers

Except for the option register, all I/O, control and status registers are contained within one 32-byte block in page zero of the address space (\$0000–\$001F). These registers are shown in Table 13.

MC68HC05D9 Rev 3.0

2-mem





#### Figure 16. Memory map of the MC68HC05D9

## **Memory and Registers**

| Register name              | Address               | bit 7 | bit 6 | bit 5 | bit 4 | bit 3 | bit 2 | bit 1 | bit 0 | State on reset |
|----------------------------|-----------------------|-------|-------|-------|-------|-------|-------|-------|-------|----------------|
| Port A data (PORTA)        | \$0000                |       |       |       |       |       |       |       |       | undefined      |
| Port B data (PORTB)        | \$0001                |       |       |       |       |       |       |       |       | undefined      |
| Port C data (PORTC)        | \$0002                |       |       |       |       |       |       |       |       | undefined      |
| Port D data (PORTD)        | \$0003                |       |       |       |       |       |       |       |       | undefined      |
| Data direction A (DDRA)    | \$0004                |       |       |       |       |       |       |       |       | 0000 0000      |
| Data direction B (DDRB)    | \$0005                |       |       |       |       |       |       |       |       | 0000 0000      |
| Data direction C (DDRC)    | \$0006                |       |       |       |       |       |       |       |       | 0000 0000      |
| Data direction D (DDRD)    | \$0007                |       |       |       |       |       |       |       |       | 0u00 0000      |
| PWM mode (PWMM)            | \$0008                | 0     | 0     | SCIB  | PWM4  | PWM3  | PWM2  | PWM1  | PWM0  | 0010 0000      |
| PWM channel 0 (PWM0)       | \$0009                | 0     | 0     |       |       |       |       |       |       | 0000 0000      |
| PWM channel 1 (PWM1)       | \$000A                | 0     | 0     |       |       |       |       |       |       | 0000 0000      |
| PWM channel 2 (PWM2)       | \$000B                | 0     | 0     |       |       |       |       |       |       | 0000 0000      |
| PWM channel 3 (PWM3)       | \$000C                | 0     | 0     |       |       |       |       |       |       | 0000 0000      |
| PWM channel 4 (PWM4)       | \$000D <sup>(1)</sup> | 0     | 0     |       |       |       |       |       |       | 0000 0000      |
| SCI baud rate (BAUD)       | \$0000                |       |       | SCP1  | SCP0  |       | SCR2  | SCR1  | SCR0  | นน00 นนนน      |
| SCI control 1 (SCCR1)      | \$000E                | R8    | Т8    | 0     | M     | WAKE  | 0     | 0     | 0     | uu0u u000      |
| SCI control 2 (SCCR2)      | \$000F                | TIE   | TCIE  | RIE   | ILIE  | TE    | RE    | RWU   | SBK   | 0000 0000      |
| SCI status (SCSR)          | \$0010                | TDRE  | тс    | RDRF  | IDLE  | OR    | NF    | FE    | 0     | 1100 0000      |
| SCI data (SCDR)            | \$0011                |       |       |       |       |       |       |       |       | undefined      |
| Timer control (TCR)        | \$0012                | ICIE  | OCIE  | TOIE  | 0     | 0     | 0     | IEDG  | OLVL  | 0000 0000      |
| Timer status (TSR)         | \$0013                | ICF   | OCF   | TOF   | 0     | 0     | 0     | 0     | 0     | uuu0 0000      |
|                            | \$0014                |       |       |       |       |       |       |       |       | undefined      |
| Input capture (ICR)        | \$0015                |       |       |       |       |       |       |       |       | undefined      |
|                            | \$0016                |       |       |       |       |       |       |       |       | undefined      |
| Output compare (OCR)       | \$0017                |       |       |       |       |       |       |       |       | undefined      |
|                            | \$0018                |       |       |       |       |       |       |       |       | 1111 1111      |
| Timer counter (TCNT)       | \$0019                |       |       |       |       |       |       |       |       | 1111 1100      |
|                            | \$001A                |       |       |       |       |       |       |       |       | 1111 1111      |
| Alternate counter (ALTCNT) | \$001B                |       |       |       |       |       |       |       |       | 1111 1100      |
| Reserved                   | \$001C                |       |       |       |       |       |       |       |       | undefined      |
| COP reset (COPRST)         | \$001D                | ICAF  | ICBF  | OCAF  | TOF   | 0     | 0     | 0     | 0     | 0000 0000      |
| COP control (COPCR)        | \$001E                | 0     | 0     | 0     | COPF  | CME   | COPE  | CM1   | CM0   | 0000 0000      |
| Reserved                   | \$001F                |       |       | -     |       |       |       |       |       | undefined      |
|                            |                       | 1     | 1     | 1     | 1     | 1     | 1     | 1     | I     |                |
| OPTION                     | \$3FDF                | RAM0  | RAM1  | 0     | 0     | 0     |       | IRQ   | 0     | 0000 0u10      |
|                            |                       |       | I     | I     | 1     | 1     |       |       | u     | = undefined    |

#### Table 13. MC68HC05D9 register assignment

1. If SCIB = 0, the PWM4 register is available at location \$000D

If SCIB = 1, the SCI baud rate generator register is available at location \$000D



## Input/Output Ports

#### Contents

| Introduction                                         |     | 57 | 7 |
|------------------------------------------------------|-----|----|---|
| Input/output programming                             |     | 57 | 7 |
| Port D                                               |     | 59 | 9 |
| Ports A, B and C                                     |     | 59 | 9 |
| Port registers                                       |     | 6  | ) |
| Port data registers (PORTA, PORTB, PORTC and PORTD)  |     |    |   |
| Data direction registers (DDRA, DDRB, DDRC and DDRD) |     |    |   |
| Other port considerations                            | • • | 6  | 1 |

#### Introduction

In single chip mode there are four 8-bit wide parallel ports comprising 31 bidirectional I/O lines and one output-only line. The bidirectional ports are programmable as either inputs or outputs under software control, via the data direction registers.

To prevent glitches on the output pins, data should be written to the I/O port data register before configuring the port as outputs, by setting the corresponding data direction register bits.

#### Input/output programming

Bidirectional port lines may be programmed as inputs or outputs under software control. The direction of each pin is determined by the state of the corresponding bit in the port data direction register (DDR). Each port has an associated DDR. Any I/O port pin is configured as an output if its

1-ports



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

At power-on or reset, all DDRs are cleared, thus configuring all port pins as inputs. The data direction registers can be written to or read by the processor. During the programmed output state, a read of the data register reads the value of the output data latch and not the I/O pin (see **Figure 17** and **Table 14**).



#### Figure 17. Standard I/O port structure

| Table 14 | . Bidirectional | I/O pin | functions |
|----------|-----------------|---------|-----------|
|----------|-----------------|---------|-----------|

| R/W <sup>(1)</sup> | DDR | I/O Pin function                                                          |
|--------------------|-----|---------------------------------------------------------------------------|
| 0                  | 0   | The I/O pin is in input mode. Data is written into the output data latch. |
| 0                  | 1   | Data is written into the output data latch, and output to the I/O pin.    |
| 1                  | 0   | The state of the I/O pin is read.                                         |
| 1                  | 1   | The I/O pin is in output mode. The output data latch is read.             |

1. Note that  $R/\overline{W}$  is an internal signal, not available to the user.



#### Ports A, B and C

Ports A, B and C are 8-bit bidirectional ports (see **Table 14**). Their data registers reside at addresses \$0000-\$0002 and their data direction registers (DDRn) at \$0004-\$0006, respectively. Reset does not affect the data register, but clears the data direction register, thereby returning the ports to inputs. Writing a '1' to a data direction register bit sets the corresponding port bit to output mode.

### Port D

Port D is an 8-bit wide port that shares pins with the on-board sub-systems (timer, SCI and PWM). When a sub-system function is enabled, the associated pin or pins are configured to support the input/output requirements of that function (see PD0–PD7). In particular, a bit whose pin is shared with the timer, SCI or PWM sub-system can be used to read the level on the pin, even when the associated sub-system is enabled. When a sub-system is enabled, certain pins associated with that sub-system are capable of becoming outputs. These pins then get their drive signals directly from the sub-system rather than from the port D data register. These pins, however, remain under the control of the data direction register and can be configured as input pins when driven directly from the sub-system.

The port D data register is located at address \$0003 and the port D data direction register (DDR) at \$0007. Bits 0–5 and 7 are bidirectional lines, their direction controlled by the corresponding bits in DDRD. Bit 6 is dedicated to the timer output compare function as an output; as an input, reading this bit returns the instantaneous level on the TCMP pin. Consequently, bit 6 does not have a corresponding data direction register bit in DDRD. Reset does not affect the data register, but clears the data direction register, thereby returning the ports to inputs. Writing a '1' to a DDR bit sets the corresponding bit in the data register monitors the level on the pin at all times.

#### Input/Output Ports

**NOTE:** The operation of the timer and PWM sub-systems can cause transitions on the port D pins that are asynchronous with respect to the read cycles on the port D data register. User software should be written in such a way as not to depend on the value of any bit on port D that was read while the operation of one of the sub-systems may have been causing transitions on the pin.

#### Port registers

The following sections explain in detail the individual bits in the data and control registers associated with the ports.

#### Port data registers (PORTA, PORTB, PORTC and PORTD)

|                     | Address | bit 7 | bit 6 | bit 5 | bit 4 | bit 3 | bit 2 | bit 1 | bit 0 | State<br>on reset |
|---------------------|---------|-------|-------|-------|-------|-------|-------|-------|-------|-------------------|
| Port A data (PORTA) | \$0000  |       |       |       |       |       |       |       |       | undefined         |
| Port B data (PORTB) | \$0001  |       |       |       |       |       |       |       |       | undefined         |
| Port C data (PORTC) | \$0002  |       |       |       |       |       |       |       |       | undefined         |
| Port D data (PORTD) | \$0003  |       |       |       |       |       |       |       |       | undefined         |

Each bit can be configured as input or output via the corresponding data direction bit in the port data direction register (DDRx).

Reset does not affect the state of the port data registers.



#### **Data direction** registers (DDRA, DDRB, DDRC and DDRD)

|                         | Address | bit / | bit 6 | bit 5 | bit 4 | bit 3 | bit 2 | bit 1 | bit 0 | on reset  |
|-------------------------|---------|-------|-------|-------|-------|-------|-------|-------|-------|-----------|
| Data direction A (DDRA) | \$0004  |       |       |       |       |       |       |       |       | 0000 0000 |
| Data direction B (DDRB) | \$0005  |       |       |       |       |       |       |       |       | 0000 0000 |
| Data direction C (DDRC) | \$0006  |       |       |       |       |       |       |       |       | 0000 0000 |
| Data direction D (DDRD) | \$0007  |       |       |       |       |       |       |       |       | 0u00 0000 |

State

Writing a '1' to any bit configures the corresponding bit in the port data register as an output; conversely, writing any bit to '0' configures the corresponding port data bit as an input.

Reset clears these registers, thus configuring all pins as inputs.

#### Other port considerations

All input/output ports can emulate open-drain outputs. This is done by writing a '0' to the relevant output port latch. By toggling the corresponding data direction bit, the port pin will be either output a '0' or be tri-state (i.e. an input). (See Figure 18.)

When using a port pin as an open-drain output, certain precautions must be taken in the user software. If a read-modify-write instruction is used on a port where the open-drain is assigned and the pin at this time is programmed as an input, it will read it as a '1'. The read-modify-write instruction will then write this '1' into the output data latch on the next cycle. This would cause the open-drain pin not to output a "0" when desired.

NOTE: 'Open-drain' outputs should not be pulled above  $V_{DD}$ .



## Input/Output Ports

| A | Y        | ]                                                                                                                                                         |
|---|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0 | 0        |                                                                                                                                                           |
| 1 | 1        | Normal operation – tristate                                                                                                                               |
| 0 | tristate |                                                                                                                                                           |
| 1 | tristate | J                                                                                                                                                         |
|   |          | 1                                                                                                                                                         |
| 0 | low      |                                                                                                                                                           |
| 1 |          | {<br>} Open drain                                                                                                                                         |
| 0 | high     |                                                                                                                                                           |
| 1 | high     | j                                                                                                                                                         |
|   | 0        | 0         0           1         1           0         tristate           1         tristate           0         low           1            0         high |



Figure 18. Port logic levels



## 16-bit Programmable TImer

#### Contents

| ntroduction                  | 33 |
|------------------------------|----|
| Counter                      | 35 |
| Counter registers            | 35 |
| Fimer functions              | 37 |
| Timer control register (TCR) |    |
| Timer status register (TSR)  |    |
| Input capture register       |    |
| Output compare register      |    |
| Timer during WAIT mode       |    |
| Fimer during STOP mode       |    |
| Fimer state diagrams         | 73 |

#### Introduction

The programmable input capture/output compare timer on the MC68HC05D9 consists of a 16-bit read-only free-running counter, preceded by a fixed divide-by-four prescaler. Selected input edges cause the current counter value to be latched into a 16-bit input capture register so that software can later read this value to determine when the edge occurred. When the free running counter value matches the value in the output compare registers, the programmed pin action takes place. Refer to **Figure 19** for a block diagram of the timer.

The timer has a 16-bit architecture hence each specific functional segment is represented by two registers. These registers contain the high and low byte of that functional segment. Accessing the low byte of a specific timer function allows full control of that function; however, an access of the high byte inhibits that specific timer function until the low byte is also accessed.



## 16-bit Programmable TImer

**NOTE:** The I-bit in the CCR should be set while manipulating both the high and low byte register of a specific timer function to ensure that an interrupt does not occur.





MC68HC05D9 Rev 3.0

2-timer



### Counter

The key element in the programmable timer is a 16-bit, free-running counter or counter register, preceded by a prescaler that divides the internal processor clock by four. The prescaler gives the timer a resolution of  $2\mu$ s if the internal bus clock is 2 MHz. The counter is incremented during the low portion of the internal bus clock. Software can read the counter at any time without affecting its value.

The free-running counter is set to \$FFFC during reset and is always read-only. During a power-on reset, the counter is also preset to \$FFFC and begins running after the oscillator start-up delay. Because the free-running counter is 16 bits preceded by a fixed divide-by-four prescaler, the value in the free-running counter repeats every 262,144 internal bus clock cycles. TOF is set when the counter overflows (from \$FFFF to \$0000); this will cause an interrupt if TOIE is set.

#### **Counter registers**

The double-byte, free-running counter can be read from either of two locations, \$18–\$19 (counter register) or \$1A–\$1B (alternate counter register). A read from only the less significant byte (LSB) of the free-running counter (\$19 or \$1B) receives the count value at the time of the read. If a read of the free-running counter or alternate counter register first addresses the more significant byte (MSB) (\$18 or \$1A), the LSB is transferred to a buffer. This buffer value remains fixed after the first MSB read, even if the user reads the MSB several times. This buffer is accessed when reading the free-running counter or alternate counter register LSB and thus completes a read sequence of the total counter value. In reading either the free-running counter or alternate counter register, if the MSB is read, the LSB must also be read to complete the sequence.



1

Reset:

1

1

#### 16-bit Programmable TImer





1

1

1

0

0

The alternate counter register differs from the counter register only in that a read of the LSB will not clear the timer overflow flag (TOF). Therefore, to avoid the possibility of missing timer overflow interrupts due to clearing of TOF, the alternate counter register should be used where this is a critical issue.





Figure 23. Alternate Counter Register (ALTCNT) LSB



2

0

0

1

IEDG

u

Bit 0

OLVL

0

#### **Timer functions**

The 16-bit programmable timer is monitored and controlled by a group of ten registers, full details of which are contained in the following paragraphs. An explanation of the timer functions is also given.

Timer control<br/>register (TCR)The timer control register (\$12) is used to enable the input capture<br/>(ICIE), output compare (OCIE), and timer overflow (TOIE) functions as<br/>well as selecting input edge sensitivity (IEDG) and output level polarity<br/>(OLVL).

| Address: | \$0012 |      |      |   |   |
|----------|--------|------|------|---|---|
|          | Bit 7  | 6    | 5    | 4 | 3 |
| ſ        | ICIE   | OCIE | TOIE | 0 | 0 |

0

#### Figure 24. Timer Control Register (TCR)

0

0

ICIE — Input capture interrupt enable

0

0

Reset:

ICIE is a read/write control bit that is used to enable or disable interrupts coming from the input capture circuitry. Reset clears this bit.

- 1 = Input capture interrupt enabled.
- 0 = Input capture interrupt disabled.

OCIE — Output compare interrupt enable

OCIE is a read/write control bit that is used to enable or disable interrupts coming from the output compare circuitry. Reset clears this bit.

- 1 = Output compare interrupt enabled.
- 0 = Output compare interrupt disabled.

TOIE — Timer overflow interrupt enable

TOIE is a read/write control bit that is used to enable or disable interrupts coming from the timer overflow detection circuitry. Reset clears this bit.

- 1 = Timer overflow interrupt enabled.
- 0 = Timer overflow interrupt disabled.

5-timer



#### 16-bit Programmable TImer

IEDG — Input edge

IEDG is a read/write control bit that is used to specify the input capture trigger mechanism. Reset clears this bit.

- 1 = A positive going edge on the TCAP pin will trigger free-running counter transfer to the input capture register.
- 0 = A negative going edge on the TCAP pin will trigger free-running counter transfer to the input capture register.

#### OLVL - Output level

OLVL is a read/write control bit that is used to specify whether a logic high or logic low level will appear on the TCMP pin following the next successful output compare. Reset clears this bit.

- 1 = A high output value will be clocked into the output level register by the next successful output compare and will appear on the TCMP pin.
- 0 = A low output value will be clocked into the output level register by the next successful output compare and will appear on the TCMP pin.

The timer status register (\$13) contains the status bits for the above three interrupt conditions – ICF, OCF, TOF.

Accessing the timer status register satisfies the first condition required to clear the status bits. The remaining step is to access the register corresponding to the status bit.



Figure 25. Timer Status Register (TSR)

Timer status

register (TSR)



ICF — Input capture flag

ICF is a read-only bit that is set whenever an input capture occurs. If input capture interrupts are enabled (via ICIE in TCR), the setting of this bit will interrupt the processor. It is cleared by the sequence of reading TSR followed by the input capture low register (\$15).

- 1 = Input capture has occurred.
- 0 = No interrupt capture has occurred.
- OCF Output compare flag

OCF is a read-only bit that is set whenever an output compare occurs. If output compare interrupts are enabled (via OCIE in TCR), the setting of this bit will interrupt the processor. It is cleared by the sequence of reading TSR followed by the output compare low register (\$17).

- 1 = Output compare has occurred.
- 0 = No output compare has occurred.
- TOF Timer overflow flag

TOF is a read-only bit that is set whenever a timer overflow occurs. If timer overflow interrupts are enabled (via TOIE in TCR), the setting of this bit will interrupt the processor. It is cleared by the sequence of reading TSR followed by the counter low register (\$19).

1 = Timer overflow has occurred.

0 = No timer overflow has occurred.

**NOTE:** When using the timer overflow function and reading the free-running counter at random times to measure an elapsed time, a problem could occur where the timer overflow flag may be cleared unintentionally if the timer status register is read or written when TOF is set and the LSB of the free-running counter is read, but not for the purpose of servicing the flag.



Semiconductor, Inc

reescale

#### 16-bit Programmable TImer

Input capture'Input capture' is a technique whereby an external signal (connected to<br/>the TCAP pin) is used to trigger a read of the free running counter. In this<br/>way it is possible to relate the timing of an external signal to the internal<br/>counter value, and hence to elapsed time.







Figure 27. Input Capture Register (ICR) Low Byte

The two 8-bit registers that make up the 16-bit input capture register are read-only, and are used to latch the value of the free-running counter after the input capture edge detector senses a valid transition. The level transition that triggers the counter transfer is defined by the input edge bit (IEDG). The most significant 8 bits are stored in the input capture high register at \$14, the least significant in the input capture low register at \$15.

The result obtained from an input capture will be one greater than the value of the free-running counter on the rising edge of the internal bus clock preceding the external transition. This delay is required for internal synchronization. Resolution is one count of the free-running counter, which is four internal bus clock cycles. The free-running counter contents are transferred to the input capture register on each valid signal transition whether the input capture flag (ICF) is set or clear. The input capture register always contains the free-running counter value that corresponds to the most recent input capture. After a read of the input capture register MSB (\$14), the counter transfer is inhibited until the LSB (\$15) is also read. This characteristic causes the time used in the input

8-timer



capture software routine and its interaction with the main program to determine the minimum pulse period. A read of the input capture register LSB (\$15) does not inhibit the free-running counter transfer since the two actions occur on opposite edges of the internal bus clock.

Reset does not affect the contents of the input capture register, except when exiting STOP mode.

Output compare'Output compare' is a technique that may be used, for example, to<br/>generate an output waveform, or to signal when a specified time has<br/>elapsed, by presetting the output compare register to the appropriate<br/>value. Note that the output pin used is the shared PD6/TCMP pin.



Figure 28. Output Compare Register (OCR) High Byte



Figure 29. Output Compare Register (OCR) Low Byte

The 16-bit output compare register is made up of two 8-bit registers at locations \$16 (MSB) and \$17 (LSB). The contents of the output compare register are compared with the contents of the free-running counter continually and, if a match is found, the corresponding output compare flag (OCF) in the timer status register is set and the output level (OLVL) bit clocked to the output level register. The output compare register values and the output level bit should be changed after each successful comparison to establish a new elapsed timeout. An interrupt can also accompany a successful output compare provided the corresponding



16-bit Programmable TImer

interrupt enable bit (OCIE) is set. (The free-running counter is updated every four internal bus clock cycles.)

After a processor write cycle to the output compare register containing the MSB (\$16), the output compare function is inhibited until the LSB (\$17) is also written. The user must write both bytes (locations) if the MSB is written first. A write made only to the LSB (\$17) will not inhibit the compare function. The processor can write to either byte of the output compare register without affecting the other byte. The output level (OLVL) bit is clocked to the output level register whether the output compare flag (OCF) is set or clear. The minimum time required to update the output compare register is a function of the program rather than the internal hardware. Because the output compare flag and the output compare register are not defined at power on, and not affected by reset, care must be taken when initialising output compare functions with software. The following procedure is recommended:

- 1. Write to output compare high to inhibit further compares;
- 2. Read the timer status register to clear OCF (if set);
- 3. Write to output compare low to enable the output compare function.

All bits of the output compare register are readable and writable and are not altered by the timer hardware or reset. If the compare function is not needed, the two bytes of the output compare register can be used as storage locations.

## Timer during WAIT mode

Only the CPU clock halts during WAIT mode, hence the timer continues to run. A timer interrupt may be used to bring the CPU out of WAIT mode. If RESET is used to exit WAIT mode, the counters are forced to \$FFFC.

MC68HC05D9 Rev 3.0

10-timer



#### Timer during STOP mode

In the STOP mode all MCU clocks are stopped, hence the timer stops counting. If STOP is exited by an interrupt the counter retains the last count value. If the device is reset then the counter is forced to \$FFFC.

During STOP, if at least one valid input capture edge occurs at the TCAP pin, the input capture detection circuitry is armed. This does not set any timer flags nor wake up the MCU. When the MCU does wake up, however, there is an active input capture flag and data from the first valid edge that occurred during the STOP period. If the device is reset to exit STOP mode, then no input capture flag or data remains, even if a valid input capture edge occurred.

#### Timer state diagrams

The relationships between the internal clock signals, the counter contents and the status of the flag bits are shown in the following figures.

11-timer



16-bit Programmable TImer

The signals labelled 'internal' (processor clock, timer clocks and reset) are not available to the user.

MC68HC05D9 Rev 3.0

12-timer





Note: The counter and timer control registers are the only ones affected by power-on or external reset.

#### Figure 30. Timer state timing diagram for reset

13-timer



#### 16-bit Programmable TImer



Note: If the input edge occurs in the shaded area from one timer state T10 to the next timer state T10, then the input capture flag will be set during the next T11 state..

#### Figure 31. Timer state timing diagram for input capture





Note: (1)The CPU write to the compare registers may take place at any time, but a compare only occurs at timer state T01. Thus a four cycle difference may exist between the write to the compare register and the actual compare.

(2) The output compare flag is set at the timer state T11 that follows the comparison match (\$F457 in this example).

#### Figure 32. Timer state timing diagram for output compare

15-timer



## 16-bit Programmable Timer



Note: The timer overflow flag is set at timer state T11 (transition of counter from \$FFFF to \$0000). It is cleared by a read of the timer status register during the internal processor clock high time, followed by a read of the counter low register.

#### Figure 33. Timer state timing diagram for timer overflow



## Serial Communications Interface (SCI)

## Contents

| Introduction                                     | . 79 |
|--------------------------------------------------|------|
| Overview and features                            | . 80 |
| SCI two-wire system features                     | . 80 |
| SCI receiver features                            |      |
| SCI transmitter features                         | . 80 |
| Functional description                           | . 81 |
| Data format                                      | . 83 |
| Receiver wake-up operation                       | . 84 |
| Idle line wake-up                                | . 84 |
| Address mark wake-up                             | . 85 |
| Receive data (RDI)                               | . 85 |
| Start bit detection                              | . 86 |
| Transmit data (TDO)                              | . 89 |
| SCI registers                                    | . 89 |
| PWM mode register (PWMM)                         | . 89 |
| SCIB — Serial communications interface baud      |      |
| Serial communications data register (SCDR)       | . 90 |
| Serial communications control register 1 (SCCR1) |      |
| Serial communications control register 2 (SCCR2) | . 91 |
| Serial communications status register (SCSR)     | . 94 |
| Baud rate register (BAUD)                        | . 96 |
|                                                  |      |

## Introduction

This section describes the UART type serial communications interface system (SCI). The SCI can be used, for example, to connect a CRT terminal or personal computer to the MCU or to form a serial communication network connecting several widely distributed MCUs.



## Serial Communications Interface (SCI)

#### **Overview and features**

The SCI on the MCU is a full duplex UART type asynchronous system. The SCI uses standard non-return-to-zero (NRZ) format (one start bit, eight or nine data bits, and one stop bit). An on-chip baud rate generator derives standard baud rate frequencies from the MCU oscillator. Both the transmitter and the receiver are double buffered, so back-to-back characters can be handled easily even if the CPU is delayed in responding to the completion of an individual character. The SCI transmitter and receiver are functionally independent but use the same data format and baud rate.

SCI two-wire system features

- Standard NRZ (mark/space) format
- Advanced error detection method includes noise detection for noise duration of up to 1/16th bit time
- Full-duplex operation
- Software programmable for one of 32 different baud rates
- Software selectable word length (eight- or nine-bit words)
- Separate transmitter and receiver enable bits
- Can be interrupt driven
- Four separate enable bits available for interrupt control

#### SCI receiver features

- Receiver wake-up function (idle line or address bit)
- Idle line detect
- Framing error detect
- Noise detect
- Overrun detect
- Receiver data register full flag

#### SCI transmitter features

Transmit data register empty flag

#### MC68HC05D9 Rev 3.0

2-sci



- Transmit complete flag
- Send break

#### **Functional description**

A block diagram of the SCI is shown in Figure 8-1. The user has option bits in serial communications control register 1 (SCCR1) to select the "wake-up" method (WAKE bit) and data word length (M bit) of the SCI. Serial communications control register 2 (SCCR2) provides control bits which individually enable/disable the transmitter or receiver (TE and RE, respectively), enable system interrupts (TIE, TCIE, ILIE) and provide the wake-up enable bit (RWU) and the send break code bit (SBK). Control bits in the baud rate register (BAUD) allow the user to select one of 32 different baud rates for the transmitter and receiver.

Data transmission is initiated by a write to the serial communications data register (SCDR). Provided the transmitter is enabled, data stored in the SCDR is transferred to the transmit data shift register. This transfer of data sets the transmit data register empty flag (TDRE) in the SCI status register (SCSR) and may generate an interrupt if the transmit interrupt is enabled. The transfer of data to the transmit data shift register is synchronized with the bit rate clock (Figure 35). All data is transmitted least significant bit first. Upon completion of data transmission, the transmission complete flag (TC) in the SCSR is set (provided no pending data, preamble or break is to be sent), and an interrupt may be generated if the transmit complete interrupt is enabled. If the transmitter is disabled, and the data, preamble or break (in the transmit data shift register) has been sent, the TC bit will also be set. This will also generate an interrupt if the transmission complete interrupt enable bit (TCIE) is set. If the transmitter is disabled in the middle of a transmission, that character will be completed before the transmitter gives up control of the TDO pin.

When SCDR is read, it contains the last data byte received, provided that the receiver is enabled. The receive data register full flag bit (RDRF) in the SCSR is set to indicate that a data byte has been transferred from the input serial shift register to the SCDR, which can cause an interrupt



#### Serial Communications Interface (SCI)



The serial communications data register (SCI SCDR) is controlled by the internal R/W signal. It is the transmit data register when written to and the receive data register when read.

Receive data in (RDI) is served by pin 0 of port B (PD0)

Transmit data out (TDO) is served by pin 1 of port B (PD1)

#### Figure 34. Serial communications interface block diagram

MC68HC05D9 Rev 3.0

4-sci



Serial Communications Interface (SCI) Data format

if the receiver interrupt is enabled. The data transfer from the input serial shift register to the SCDR is synchronized by the receiver bit rate clock. The OR (overrun), NF (noise), or FE (framing) error flags in the SCSR may be set if data reception errors occurred.

An idle line interrupt is generated if the idle line interrupt is enabled and the IDLE bit (which detects idle line transmission) in SCSR is set. This allows a receiver that is not in the wake-up mode to detect the end of a message or the preamble of a new message, or to resynchronize with the transmitter. A valid character must be received before the idle line condition or the IDLE bit will not be set and an idle line interrupt will not be generated.



Figure 35. Rate generator division

## Data format

Receive data or transmit data is the serial data that is transferred to the internal data bus from the receive data input pin (RDI) or from the internal bus to the transmit data output pin (TDO). The non-return-to-zero (NRZ) data format shown in Figure 8-3 is used and must meet the following criteria:

- The idle line is brought to a logic one state prior to transmission/reception of a character.
- A start bit (logic zero) is used to indicate the start of a frame.
- The data is transmitted and received least significant bit first.
- A stop bit (logic one) is used to indicate the end of a frame. A frame consists of a start bit, a character of eight or nine data bits, and a stop bit.



Semiconductor, Inc.

0

eescal

**Freescale Semiconductor, Inc.** 

## Serial Communications Interface (SCI)

 A break is defined as the transmission or reception of a low (logic zero) for at least one complete frame time.





#### **Receiver wake-up operation**

The receiver logic hardware also supports a receiver wake-up function which is intended for systems having more than one receiver. With this function a transmitting device directs messages to an individual receiver or group of receivers by passing addressing information as the initial byte(s) of each message. The wake-up function allows receivers not addressed to remain in a dormant state for the remainder of the unwanted message. This eliminates any further software overhead to service the remaining characters of the unwanted message and thus improves system performance.

The receiver is placed in wake-up mode by setting the receiver wake-up bit (RWU) in the SCCR2 register. While RWU is set, all the receiver related status flags (RDRF, IDLE, OR, NF, and FE) are inhibited (cannot become set). Note that the idle line detect function is inhibited while the RWU bit is set. Although RWU may be cleared by a software write to SCCR2, it would be unusual to do so. Normally RWU is set by software and gets cleared automatically with hardware by one of the two methods described below.

# Idle line wake-up In idle line wake-up mode, a dormant receiver wakes up as soon as the RDI line becomes idle. Idle is defined as a continuous logic high level on



Serial Communications Interface (SCI) Receive data (RDI)

the RDI line for ten (or eleven) full bit times. Systems using this type of wake-up must provide at least one character time of idle between messages to wake up sleeping receivers, but must not allow any idle time between characters within a message.

Address mark In address mark wake-up, the most significant bit (MSB) in a character is used to indicate that the character is an address (1) or a data (0) character. Sleeping receivers will wake up whenever an address character is received. Systems using this method for wake-up would set the MSB of the first character of each message and leave it clear for all other characters in the message. Idle periods may be present within messages and no idle time is required between messages for this wake-up method.

## Receive data (RDI)

Receive data is the serial data that is applied through the input line and the serial communications interface to the internal bus. The receiver circuitry clocks the input at a rate equal to 16 times the baud rate and this time is referred to as the RT clock.

Once a valid start bit is detected the start bit, each data bit and the stop bit are sampled three times at positions 8 RT, 9 RT and 10 RT (1 RT is the position where the bit is expected to start), as shown in **Figure 37**. The value of the bit is determined by voting logic which takes the value of the majority of the samples.



Figure 37. SCI sampling technique used on all bits



Serial Communications Interface (SCI)

#### Start bit detection

When the RDI input is detected low, it is tested for three more sample times (referred to as the start edge verification samples in **Figure 38**). If at least two of these three verification samples detect a logic zero, a valid start bit has been detected, otherwise the line is assumed to be idle. A noise flag is set if all three verification samples do not detect a logic zero. A valid start bit could be assumed with a set noise flag present.

If there has been a framing error without detection of a break (10 zeros for 8-bit format or 11 zeros for 9-bit format), the circuit continues to operate as if there was a stop bit and the start edge will be placed artificially. The last bit received in the data shift register is inverted to a logic one, and the three logic one start qualifiers (shown in Figure 38) are forced into the sample shift register during the interval when detection of a start bit is anticipated (see Figure 39); therefore, the start bit will be accepted no sooner than it is anticipated.

If the receiver detects that a break produced the framing error, the start bit will not be artificially induced and the receiver must detect a logic one before the start bit can be recognised (see Figure 40).



Serial Communications Interface (SCI) Start bit detection



#### Figure 38. SCI examples of start bit sampling technique



Serial Communications Interface (SCI)







b) Case 2, receive line high during expected start edge





Figure 40. SCI start bit following a break

Semiconductor, Inc.



## Transmit data (TDO)

Transmit data is the serial data from the internal data bus that is applied through the serial communications interface to the output line. The transmitter generates a bit time by using a derivative of the RT clock, thus producing a transmission rate equal to 1/16th that of the receiver sample clock.

## **SCI registers**

Primarily the SCI system is configured and controlled by five registers (BAUD, SCCR1, SCCR2, SCSR, and SCDR). In addition, the serial communications interface baud bit (SCIB) in the PWM mode register (PWMM) provides access to the SCI baud rate register (BAUD) at address \$000D (see Figure 8-1).

## PWM mode register (PWMM)



Figure 41. PWM Mode Register (PWMM)

SCIB — Serial communications interface baud SCIB is a read/write control bit that provides access to either the SCI baud rate register or the PWM4 data register at address \$000D. This bit is set following reset.

1 = SCI baud rate register accessed at address \$000D

0 = SCI PWM4 register accessed at address \$000D

The other control bits in this register are discussed in **Pulse Width Modulator (PWM)**.

nunica ace ba



Semiconductor, Inc.

reescale

## Serial Communications Interface (SCI)

| Serial         |
|----------------|
| communications |
| data register  |
| (SCDR)         |

The SCI data register (SCDR) is actually two separate registers. When SCDR is read, the read-only receive data register is accessed and when SCDR is written, the write-only transmit data register is accessed. This address is unaffected by reset.





Figure 42. SCI Data Register (SCDR)

Serial communications control register 1 (SCCR1)

The SCI control register 1 (SCCR1) contains control bits related to the nine data bit character format and the receiver wake-up feature.

**NOTE:** Bits 0–2 and 5 are not implemented in this register and always read as zeros.





R8 — Receive data bit 8

This read-only bit is the ninth serial data bit received when the SCI system is configured for nine data bit operation (M = 1). The most significant bit (bit 8) of the received character is transferred into this bit at the same time as the remaining eight bits (bits 0–7) are transferred from the serial receive shifter to the SCI receive data register.



Serial Communications Interface (SCI) SCI registers

T8 — Transmit data bit 8

This read/write bit is the ninth data bit to be transmitted when the SCI system is configured for nine data bit operation (M = 1). When the eight low order bits (bits 0–7) of a transmit character are transferred from the SCI data register to the serial transmit shift register, this bit (bit 8) is transferred to the ninth bit position of the shifter.

M — Mode (select character format)

The M bit is a read/write bit which controls the character length for both the transmitter and receiver at the same time. The 9th data bit is most commonly used as an extra stop bit or in conjunction with the "address mark" wake-up method. It can also be used as a parity bit.

- 1 = 1 start bit, 8 data, 9th data bit, 1 stop bit
- 0 = 1 start bit, 8 data bits, 1 stop bit
- WAKE Wake-up mode select

This read/write bit is used to select the wake-up mode used by the receiver.

- 1 = Wake-up on address mark; if RWU is set, SCI will wake-up if the 8th (if M=1) or 9th (if M=0) bit received on the Rx line is set
- 0 = Wake-up on idle line; if RWU is set, SCI will wake-up after 11 (if M=0) or 12 (if M=1) consecutive '1's on the Rx line

The SCI control register 2 (SCCR2) contains the control bits that enable/disable individual SCI functions. SCCR2 is cleared during reset and can be read or written at any time.



Figure 44. SCI Control Register 2 (SCCR2)

Serial communications control register 2 (SCCR2)

MC68HC05D9 Rev 3.0

13-sci



## Serial Communications Interface (SCI)

TIE — Transmit interrupt enable

This bit allows the processor to be interrupted by the SCI when the contents of the transmit data register are transferred to the transmit shift register, i.e. when the transmit data register is ready to accept the next byte to be transmitted.

- 1 = Transmit interrupt enabled (interrupt if TDRE = 1)
- 0 = Transmit interrupt disabled
- TCIE Transmit complete interrupt enable

This bit allows the processor to be interrupted by the SCI when the last bit has been transferred out of the transmit shift register to the TDO line.

- 1 = Transmit complete interrupt enabled (interrupt if TC = 1)
- 0 = Transmit complete interrupt disabled
- RIE Receiver interrupt enable

This bit allows the processor to be interrupted by the SCI when the contents of the receive shift register are transferred to the receive data register or when an overrun occurs (i.e. when a byte is ready to be transferred from the receive shift register but the receive data register still contains the previously received byte.

1 = Receiver interrupt enabled (interrupt if RDRF or OR = 1)

- 0 = Receiver interrupt disabled
- ILIE Idle line interrupt enable

This bit allows the processor to be interrupted by the SCI when the receiver detects an idle line condition.

1 = Idle line interrupt enabled (interrupt if IDLE = 1)

0 =Idle line interrupt disabled

TE — Transmitter enable

When the transmitter enable bit is set, the transmit shift register output is applied to the TDO line. Depending on the state of control bit M (SCCR1), a preamble of 10 (M = 0) or 11 (M = 1) consecutive ones is transmitted when software sets the TE bit from a cleared state. After loading the last byte in the serial communications data register and receiving the TDRE flag, the user can clear TE. Transmission of the last byte will then be completed before the transmitter gives up control of the TDO pin. While the transmitter is active, the data direction register control for Port D bit 1 is overridden and the line is forced to be an output.



Serial Communications Interface (SCI) SCI registers

- 1 = Transmitter enabled
- 0 = Transmitter disabled
- RE Receiver enable

When the receiver enable bit is set, the RDI line is applied to the receiver shift register input. When RE is clear, the receiver is disabled and all the status bits associated with the receiver (RDRF, IDLE, OR, NF and FE) are inhibited. While the receiver is enabled, the data direction register control for Port D bit 0 is overridden and the line is forced to be an input. After writing to RE, at least 10 RT cycles must occur before data can be received correctly

- 1 = Receiver enabled
- 0 = Receiver disabled
- RWU Receiver wake-up

When the receiver wake-up bit is set by the user software, it puts the receiver to sleep and enables the wake-up function. If the WAKE bit is cleared, RWU is cleared by the SCI logic after receiving 10 (M = 0) or 11 (M = 1) consecutive ones. If the WAKE bit is set, RWU is cleared by the SCI logic after receiving a data word whose MSB is set.

1 = Receiver wake-up enabled

0 = Receiver wake-up disabled

#### SBK — Send break

If the send break bit is toggled set and cleared, the transmitter sends 10 (M = 0) or 11 (M = 1) zeros and then reverts to idle sending data. If SBK remains set, the transmitter will continually send whole blocks of zeros (sets of 10 or 11) until cleared. At the completion of the break code, the transmitter sends at least one high bit to guarantee recognition of a valid start bit. If the transmitter is empty and idle, setting and clearing SBK is likely to queue two character times of break because the first break transfers almost immediately to the shift register and the second is then queued into the parallel transmit buffer.

- 1 = Send break
- 0 = Do not send break



## Serial Communications Interface (SCI)

Serial communications status register (SCSR) This read-only register contains all the flag bits that indicate the status of the SCI and are used to generate interrupts from the SCI to the processor.

Address: \$0010

|                 | Bit 7 | 6  | 5    | 4    | 3  | 2  | 1  | Bit 0 |
|-----------------|-------|----|------|------|----|----|----|-------|
| Read:<br>Write: | TDRE  | TC | RDRF | IDLE | OR | NF | FE | 0     |
| Reset:          | 1     | 1  | 0    | 0    | 0  | 0  | 0  | 0     |

#### Figure 45. SCI Status Register (SCSR)

TDRE — Transmit data register empty flag

This bit is set when the byte in the transmit data register is transferred to the serial shift register. New data will not be transmitted unless the SCSR register is read before writing to the transmit data register. Reset sets this bit.

- 1 = Transmit data register empty
- 0 = Transmit data register full

TC — Transmission complete flag

This bit is set to indicate that the SCI transmitter has no meaningful information to transmit (no data in shifter, no preamble, no break). When TC is set the serial line will go idle (continuous MARK). Reset sets this bit.

- 1 = Transmission complete
- 0 = Transmission not complete

RDRF — Receive data register full flag

This bit is set when the contents of the receiver serial shift register is transferred to the receiver data register. Reset clears this bit.

- 1 = Receive data register full
- 0 = Receive data register empty

IDLE — Idle line detected flag



This bit is set when a receiver idle line is detected (the receipt of a minimum of ten/eleven consecutive "1"s). This bit will not be set by the idle line condition when the RWU bit is set. Once cleared, IDLE will not be set again until after RDRF has been set, (until after the line has been active and becomes idle again). Reset clears this bit.

- 1 = Idle line detected
- 0 = Idle line not detected

#### OR — Overrun error flag

This bit is set when a new byte is ready to be transferred from the receiver shift register to the receiver data register and the receive data register is already full (RDRF bit is set). Data transfer is inhibited until this bit is cleared. Reset clears this bit.

1 = Overrun error has occurred

0 = Overrun error has not occurred

#### NF — Noise error flag

This bit is set if there is noise on a "valid" start bit, any of the data bits, or on the stop bit. The NF bit is set during the same cycle as the RDRF bit but does not get set if an overrun (OR) occurs. Reset clears this bit.

1 = Noise error has occurred

0 = Noise error has not occurred

#### FE — Framing error flag

This bit is set when the word boundaries in the bit stream are not synchronized with the receiver bit counter (generated by the reception of a logic zero bit where a stop bit was expected). The FE bit reflects the status of the byte in the receive data register. It is set during the same cycle as the RDRF bit but does not get set if an overrun (OR) has occurred. The transfer from the receive shifter to the receive data register is also inhibited if an overrun has occurred. The framing error flag inhibits further transfer of data into the receive data register until it is cleared. Reset clears this bit.

1 = Framing error has occurred

0 = Framing error has occurred



## Serial Communications Interface (SCI)

Baud rate register (BAUD) The baud rate register (BAUD) is used to set the bit rate for the SCI system. Normally this register is written once, during initialisation, to set the baud rate for SCI communications. Both the receiver and the transmitter use the same baud rate which is derived from the MCU bus rate clock. A two stage divider is used to develop custom baud rates from normal MCU crystal frequencies so it is not necessary to use special baud rate crystal frequencies. (See Figure 35.)





**NOTE:** This register shares address \$000D with PWM4. Access to the baud rate register is gained by setting the SCIB bit in the PWM mode register to 1. The SCIB bit defaults to 1 on reset.

SCP1, SCP0 — Serial prescaler select bits

These read/write bits select one of four division ratios for the first prescaler stage (N) shown in **Figure 35**. The bus frequency clock ( $f_{OP}$ ) is divided by the factor N shown in **Table 15**. This prescaled output provides an input to the second prescaler stage which is controlled by the SCI rate select bits (SCR2–SCR0)

#### Table 15. First prescaler stage

| SCP1 | SCP0 | SCI prescaler division ratio (N) |
|------|------|----------------------------------|
| 0    | 0    | 1                                |
| 0    | 1    | 3                                |
| 1    | 0    | 4                                |
| 1    | 1    | 13                               |



#### SCR2, SCR1, SCR0 - SCI rate select bits

These three read/write bits select one of eight division ratios for the second prescaler stage (M) shown in **Figure 35**. The prescaler output described above is divided by the factors shown in **Table 16**.

| SCR2 | SCR1 | SCR0 | SCI rate select division ratio (M) |
|------|------|------|------------------------------------|
| 0    | 0    | 0    | 1                                  |
| 0    | 0    | 1    | 2                                  |
| 0    | 1    | 0    | 4                                  |
| 0    | 1    | 1    | 8                                  |
| 1    | 0    | 0    | 16                                 |
| 1    | 0    | 1    | 32                                 |
| 1    | 1    | 0    | 64                                 |
| 1    | 1    | 1    | 128                                |

#### Table 16. Second prescaler stage



Serial Communications Interface (SCI)

MC68HC05D9 Rev 3.0

20-sci



## Pulse Width Modulator (PWM)

## **Contents**

| ntroduction                            | 99    |
|----------------------------------------|-------|
| PWM counter                            | 99    |
| PWM registers                          | . 100 |
| PWM mode register                      | . 100 |
| PWM channel data registers (PWM0–PWM4) | . 102 |
|                                        |       |

#### Introduction

The pulse width modulation unit on the MC68HC05D9 is a self-contained sub-system providing 5 PWM channels of six bits to be used as independent D to A converters. It consists of a 6-bit counter, a PWM mode control register and 5 PWM channel data registers (see Figure 47). The PWM output signals, PWM0–4, appear on port D pins 2-5 and 7, respectively, provided they are enabled.

## **PWM** counter

The PWM counter, which has a range of \$00 to \$3F, is driven by the bus frequency clock, fop. The output pulse level on each channel is set to 1 (high) when the counter value equals \$00. The counter value is continuously compared with the contents of each data register. When the counter value equals that of the PWM data register, the output pulse is reset to 0 (low).

1-pwm



## Pulse Width Modulator (PWM)





## **PWM registers**

#### PWM mode register

This register contains five bits, PWM0–PWM4, that enable the PWM output waveforms to appear on the associated port D pins and one bit, SCIB, which allows either the PWM4 data register or the SCI baud register to be accessible at address \$000D. On reset, the SCI baud register is available at this address.

When not being used for the PWM outputs, the associated pins can be configured as normal I/O pins by clearing the corresponding PWM bit in the PWM mode register, where a 1 dedicates the pin to PWM output. Due to the port D data direction register being set to input on reset, the PWM channels present a high impedance until the PWM mode register is rewritten.

Address: \$0008

Bit 7 6 5 4 3 2 1 Bit 0 Figure 48. PWM Mode Register (PWMM)



| Read:  | 0 | 0 | SCIE | PWM4 | PWM3    | PWM2 | PWM1 | PWM0 |  |
|--------|---|---|------|------|---------|------|------|------|--|
| Write: | 0 | U | JUL  |      | 1 11113 |      |      |      |  |
| Reset: | 0 | 1 | 0    | 0    | 0       | 0    | 0    | 0    |  |

Figure 48. PWM Mode Register (PWMM)

SCIB — Serial communications interface baud

SCIB is a read/write control bit that provides access to either the SCI baud rate register or the PWM4 data register at address \$000D. This bit is set following reset.

1 = SCI baud rate register accessed at address \$000D

0 = PWM4 register accessed at address \$000D

PWM0 - 4 - PWM channel enable bits

These read/write bits allow the corresponding PWM channels to be enabled or disabled.

1 = PWM channel enabled

0 = PWM channel disabled



Pulse Width Modulator (PWM)

## PWM channel data registers (PWM0–PWM4)

PWM channel 0 (PWM0) PWM channel 1 (PWM1) PWM channel 2 (PWM2) PWM channel 3 (PWM3) PWM channel 4 (PWM4)

| Address | bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | bit 0 | Reset     |
|---------|-------|---|---|---|---|---|---|-------|-----------|
| \$0009  | 0     | 0 |   |   |   |   |   |       | 0000 0000 |
| \$000A  | 0     | 0 |   |   |   |   |   |       | 0000 0000 |
| \$000B  | 0     | 0 |   |   |   |   |   |       | 0000 0000 |
| \$000C  | 0     | 0 |   |   |   |   |   |       | 0000 0000 |
| \$000D  | 0     | 0 |   |   |   |   |   |       | 0000 0000 |

The PWM4 data register shares its address at \$000D with the SCI baud register. Read or write access to the PWM4 register is gained by setting the SCIB bit in the PWM mode register to 0. On reset, this bit defaults to a 1 and the PWM rate is set at  $f_{OP}/64$ , corresponding to a maximum rate of 31.3 kHz.

A value of \$00 loaded into the data registers results in a continuously low output, whereas a value of \$20 results in a 50% duty cycle output and so on. The maximum value is \$3F which corresponds to an output which is at 1 for 63/64 of the cycle. (See Figure 49.)

When the MCU makes a write to a PWM register, the new value will only be picked up by the D to A converters at the end of a conversion cycle. The counter is cleared to \$00 on reset and the data latches are set to \$00. Therefore, on power-on and on each subsequent reset of the device, the PWM channels resume their zero values.



#### Figure 49. PWM output waveform examples.



## **Electrical Specifications**

## Contents

| ntroduction                                      | 103 |
|--------------------------------------------------|-----|
| Maximum ratings                                  | 103 |
| Thermal characteristics and power considerations | 103 |
| DC electrical characteristics                    | 106 |
| Control timing                                   | 107 |
|                                                  |     |

## Introduction

This section contains the electrical specifications and associated timing information for the MC68HC05D9, MC68HC05D24, MC68HC05D32 and MC68HC705D32.

## **Maximum ratings**

#### Thermal characteristics and power considerations

The average chip junction temperature,  $T_J$ , in degrees Celsius can be obtained from the following equation:

$$T_{J} = T_{A} + (P_{D} \bullet \theta_{JA})$$
<sup>[1]</sup>

where:

 $T_A$  = Ambient temperature (°C)

**Electrical Specifications** 

| Rating                                                                           | Symbol           | Value                                                                                                              | Unit |
|----------------------------------------------------------------------------------|------------------|--------------------------------------------------------------------------------------------------------------------|------|
| Supply voltage                                                                   | V <sub>DD</sub>  | - 0.3 to +7.0                                                                                                      | V    |
| Input voltage<br>(ports, OSC1)                                                   | V <sub>IN</sub>  | V <sub>SS</sub> – 0.3 to<br>V <sub>DD</sub> + 0.3                                                                  | V    |
| Input voltage<br>– RESET, IRQ                                                    | V <sub>IN</sub>  | V <sub>SS</sub> – 0.3 to<br>2 x V <sub>DD</sub> + 0.3                                                              | V    |
| Input voltage<br>- VPP - MC68HC705D32                                            | V <sub>PP</sub>  | V <sub>SS</sub> – 0.3 to 19                                                                                        | V    |
| Operating temperature range                                                      | T <sub>A</sub>   | T <sub>L</sub> to T <sub>H</sub><br>–40 to +85 (all devices except<br>MC68HC05D9)<br>–40 to +105 (MC68HC05D9 only) | °C   |
| Storage temperature range                                                        | T <sub>STG</sub> | – 65 to +150                                                                                                       | °C   |
| Current drain per pin (note 2) $-$ excluding V <sub>DD</sub> and V <sub>SS</sub> | Ι <sub>D</sub>   | 25                                                                                                                 | mA   |

#### Table 17. Maximum ratings

(1)All voltages are with respect to  $V_{SS}$ .

(2)Maximum current drain per pin is for one pin at a time, limited by an external resistor.

(3)This device contains circuitry designed to protect against damage due to high electrostatic voltages or electric fields. However, it is recommended that normal precautions be taken to avoid the application of any voltages higher than those given in the maximum ratings table to this high impedance circuit. For maximum reliability all unused inputs should be tied to either V<sub>SS</sub> or V<sub>DD</sub>.

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

 $P_{D} = P_{INT} + P_{I/O} (W)$ 

 $P_{INT}$  = Internal chip power =  $I_{DD} \bullet V_{DD}$  (W)

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

An approximate relationship between  $P_D$  and  $T_J$  (if  $P_{I/O}$  is neglected) is:

$$P_{D} = \frac{K}{T_{I} + 273}$$
 [2]

Solving equations [1] and [2] for K gives:

$$K = P_{D} \bullet (T_{A} + 273) + \theta_{JA} \bullet P_{D}^{2}$$
[3]



where K is a constant for a particular part. K can be determined 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 for any value of  $T_A$  by solving the above equations. The package thermal characteristics are shown in **Table 18**.

#### Table 18. Package thermal characteristics

| Characteristics                                                             | Symbol        | Value | Unit |
|-----------------------------------------------------------------------------|---------------|-------|------|
| Thermal resistance<br>– 40-pin plastic DIL package<br>– 44-pin PLCC package | $\theta_{JA}$ | 50    | °C/W |



| PE | 30–7 | 520Ω | 130Ω | 50pF |
|----|------|------|------|------|
|    |      |      |      |      |
|    |      |      |      |      |

**R1** 

 $3.26 k\Omega$ 

**R2** 

 $2.38k\Omega$ 

С

50pF

Pins

PA0-7, PC0-7, PD0-7

Figure 50. Equivalent test load



## DC electrical characteristics

## Table 19. DC electrical characteristics (5.0 V operation)

 $(V_{DD} = 5.0 \text{ Vdc} \pm 10\%, V_{SS} = 0 \text{ Vdc}, T_A = T_L \text{ to } T_H$ Characteristic Symbol Min Тур Max Output voltage  $I_{LOAD} = -25 \,\mu A$ VOH  $V_{DD} - 0.1$  $V_{OL}$ 0.1  $I_{LOAD} = +25 \,\mu A$ Output high voltage ( $I_{LOAD} = -0.8 \text{ mA}$ )  $V_{DD} - 0.8$ VOH \_\_\_\_ PA0-7, PB0-7, PC0-7, PD0-7 Output low voltage ( $I_{LOAD} = +1.6 \text{ mA}$ )  $V_{OL}$ 0.4 \_\_\_\_ \_\_\_\_ PA0-7, PB0-7, PC0-7, PD0-7 Output low voltage ( $I_{LOAD} = +25 \text{ mA}$ ) Vol 1.0 PB0-7 Input high voltage PA0-7, PB0-7, PC0-7, PD0-7, VIH 0.7V<sub>DD</sub> OSC1, TCAP, IRQ, RESET Input low voltage PA0-7, PB0-7, PC0-7, PD0-7,  $V_{IL}$ VSS 0.2V<sub>DD</sub> OSC1, TCAP, IRQ, RESET Supply current (see notes) RUN 5.5 9.5 RUN (MC68HC05D32) 12  $I_{DD}$ WAIT 1 4 STOP 2 10 STOP (MC68HC705D32) 150 High-Z leakage current ±1 ΙI \_\_\_\_ PA0-7, PB0-7, PC0-7, PD0-7 Input current ±1  $I_{IN}$ OSC1, TCAP, IRQ, RESET Total port B sink current to V<sub>SS</sub> 200 ISS Data retention mode voltage  $V_{RM}$ 2.0 \_\_\_\_ \_\_\_\_ Capacitance Ports (as input or output) 12 COUT **IRQ**, **RESET** 8 CIN

MC68HC705D32 EPROM

Programming voltage

Programming current

Programming time

Unit

V

V

V

V

V

V

V

mΑ

mΑ

mΑ

μΑ

μA

μΑ

μΑ

mΑ

V

pF pF

V

mΑ

ms

VPP

IPP

t<sub>PROG</sub>

14

4

15

2

16



#### Table 19. DC electrical characteristics (5.0 V operation)

| $(V_{DD} = 5.0 \text{ Vdc} \pm$ | $10\% V_{00} = 0 V dc$ | $T_{A} = T_{L} t_{O} T_{LL}$          |
|---------------------------------|------------------------|---------------------------------------|
| $(v_{DD} - 3.0 v_{UC} \pm$      | $10/0, v_{SS} = 0 vuc$ | $\gamma$ , $I_{A} = I_{I} \cup I_{H}$ |

| 00             | <br> |        |     |     |     |      |
|----------------|------|--------|-----|-----|-----|------|
| Characteristic |      | Symbol | Min | Тур | Max | Unit |
|                |      |        |     |     |     |      |

 All I<sub>DD</sub> measurements taken with suitable decoupling capacitors across the power supply to suppress the transient switching currents inherent in CMOS designs (see VDD and VSS).

(2)Typical values are at mid point of voltage range and at 25°C only.

(3)RUN and WAIT IDD: measured using an external square-wave clock source (fOSC = 4MHz); all inputs 0.2V from rail; no DC loads; maximum load on outputs 50pF (except OSC2 load 20pF).

(4)WAIT IDD: only the timer system active; current varies linearly with the OSC2 capacitance.

(5)WAIT and STOP IDD: all ports configured as inputs; VIL = 0.2V and VIH = VDD - 0.2V.

(6)STOP IDD: measured with OSC1 = VDD.

#### Control timing

5-elec



#### Table 20. DC electrical characteristics (3.3 V operation)

 $(V_{DD} = 3.3 \text{ Vdc} \pm 10\%, V_{SS} = 0 \text{ Vdc}, T_A = T_L \text{ to } T_H$ 

| Characteristic                                                                       | Symbol                              | Min                   | Тур          | Max                | Unit           |
|--------------------------------------------------------------------------------------|-------------------------------------|-----------------------|--------------|--------------------|----------------|
| Output voltage<br>$I_{LOAD} = -25 \ \mu A$<br>$I_{LOAD} = +25 \ \mu A$               | V <sub>OH</sub><br>V <sub>OL</sub>  | V <sub>DD</sub> – 0.1 |              | 0.1                | V<br>V         |
| Output high voltage (I <sub>LOAD</sub> = - 0.8 mA)<br>PA0-7, PB0-7, PC0-7, PD0-7     | V <sub>OH</sub>                     | V <sub>DD</sub> – 0.3 |              | _                  | V              |
| Output low voltage (I <sub>LOAD</sub> = +1.6 mA)<br>PA0–7, PB0–7, PC0–7, PD0–7       | V <sub>OL</sub>                     |                       | _            | 0.3                | V              |
| Output low voltage (I <sub>LOAD</sub> = +25 mA)<br>PB0–7                             | V <sub>OL</sub>                     |                       |              | 0.5                | V              |
| Input high voltage<br>PA0–7, PB0–7, PC0–7, PD0–7,<br>OSC1, TCAP, IRQ, RESET          | V <sub>IH</sub>                     | 0.7V <sub>DD</sub>    |              | _                  | V              |
| Input low voltage<br>PA0–7, PB0–7, PC0–7, PD0–7,<br>OSC1, TCAP, IRQ, RESET           | V <sub>IL</sub>                     | V <sub>SS</sub>       | _            | 0.2V <sub>DD</sub> | V              |
| Supply current (see notes)<br>RUN<br>WAIT<br>STOP                                    | IDD                                 | <br><br>              |              | 3<br>1.4<br>5      | mA<br>mA<br>μA |
| High-Z leakage current<br>PA0–7, PB0–7, PC0–7, PD0–7                                 | IIL                                 |                       |              | ±1                 | μA             |
| Input current<br>OSC1, TCAP, IRQ, RESET                                              | I <sub>IN</sub>                     | _                     |              | ±1                 | μΑ             |
| Total port B sink current to V <sub>SS</sub>                                         | I <sub>SS</sub>                     | —                     |              | 200                | mA             |
| Data retention mode voltage                                                          | V <sub>RM</sub>                     | 2.0                   | —            | _                  | V              |
| Capacitance<br>Ports (as input or output)<br>IRQ, RESET                              | C <sub>OUT</sub><br>C <sub>IN</sub> |                       |              | 12<br>8            | pF<br>pF       |
| MC68HC705D32 EPROM<br>Programming voltage<br>Programming current<br>Programming time | VPP<br>IPP<br><sup>t</sup> pROG     | 14<br>                | 15<br>2<br>— | 16<br>             | V<br>mA<br>ms  |

(1) All I<sub>DD</sub> measurements taken with suitable decoupling capacitors across the power supply to suppress the transient switching currents inherent in CMOS designs (see VDD and VSS).

(2)Typical values are at mid point of voltage range and at 25°C only.

(3)RUN and WAIT IDD: measured using an external square-wave clock source (fOSC = 4MHz); all inputs 0.2V from rail; no DC loads; maximum load on outputs 50pF (except OSC2 load 20pF).

(4)WAIT IDD: only the timer system active; current varies linearly with the OSC2 capacitance.

(5)WAIT and STOP IDD: all ports configured as inputs; VIL = 0.2V and VIH = VDD - 0.2V.

(6)STOP IDD: measured with OSC1 = VDD.





#### Table 21. Control timing (5.0 V operation)

 $(V_{DD} = 5.0 \text{ Vdc} \pm 10\%, V_{SS} = 0 \text{ Vdc}, T_A = T_L \text{ to } T_H)$ 

| Characteristic                             | Symbol                            | Min  | Max  | Unit             |
|--------------------------------------------|-----------------------------------|------|------|------------------|
| Frequency of operation                     |                                   |      |      |                  |
| Crystal                                    | f <sub>OSC</sub>                  | —    | 4.0  | MHz              |
| External clock                             | f <sub>OSC</sub>                  | dc   | 4.0  | MHz              |
| Internal operating frequency               |                                   |      |      |                  |
| Crystal (f <sub>OSC</sub> /2)              | f <sub>OP</sub>                   | _    | 2.0  | MHz              |
| External clock (f <sub>OSC</sub> /2)       | f <sub>OP</sub>                   | dc   | 2.0  | MHz              |
| Processor cycle time                       | t <sub>CYC</sub>                  | 500  | _    | ns               |
| Crystal oscillator start-up time           | t <sub>OXOV</sub>                 |      | 100  | ms               |
| RESET pulse width                          | t <sub>RL</sub>                   | 8    | —    | t <sub>CYC</sub> |
| Power-on reset delay                       | t <sub>PORL</sub>                 | 3968 | 3968 | t <sub>CYC</sub> |
| Interrupt pulse width low (edge-triggered) | t <sub>ILIH</sub>                 | 125  |      | ns               |
| Interrupt pulse period                     | t <sub>ILIL</sub>                 | (1)  | —    | t <sub>CYC</sub> |
| OSC1 pulse width                           | t <sub>OH</sub> , t <sub>OL</sub> | 100  |      | ns               |

1. The minimum period t<sub>ILIL</sub> should not be less than the number of cycles it takes to execute the interrupt service routine plus t<sub>CYC</sub>.

#### Table 22. Control timing (3.0 V operation)

 $(V_{DD} = 3.3 \text{ Vdc} \pm 10\%, V_{SS} = 0 \text{ Vdc}, T_A = T_L \text{ to } T_H)$ 

| Characteristic                             | Symbol                            | Min  | Max  | Unit             |
|--------------------------------------------|-----------------------------------|------|------|------------------|
| Frequency of operation                     |                                   |      |      |                  |
| Crystal                                    | fosc                              | —    | 2.0  | MHz              |
| External clock                             | f <sub>OSC</sub>                  | dc   | 2.0  | MHz              |
| Internal operating frequency               |                                   |      |      |                  |
| Crystal (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              |
| Processor cycle time                       | t <sub>CYC</sub>                  | 1000 |      | ns               |
| Crystal oscillator start-up time           | t <sub>OXOV</sub>                 | —    | 100  | ms               |
| RESET pulse width                          | t <sub>RL</sub>                   | 8    |      | t <sub>CYC</sub> |
| Power-on reset delay                       | t <sub>PORL</sub>                 | 3968 | 3968 | t <sub>CYC</sub> |
| Interrupt pulse width low (edge-triggered) | t <sub>ILIH</sub>                 | 250  |      | ns               |
| Interrupt pulse period                     | t <sub>ILIL</sub>                 | (1)  |      | t <sub>CYC</sub> |
| OSC1 pulse width                           | t <sub>OH</sub> , t <sub>OL</sub> | 200  |      | ns               |

1. The minimum period t<sub>ILIL</sub> should not be less than the number of cycles it takes to execute the interrupt service routine plus t<sub>CYC</sub>.



**Electrical Specifications** 

MC68HC05D9 Rev 3.0

8-elec



# Mechanical Data and Ordering Information

# Contents

| Mechanical Data      | <br> | <br>112 |
|----------------------|------|---------|
| Ordering information | <br> | <br>115 |
| EPROMs               | <br> | <br>115 |
| Verification media   | <br> | <br>115 |

1-mech



# Mechanical Data and Ordering Information

# **Mechanical Data**



| Dim. | Min.       | Max.  | Notes                                                                                                       | Dim. | Min.  | Max. |
|------|------------|-------|-------------------------------------------------------------------------------------------------------------|------|-------|------|
| A    | 51.69      | 52.45 | 1.Due to space limitations, case no. 711 shall be repre-                                                    | Н    | 1.65  | 2.16 |
| В    | 13.72      | 14.22 | sented by a general case outline, rather than one showing all the leads.                                    | J    | 0.20  | 0.38 |
| С    | 3.94       | 5.08  |                                                                                                             | K    | 2.92  | 3.43 |
| D    | 0.36       | 0.56  | 2.All dimensions in mm.                                                                                     |      | 15.24 | BSC  |
| F    | 1.02       | 1.52  | 3.Positional tolerance of leads ('D') shall be within 0.25 mm at maximum material condition, in relation to | М    | 0°    | 15°  |
|      | G 2.54 BSC |       | seating plane and to each other.                                                                            |      |       |      |
| G    |            |       | 4.Dimension 'L' is to centre of leads when formed parallel.                                                 | Ν    | 0.51  | 1.02 |
|      |            |       | 5.Dimension 'B' does not include mould protrusion.                                                          |      |       |      |

#### Figure 51. 40-pin PDIP mechanical dimensions

MC68HC05D9 Rev 3.0

2-mech



Mechanical Data and Ordering Information Mechanical Data



| Dim | Millim   | Millimeters |               | Inches |     | Millin | neters | Inc   | hes   |
|-----|----------|-------------|---------------|--------|-----|--------|--------|-------|-------|
|     | Min      | Мах         | Min           | Мах    | Dim | Min    | Мах    | Min   | Мах   |
| A   | 17.40    | 17.65       | 0.685         | 0.695  | U   | 16.51  | 16.66  | 0.650 | 0.656 |
| В   | 17.40    | 17.65       | 0.685         | 0.695  | V   | 1.07   | 1.21   | 0.042 | 0.048 |
| C   | 4.20     | 4.57        | 0.165         | 0.180  | W   | 1.07   | 1.21   | 0.042 | 0.048 |
| E   | 2.29     | 2.79        | 0.090         | 0.110  | X   | 1.07   | 1.42   | 0.042 | 0.056 |
| F   | 0.33     | 0.48        | 0.013         | 0.019  | Y   | _      | 0.50   | _     | 0.020 |
| G   | 1.27 BSC |             | BSC 0.050 BSC |        | Z   | 2°     | 10°    | 2°    | 10°   |
| Н   | 0.66     | 0.81        | 0.026         | 0.032  | G1  | 15.50  | 16.00  | 0.610 | 0.630 |
| J   | 0.51     | —           | 0.020         | —      | K1  | 1.02   | _      | 0.040 | _     |
| К   | 0.64     | —           | 0.025         | —      | Z1  | 2°     | 10°    | 2°    | 10°   |
| R   | 16.51    | 16.66       | 0.650         | 0.656  |     |        |        |       |       |

- 1.Due to space limitation, case 777-02 shall be represented by a general (smaller) case outline drawing rather than showing all 44 leads.
- 2.Datums -L-, -M-, -N- and -P- determine where top of lead shoulder exits plastic body at mould parting line.
- 3.Dim G1: True position to be measured at datum -T-, seating plane.
- 4.Dim R and U do not include mould protrusion. Allowable mould protrusion is 0.25 (0.010) per side.
- 5.Dimensioning and tolerancing per ANSI Y14.5M, 1982.

6.Controlling dimension: inch.

7.777-01 is obsolete; new standard 777-02.

#### Figure 52. 44-pin PLCC mechanical dimensions

Semiconductor, Inc



## Mechanical Data and Ordering Information



| Dim. | Min.     | Max.  | Notes                                                                                                                | Dim. | Min.  | Max.  |
|------|----------|-------|----------------------------------------------------------------------------------------------------------------------|------|-------|-------|
| Α    | 9.90     | 10.10 | 1.Datum plane –H– is located at bottom of lead and is coincident                                                     | М    | 5°    | 10°   |
| В    | 9.90     | 10.10 | with the lead where the lead exits the plastic body at the bottom of                                                 | Ν    | 0.130 | 0.170 |
| С    | 2.10     | 2.45  | the parting line.                                                                                                    | Q    | 0°    | 7°    |
| D    | 0.30     | 0.45  | 2.Datums A–B and –D to be determined at datum plane –H–. 3.Dimensions S and V to be determined at seating plane –C–. | R    | 0.13  | 0.30  |
| Е    | 2.00     | 2.10  | 4.Dimensions A and B do not include mould protrusion. Allowable                                                      | S    | 12.95 | 13.45 |
| F    | 0.30     | 0.40  | mould protrusion is 0.25mm per side. Dimensions A and B do                                                           | Т    | 0.13  | _     |
| G    | 0.80 BSC |       | include mould mismatch and are determined at datum plane -H                                                          | U    | 0°    | _     |
| Н    | _        | 0.250 | 5.Dimension D does not include dambar protrusion. Allowable                                                          | V    | 12.95 | 13.45 |
| J    | 0.130    | 0.230 | dambar protrusion shall be 0.08 total in excess of the D dimension                                                   | W    | 0.40  | _     |
| K    | 0.65     | 0.95  | at maximum material condition. Dambar cannot be located on the lower radius or the foot.                             |      | 1.6   | REF   |
| L    | 8.00 REF |       | 6.Dimensions and tolerancing per ANSI Y 14.5M, 1982.<br>7.All dimensions in mm.                                      |      |       |       |

#### Figure 53 44-pin QFP mechanical dimensions



# Ordering information

This section describes the information needed to order the MCU.

To initiate a ROM pattern for the MCU, it is necessary first to contact your local field service office, local sales person or Freescale representative. Please note that you will need to supply details such as mask option selections, temperature range, oscillator frequency, package type, electrical test requirements and device marking details, so that an order can be processed and a customer specific part number allocated.

**NOTE:** The MC68HC705D32 has no customer specific ROM, or options, and may therefore be ordered as a standard part.

EPROMs For the MC68HC05D9, a 16K byte EPROM programmed with the customer's software (positive logic for address and data) should be submitted for pattern generation. All unused bytes should be programmed to zeros. For the MC68HC05D24 and the MC68HC05D32, a 32K byte EPROM should be used.

**NOTE:** The EPROM must be programmed such that the user's software is mapped exactly as it will appear in the masked ROM, e.g. the reset vector must be located at \$3FFE and \$3FFF in the EPROM submitted for an MC68HC05D32.

The EPROM should be clearly labelled, placed in a conductive IC carrier and securely packed.

All original pattern media (EPROMs) are filed for contractual purposes

# Verification media

and are not returned. A computer listing of the ROM code will be generated and returned with a listing verification form. The listing should be thoroughly checked and the verification form completed, signed and returned to Freescale. The signed verification form constitutes the contractual agreement for creation of the custom mask. If desired, Freescale will program blank EPROMs (supplied by the customer) from the data file used to create the custom mask, to aid in the verification process.

5-mech



Mechanical Data and Ordering Information

MC68HC05D9 Rev 3.0

6-mech



# Features Specific to the MC68HC05D24

### Contents

| Introduction             | 117 |
|--------------------------|-----|
| Memory map and registers | 117 |
| Programming model        | 117 |

# Introduction

The MC68HC05D24 is similar to the MC68HC05D9, but with 24K bytes of masked ROM instead of 16K bytes. Apart from the extended ROM and the resulting changes to the memory map and register addresses, which are discussed in this appendix, the MC68HC05D24 is identical to the MC68HC05D9 (see Figure 54).

#### Memory map and registers

The memory map for this device is shown in **Figure 54**. The registers are shown in more detail in **Table 23**. Note that the address locations of the self-check ROM, the option register and the self-check and user vectors are \$4000 higher than in the MC68HC05D9.

#### **Programming model**

The programming model of the MC68HC05D24 is identical to that of the MC68HC05D9, except for the program counter (see Figure 55). Only bit 15 of the program counter (PC) in the MC68HC05D24 is permanently

1-05D24



Semiconductor, Inc.

Freescale

**Freescale Semiconductor, Inc.** 

#### Features Specific to the MC68HC05D24



#### Figure 54. Memory map of the MC68HC05D24

MC68HC05D9 Rev 3.0

2-05D24



| Register name              | Address | bit 7 | bit 6 | bit 5 | bit 4 | bit 3 | bit 2 | bit 1 | bit 0 | State on reset |
|----------------------------|---------|-------|-------|-------|-------|-------|-------|-------|-------|----------------|
| Port A data (PORTA)        | \$0000  |       |       |       |       |       |       |       |       | undefined      |
| Port B data (PORTB)        | \$0001  |       |       |       |       |       |       |       |       | undefined      |
| Port C data (PORTC)        | \$0002  |       |       |       |       |       |       |       |       | undefined      |
| Port D data (PORTD)        | \$0003  |       |       |       |       |       |       |       |       | undefined      |
| Data direction A (DDRA)    | \$0004  |       |       |       |       |       |       |       |       | 0000 0000      |
| Data direction B (DDRB)    | \$0005  |       |       |       |       |       |       |       |       | 0000 0000      |
| Data direction C (DDRC)    | \$0006  |       |       |       |       |       |       |       |       | 0000 0000      |
| Data direction D (DDRD)    | \$0007  |       |       |       |       |       |       |       |       | 0u00 0000      |
| PWM mode (PWMM)            | \$0008  | 0     | 0     | SCIB  | PWM4  | PWM3  | PWM2  | PWM1  | PWM0  | 0010 0000      |
| PWM channel 0 (PWM0)       | \$0009  | 0     | 0     |       |       |       |       |       |       | 0000 0000      |
| PWM channel 1 (PWM1)       | \$000A  | 0     | 0     |       |       |       |       |       |       | 0000 0000      |
| PWM channel 2 (PWM2)       | \$000B  | 0     | 0     |       |       |       |       |       |       | 0000 0000      |
| PWM channel 3 (PWM3)       | \$000C  | 0     | 0     |       |       |       |       |       |       | 0000 0000      |
| PWM channel 4 (PWM4)       | \$000D  | 0     | 0     |       |       |       |       |       |       | 0000 0000      |
| SCI baud rate (BAUD)       | (1)     |       |       | SCP1  | SCP0  |       | SCR2  | SCR1  | SCR0  | นน00 นนนน      |
| SCI control 1 (SCCR1)      | \$000E  | R8    | T8    | 0     | М     | WAKE  | 0     | 0     | 0     | uu0u u000      |
| SCI control 2 (SCCR2)      | \$000F  | TIE   | TCIE  | RIE   | ILIE  | TE    | RE    | RWU   | SBK   | 0000 0000      |
| SCI status (SCSR)          | \$0010  | TDRE  | тс    | RDRF  | IDLE  | OR    | NF    | FE    | 0     | 1100 0000      |
| SCI data (SCDR)            | \$0011  |       |       |       |       |       |       |       |       | undefined      |
| Timer control (TCR)        | \$0012  | ICIE  | OCIE  | TOIE  | 0     | 0     | 0     | IEDG  | OLVL  | 0000 0000      |
| Timer status (TSR)         | \$0013  | ICF   | OCF   | TOF   | 0     | 0     | 0     | 0     | 0     | uuu0 0000      |
| Input capture (ICR)        | \$0014  |       |       |       |       |       |       |       |       | undefined      |
|                            | \$0015  |       |       |       |       |       |       |       |       | undefined      |
| Output compare (OCR)       | \$0016  |       |       |       |       |       |       |       |       | undefined      |
|                            | \$0017  |       |       |       |       |       |       |       |       | undefined      |
| Timer counter (TCNT)       | \$0018  |       |       |       |       |       |       |       |       | 1111 1111      |
|                            | \$0019  |       |       |       |       |       |       |       |       | 1111 1100      |
| Alternate counter (ALTCNT) | \$001A  |       |       |       |       |       |       |       |       | 1111 1111      |
|                            | \$001B  |       |       |       |       |       |       |       |       | 1111 1100      |
| Reserved                   | \$001C  |       |       |       |       |       |       |       |       | undefined      |
| COP reset (COPRST)         | \$001D  | ICAF  | ICBF  | OCAF  | TOF   | 0     | 0     | 0     | 0     | 0000 0000      |
| COP control (COPCR)        | \$001E  | 0     | 0     | 0     | COPF  | CME   | COPE  | CM1   | CM0   | 0000 0000      |
| Reserved                   | \$001F  |       |       |       |       |       |       |       |       | undefined      |



# Features Specific to the MC68HC05D24

#### Table 23. MC68HC05D24 register assignment

| Register name | Address | bit 7 | bit 6 | bit 5 | bit 4 | bit 3 | bit 2 | bit 1 | bit 0 | State on reset |
|---------------|---------|-------|-------|-------|-------|-------|-------|-------|-------|----------------|
|               |         |       |       |       |       |       |       |       |       |                |
| OPTION        | \$7FDF  | RAM0  | RAM1  | 0     | 0     | 0     |       | IRQ   | 0     | 0000 0u10      |
| u = undefined |         |       |       |       |       |       |       |       |       |                |

1. If SCIB = 0, the PWM4 register is available at location \$000D

If SCIB = 1, the SCI baud rate generator register is available at location \$000D

set to zero, thus restricting the address range to \$0000–\$7FFF (32K bytes).



Figure 55. Programming model of the MC68HC05D24



# Features Specific to the MC68HC05D32

## Contents

| Introduction             | 121 |
|--------------------------|-----|
| Memory map and registers | 121 |
| Programming model        | 121 |

# Introduction

The MC68HC05D24 is similar to the MC68HC05D9, but with 32K bytes of masked ROM instead of 16K bytes. Apart from the extended ROM and the resulting changes to the memory map and register addresses, which are discussed in this appendix, the MC68HC05D24 is identical to the MC68HC05D9 (see Figure 56).

#### Memory map and registers

The memory map for this device is shown in **Figure 56**. The registers are shown in more detail in **Table 24**. Note that the address locations of the self-check ROM, the option register and the self-check and User vectors are \$4000 higher than in the MC68HC05D9.

## Programming model

The programming model of the MC68HC05D24 is identical to that of the MC68HC05D9, except for the program counter (see Figure 57). Only bit 15 of the program counter (PC) in the MC68HC05D24 is permanently

1-05D32



#### Features Specific to the MC68HC05D32



#### Figure 56. Memory map of the MC68HC05D24

set to zero, thus restricting the address range to \$0000–\$7FFF (32K bytes).



| Register name              | Address               | bit 7 | bit 6 | bit 5 | bit 4 | bit 3 | bit 2 | bit 1 | bit 0 | State on reset |
|----------------------------|-----------------------|-------|-------|-------|-------|-------|-------|-------|-------|----------------|
| Port A data (PORTA)        | \$0000                |       |       |       |       |       |       |       |       | undefined      |
| Port B data (PORTB)        | \$0001                |       |       |       |       |       |       |       |       | undefined      |
| Port C data (PORTC)        | \$0002                |       |       |       |       |       |       |       |       | undefined      |
| Port D data (PORTD)        | \$0003                |       |       |       |       |       |       |       |       | undefined      |
| Data direction A (DDRA)    | \$0004                |       |       |       |       |       |       |       |       | 0000 0000      |
| Data direction B (DDRB)    | \$0005                |       |       |       |       |       |       |       |       | 0000 0000      |
| Data direction C (DDRC)    | \$0006                |       |       |       |       |       |       |       |       | 0000 0000      |
| Data direction D (DDRD)    | \$0007                |       |       |       |       |       |       |       |       | 0u00 0000      |
| PWM mode (PWMM)            | \$0008                | 0     | 0     | SCIB  | PWM4  | PWM3  | PWM2  | PWM1  | PWM0  | 0010 0000      |
| PWM channel 0 (PWM0)       | \$0009                | 0     | 0     |       |       |       |       |       |       | 0000 0000      |
| PWM channel 1 (PWM1)       | \$000A                | 0     | 0     |       |       |       |       |       |       | 0000 0000      |
| PWM channel 2 (PWM2)       | \$000B                | 0     | 0     |       |       |       |       |       |       | 0000 0000      |
| PWM channel 3 (PWM3)       | \$000C                | 0     | 0     |       |       |       |       |       |       | 0000 0000      |
| PWM channel 4 (PWM4)       | \$000D <sup>(1)</sup> | 0     | 0     |       |       |       |       |       |       | 0000 0000      |
| SCI baud rate (BAUD)       | -<br>Φ000D、 /         |       |       | SCP1  | SCP0  |       | SCR2  | SCR1  | SCR0  | นน00 นนนน      |
| SCI control 1 (SCCR1)      | \$000E                | R8    | T8    | 0     | М     | WAKE  | 0     | 0     | 0     | uu0u u000      |
| SCI control 2 (SCCR2)      | \$000F                | TIE   | TCIE  | RIE   | ILIE  | TE    | RE    | RWU   | SBK   | 0000 0000      |
| SCI status (SCSR)          | \$0010                | TDRE  | тс    | RDRF  | IDLE  | OR    | NF    | FE    | 0     | 1100 0000      |
| SCI data (SCDR)            | \$0011                |       |       |       |       |       |       |       |       | undefined      |
| Timer control (TCR)        | \$0012                | ICIE  | OCIE  | TOIE  | 0     | 0     | 0     | IEDG  | OLVL  | 0000 0000      |
| Timer status (TSR)         | \$0013                | ICF   | OCF   | TOF   | 0     | 0     | 0     | 0     | 0     | uuu0 0000      |
| Input capture (ICR)        | \$0014                |       |       |       |       |       |       |       |       | undefined      |
|                            | \$0015                |       |       |       |       |       |       |       |       | undefined      |
| Output compare (OCR)       | \$0016                |       |       |       |       |       |       |       |       | undefined      |
|                            | \$0017                |       |       |       |       |       |       |       |       | undefined      |
| Timer counter (TCNT)       | \$0018                |       |       |       |       |       |       |       |       | 1111 1111      |
|                            | \$0019                |       |       |       |       |       |       |       |       | 1111 1100      |
| Alternate counter (ALTCNT) | \$001A                |       |       |       |       |       |       |       |       | 1111 1111      |
|                            | \$001B                |       |       |       |       |       |       |       |       | 1111 1100      |
| Reserved                   | \$001C                |       |       |       |       |       |       |       |       | undefined      |
| COP reset (COPRST)         | \$001D                | ICAF  | ICBF  | OCAF  | TOF   | 0     | 0     | 0     | 0     | 0000 0000      |
| COP control (COPCR)        | \$001E                | 0     | 0     | 0     | COPF  | CME   | COPE  | CM1   | CM0   | 0000 0000      |
| Reserved                   | \$001F                |       |       |       |       |       |       |       |       | undefined      |

u = undefined



# Features Specific to the MC68HC05D32

#### Table 24. MC68HC05D24 register assignment

| Register name | Address | bit 7 | bit 6 | bit 5 | bit 4 | bit 3 | bit 2 | bit 1 | bit 0 | State on reset |
|---------------|---------|-------|-------|-------|-------|-------|-------|-------|-------|----------------|
|               |         |       |       |       |       |       |       |       |       |                |
| OPTION        | \$7FDF  | RAM0  | RAM1  | 0     | 0     | 0     |       | IRQ   | 0     | 0000 0u10      |
| u = undefined |         |       |       |       |       |       |       |       |       |                |

1. If SCIB = 0, the PWM4 register is available at location \$000D

If SCIB = 1, the SCI baud rate generator register is available at location \$000D



Figure 57. Programming model of the MC68HC05D24

MC68HC05D9 Rev 3.0

4-05D32



# Features Specific to the MC68HC705D32

# Contents

| Introduction                     |
|----------------------------------|
| Operating mode selection         |
| Pin descriptions                 |
| VPP                              |
| OSC1/OSC2                        |
| Crystal                          |
| External clock                   |
| Memory                           |
| MC68HC705D32 EPROM description   |
| Programming sequence             |
| EPROM security                   |
| Program control register (PCR)   |
| EPROM mask option register (MOR) |
| Bootloader mode                  |
| Bootloader functions             |

#### Introduction

The MC68HC705D32 is similar to the MC68HC05D32, but with 32K bytes of UV-erasable EPROM instead of masked ROM. The MC68HC705D32 is identical to the MC68HC05D32 (see Figure 58) apart from the EPROM replacing ROM.

#### **Operating mode selection**

Single chip mode on the MC68HC705D32 is identical to single chip mode on the MC68HC05D32. However, on the MC68HC705D32 a bootloader ROM replaces the self-check ROM on the MC68HC05D32.

1-705D32



## Features Specific to the MC68HC705D32

The bootloader mode provides for self-programming of the EPROM array and allows software to be loaded into, and run from, the on-board RAM. The voltage level on the  $\overline{IRQ}$  pin determines whether single chip mode or bootloader mode is selected (see Table 25).

- **NOTE:** The TCAP pin must be tied to  $V_{DD}$  to ensure correct selection of the bootloader mode. Failure to do so could result in unpredictable operation.
- **CAUTION:** For the MC68HC705D32, all vectors are fetched from the EPROM (locations \$7FF6–\$7FFF) in single chip mode; therefore, the EPROM must be programmed (via the bootloader mode) before the device is powered up in single chip mode.

#### Table 25. Operating mode entry conditions

| IRQ                          | RESET | ТСАР            | Mode        |  |  |
|------------------------------|-------|-----------------|-------------|--|--|
| $\rm V_{SS}$ to $\rm V_{DD}$ |       | Don't care      | Single chip |  |  |
| 2 V <sub>DD</sub>            |       | V <sub>DD</sub> | Bootloader  |  |  |

Note: The voltage level on the  $\overline{IRQ}$  pin should be maintained for at least 7x t<sub>cyc</sub> after the rising edge of the reset signal to guarantee proper mode selection.

## **Pin descriptions**

VPP

Programming power is supplied to the EPROM array on the MC68HC705D32 via this pin. The nominal programming voltage is 15 Volts. The voltage level on the VPP pin should never be allowed to fall below  $V_{DD}$ .

MC68HC05D9 Rev 3.0

2-705D32



Features Specific to the MC68HC705D32 Memory

**OSC1/OSC2** These pins provide control input for an on-chip clock oscillator circuit. A crystal or an external clock signal connected to these pins provides the oscillator clock. The oscillator frequency is divided by 2 to provide the internal bus frequency.

Crystal The circuit shown in Figure 5(b) is recommended when using a crystal. The internal oscillator is designed to interface with an AT-cut parallel-resonant quartz crystal resonator in the frequency range specified for f<sub>OSC</sub> (see Control timing). Use of an external CMOS oscillator is recommended when crystals outside the specified ranges are to be used. The crystal and components should be mounted as close as possible to the input pins to minimise output distortion and start-up stabilizing time.

- External clockAn external clock should be applied to the OSC1 input with the OSC2 pin<br/>not connected, as shown in Figure 5(d). The t<sub>OXOV</sub> specification does not<br/>apply when using an external clock input. The equivalent specification of<br/>the external clock source should be used in lieu of t<sub>OXOV</sub>.
  - **NOTE:** A ceramic resonator should not be used with the MC68HC705D32.

## Memory

The memory map for this device is shown in **Table 25**. The registers are shown in more detail in **Table 26**. Note that the MC68HC705D32 has an additional register to control the programming of the EPROM array.The circuit diagram for this self-programming mode is shown in **Figure 58**.

3-705D32



#### Features Specific to the MC68HC705D32



#### Figure 58. Memory map of the MC68HC705D32

MC68HC05D9 Rev 3.0

4-705D32



| Register Name              | Address | bit 7  | bit 6  | bit 5  | bit 4  | bit 3  | bit 2  | bit 1 | bit 0 | State<br>on reset |
|----------------------------|---------|--------|--------|--------|--------|--------|--------|-------|-------|-------------------|
| Port A data (PORTA)        | \$0000  |        |        |        |        |        |        |       |       | Unaffected        |
| Port B data (PORTB)        | \$0001  |        |        |        |        |        |        |       |       | Unaffected        |
| Port C data (PORTC)        | \$0002  |        |        |        |        |        |        |       |       | Unaffected        |
| Port D data (PORTD)        | \$0003  |        |        |        |        |        |        |       |       | Unaffected        |
| Data direction A (DDRA)    | \$0004  |        |        |        |        |        |        |       |       | 0000 0000         |
| Data direction B (DDRB)    | \$0005  |        |        |        |        |        |        |       |       | 0000 0000         |
| Data direction C (DDRC)    | \$0006  |        |        |        |        |        |        |       |       | 0000 0000         |
| Data direction D (DDRD)    | \$0007  |        |        |        |        |        |        |       |       | 0u00 0000         |
| Unused                     | \$0008  |        |        |        |        |        |        |       |       |                   |
| Unused                     | \$0009  |        |        |        |        |        |        |       |       |                   |
| SPCR SPI control register  | \$000A  | SPIE   | SPE    | DWOM   | MSTR   | CPOL   | CPHA   | SPR1  | SPR0  | 0000 uuuu         |
| SPSR SPI status register   | \$000B  | SPIF   | WCOL   |        | MODF   |        |        |       |       | 0000 uuuu         |
| SPDR SPI data register     | \$000C  | SPD7   | SPD6   | SPD5   | SPD4   | SPD3   | SPD2   | SPD1  | SPD0  | Unaffected        |
| SCI baud rate (BAUD)       | \$000D* |        |        | SCP1   | SCP0   |        | SCR2   | SCR1  | SCR0  | นน00 นนนน         |
| SCI control 1 (SCCR1)      | \$000E  | R8     | T8     | 0      | М      | WAKE   | 0      | 0     | 0     | uu0u u000         |
| SCI control 2 (SCCR2)      | \$000F  | TIE    | TCIE   | RIE    | ILIE   | TE     | RE     | RWU   | SBK   | 0000 0000         |
| SCI status (SCSR)          | \$0010  | TDRE   | тс     | RDRF   | IDLE   | OR     | NF     | FE    | 0     | 1100 0000         |
| SCI data (SCDR)            | \$0011  |        |        |        |        |        |        |       |       | Unaffected        |
| Timer control (TCR)        | \$0012  | ICIE   | OCIE   | TOIE   | 0      | 0      | 0      | IEDG  | OLVL  | 0000 0000         |
| Timer status (TSR)         | \$0013  | ICF    | OCF    | TOF    | 0      | 0      | 0      | 0     | 0     | uuu0 0000         |
| Input conture (ICP)        | \$0014  | bit 15 | bit 14 | bit 13 | bit 12 | bit 11 | bit 10 | bit 9 | bit 8 | Unaffected        |
| Input capture (ICR)        | \$0015  | bit 7  | bit 6  | bit 5  | bit 4  | bit 3  | bit 2  | bit 1 | bit 0 | Unaffected        |
| Output compare (OCR)       | \$0016  | bit 15 | bit 14 | bit 13 | bit 12 | bit 11 | bit 10 | bit 9 | bit 8 | Unaffected        |
|                            | \$0017  | bit 7  | bit 6  | bit 5  | bit 4  | bit 3  | bit 2  | bit 1 | bit 0 | Unaffected        |
| Timer counter (TCNT)       | \$0018  | bit 15 | bit 14 | bit 13 | bit 12 | bit 11 | bit 10 | bit 9 | bit 8 | 1111 1111         |
|                            | \$0019  | bit 7  | bit 6  | bit 5  | bit 4  | bit 3  | bit 2  | bit 1 | bit 0 | 1111 1100         |
| Alternate counter (ALTCNT) | \$001A  | bit 15 | bit 14 | bit 13 | bit 12 | bit 11 | bit 10 | bit 9 | bit 8 | 1111 1111         |
|                            | \$001B  | bit 7  | bit 6  | bit 5  | bit 4  | bit 3  | bit 2  | bit 1 | bit 0 | 1111 1100         |
| EPROM programming register | \$001C  |        |        |        |        |        | LATCH  |       | EPGM  | 0000 0000         |
| COP reset (COPRST)         | \$001D  | ICAF   | ICBF   | OCAF   | TOF    | 0      | 0      | 0     | 0     | 0000 0000         |
| COP control (COPCR)        | \$001E  | 0      | 0      | 0      | COPF   | CME    | COPE   | CM1   | CM0   | 0000 0000         |
| Reserved                   | \$001F  |        |        |        |        |        |        |       |       |                   |
| OPTION                     | \$7FDF  | RAM0   | RAM1   | 0      | 0      | 0      | —      | IRQ   | 0     | 0000 0u10         |

#### Table 26. MC68HC705D32 register assignment

Note: If SCIE = 0, the PWM4 register is available at location \$000D.

If SCIE = 1, the SCI Baud Rate Generator register is available at this location.

u = undefined

5-705D32



## Features Specific to the MC68HC705D32

# MC68HC705D32 EPROM description

| The 32k byte EPROM is positioned at locations \$0020 to \$004F and       |
|--------------------------------------------------------------------------|
| \$0100 to \$7EFF, with 16 bytes of the EPROM located at \$7FF0 to \$7FFF |
| for user vectors. Location \$7FDE is reserved for the mask option        |
| register. The erased state of EPROM reads as \$00 and EPROM power        |
| is supplied by the VPP pin and the VDD pin.                              |

The program control register (PCR) is provided for EPROM programming and testing.

Access to the EPROM in bootloader and test mode is controlled by a security bit in the mask option register called SEC. For further information on EPROM security, see EPROM security.

Programming sequence

The sequence includes:

- Setting the ELAT bit
- Writing the data to the address to be programmed
- Setting the PGM bit
- Delaying for an appropriate amount of time
- Clearing the ELAT and PGM bit

It is important to remember that an external programming voltage must be applied to the VPP pin while programming, but it should be equal to V<sub>DD</sub> during normal operations.

EPROM security A security feature has been incorporated into the MC68HC705D32 to prevent externally accessing the contents of the EPROM in any non-user mode of operation. This feature, once enabled, can only be disabled by completely erasing the EPROM.

> NOTE: For OTP (plastic) packaged parts, once the security feature has been enabled it cannot be disabled



# Program control register (PCR)

The program control register is provided for EPROM programming in BOOT modes. This register is available only in the MC68HC705D32 (EPROM device).



Figure 59. Program Control Register (PCR)

- LATCH EPROM latch control
  - 1 = EPROM address and data bus configured for programming (writes to EPROM cause address and data to be latched).
     EPROM is in programming mode and cannot be read if LATCH is set. This bit should not be set if no programming voltage is being applied to the VPP pin. Reset clears this bit.
  - 0 = EPROM address and data bus configured for normal reads.
- EPGM EPROM program command
  - 1 = Programming power is switched ON to EPROM array. This bit can be set only if the LATCH bit has been previously set. Reset clears this bit.
  - 0 = Programming power is switched OFF from EPROM array.

EPROM mask option register (MOR) The option register MOR is implemented as EPROM bits in the main EPROM array at address \$7DFE.





7-705D32



Features Specific to the MC68HC705D32

1. This register is implemented in EPROM, therefore reset has no effect on the state of the individual bits.

SEC — Security bit

This bit is used to control the security of the EPROM code when the device is in test or bootloader mode.

- 1 = EPROM contents not available in bootloader/test mode
- 0 = EPROM contents available in bootloader/test mode

## **Bootloader mode**

Bootloader mode is entered upon the rising edge of RESET if the VPP pin is at  $V_{TST}$  and the TCAP pin is at logic one. The bootloader code and vectors reside in the ROM from \$7F00 to \$7FEF. This program handles copying of user code from an external EPROM into the on-chip EPROM. The bootloader function has to be done from an external EPROM. The bootloader performs one programming pass at 2 ms per byte then does a verify pass.

The user code must be a one-to-one correspondence with the internal EPROM addresses. The designer MUST disable the COP hardware in bootloader mode. In the erase state the COP is disabled.

#### Bootloader functions

|       | Po    | rt D  | Bootloader |                      |
|-------|-------|-------|------------|----------------------|
| Pin 5 | Pin 4 | Pin 3 | Pin 3      | Program operation    |
| 1     | x     | х     | х          | Program MOR          |
| 0     | 1     | х     | 0          | Load RAM and execute |
| 0     | 0     | 1     | 0          | Verify               |
| 0     | 0     | 0     | 0          | Program/verify       |
| х     | х     | х     | 1          | JMP to RAM           |

#### Table 27. Bootloader functions

The EPROM must be erased before performing a program cycle

MC68HC05D9 Rev 3.0

8-705D32



Features Specific to the MC68HC705D32 Bootloader mode





9-705D32



Features Specific to the MC68HC705D32

MC68HC05D9 Rev 3.0

10-705D32



Glossary

A — See "accumulator (A)."

- accumulator (A) An 8-bit general-purpose register in the CPU08. The CPU08 uses the accumulator to hold operands and results of arithmetic and logic operations.
- acquisition mode A mode of PLL operation during startup before the PLL locks on a frequency. Also see "tracking mode."
- address bus The set of wires that the CPU or DMA uses to read and write memory locations.
- addressing mode The way that the CPU determines the operand address for an instruction. The M68HC08 CPU has 16 addressing modes.
- ALU See "arithmetic logic unit (ALU)."
- arithmetic logic unit (ALU) The portion of the CPU that contains the logic circuitry to perform arithmetic, logic, and manipulation operations on operands.
- **asynchronous** Refers to logic circuits and operations that are not synchronized by a common reference signal.
- baud rate The total number of bits transmitted per unit of time.
- BCD See "binary-coded decimal (BCD)."
- binary Relating to the base 2 number system.
- **binary number system** The base 2 number system, having two digits, 0 and 1. Binary arithmetic is convenient in digital circuit design because digital circuits have two permissible voltage levels, low and high. The binary digits 0 and 1 can be interpreted to correspond to the two digital voltage levels.
- **binary-coded decimal (BCD)** A notation that uses 4-bit binary numbers to represent the 10 decimal digits and that retains the same positional structure of a decimal number. For example,

234 (decimal) = 0010 0011 0100 (BCD)



Glossary

# Freescale Semiconductor, Inc.

- **bit** A binary digit. A bit has a value of either logic 0 or logic 1.
- **branch instruction** An instruction that causes the CPU to continue processing at a memory location other than the next sequential address.
- **break module** A module in the M68HC08 Family. The break module allows software to halt program execution at a programmable point in order to enter a background routine.
- **breakpoint** A number written into the break address registers of the break module. When a number appears on the internal address bus that is the same as the number in the break address registers, the CPU executes the software interrupt instruction (SWI).
- **break interrupt** A software interrupt caused by the appearance on the internal address bus of the same value that is written in the break address registers.
- **bus** A set of wires that transfers logic signals.
- **bus clock** The bus clock is derived from the CGMOUT output from the CGM. The bus clock frequency, f<sub>op</sub>, is equal to the frequency of the oscillator output, CGMXCLK, divided by four.
- **byte** A set of eight bits.
- C The carry/borrow bit in the condition code register. The CPU08 sets the carry/borrow bit 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 bit (as in bit test and branch instructions and shifts and rotates).
- CCR See "condition code register."
- **central processor unit (CPU)** The primary functioning unit of any computer system. The CPU controls the execution of instructions.
- CGM See "clock generator module (CGM)."
- clear To change a bit from logic 1 to logic 0; the opposite of set.
- **clock** A square wave signal used to synchronize events in a computer.



- clock generator module (CGM) A module in the M68HC08 Family. The CGM generates a base clock signal from which the system clocks are derived. The CGM may include a crystal oscillator circuit and or phase-locked loop (PLL) circuit.
- **comparator** A device that compares the magnitude of two inputs. A digital comparator defines the equality or relative differences between two binary numbers.
- **computer operating properly module (COP)** A counter module in the M68HC08 Family that resets the MCU if allowed to overflow.
- **condition code register (CCR)** An 8-bit register in the CPU08 that contains the interrupt mask bit and five bits that indicate the results of the instruction just executed.
- **control bit** One bit of a register manipulated by software to control the operation of the module.
- **control unit** One of two major units of the CPU. The control unit contains logic functions that synchronize the machine and direct various operations. The control unit decodes instructions and generates the internal control signals that perform the requested operations. The outputs of the control unit drive the execution unit, which contains the arithmetic logic unit (ALU), CPU registers, and bus interface.
- COP See "computer operating properly module (COP)."
- **counter clock** The input clock to the TIM counter. This clock is the output of the TIM prescaler.
- CPU See "central processor unit (CPU)."
- **CPU08** The central processor unit of the M68HC08 Family.
- **CPU clock** The CPU clock is derived from the CGMOUT output from the CGM. The CPU clock frequency is equal to the frequency of the oscillator output, CGMXCLK, divided by four.
- **CPU cycles** A CPU cycle is one period of the internal bus clock, normally derived by dividing a crystal oscillator source by two or more so the high and low times will be equal. The length of time required to execute an instruction is measured in CPU clock cycles.



**CPU registers** — Memory locations that are wired directly into the CPU logic instead of being part of the addressable memory map. The CPU always has direct access to the information in these registers. The CPU registers in an M68HC08 are:

- A (8-bit accumulator)
- H:X (16-bit index register)
- SP (16-bit stack pointer)
- PC (16-bit program counter)
- CCR (condition code register containing the V, H, I, N, Z, and C bits)
- CSIC customer-specified integrated circuit

**cycle time** — The period of the operating frequency:  $t_{CYC} = 1/f_{OP}$ .

decimal number system — Base 10 numbering system that uses the digits zero through nine.

- **direct memory access module (DMA)** A M68HC08 Family module that can perform data transfers between any two CPU-addressable locations without CPU intervention. For transmitting or receiving blocks of data to or from peripherals, DMA transfers are faster and more code-efficient than CPU interrupts.
- DMA See "direct memory access module (DMA)."
- **DMA service request** A signal from a peripheral to the DMA module that enables the DMA module to transfer data.
- **duty cycle** A ratio of the amount of time the signal is on versus the time it is off. Duty cycle is usually represented by a percentage.
- **EEPROM** Electrically erasable, programmable, read-only memory. A nonvolatile type of memory that can be electrically reprogrammed.
- **EPROM** Erasable, programmable, read-only memory. A nonvolatile type of memory that can be erased by exposure to an ultraviolet light source and then reprogrammed.
- **exception** An event such as an interrupt or a reset that stops the sequential execution of the instructions in the main program.



- external interrupt module (IRQ) A module in the M68HC08 Family with both dedicated external interrupt pins and port pins that can be enabled as interrupt pins.
- fetch To copy data from a memory location into the accumulator.
- firmware Instructions and data programmed into nonvolatile memory.
- free-running counter A device that counts from zero to a predetermined number, then rolls over to zero and begins counting again.
- full-duplex transmission Communication on a channel in which data can be sent and received simultaneously.
- H The upper byte of the 16-bit index register (H:X) in the CPU08.
- H The half-carry bit in the condition code register of the CPU08. This bit indicates a carry from the low-order four bits of the accumulator value to the high-order four bits. The half-carry bit is required for binary-coded decimal arithmetic operations. The decimal adjust accumulator (DAA) instruction uses the state of the H and C bits to determine the appropriate correction factor.
- **hexadecimal** Base 16 numbering system that uses the digits 0 through 9 and the letters A through F.
- high byte The most significant eight bits of a word.
- illegal address An address not within the memory map
- illegal opcode A nonexistent opcode.
- I The interrupt mask bit in the condition code register of the CPU08. When I is set, all interrupts are disabled.
- index register (H:X) A 16-bit register in the CPU08. The upper byte of H:X is called H. The lower byte is called X. In the indexed addressing modes, the CPU uses the contents of H:X to determine the effective address of the operand. H:X can also serve as a temporary data storage location.
- **input/output (I/O)** Input/output interfaces between a computer system and the external world. A CPU reads an input to sense the level of an external signal and writes to an output to change the level on an external signal.



Glossary

- instructions Operations that a CPU can perform. Instructions are expressed by programmers as assembly language mnemonics. A CPU interprets an opcode and its associated operand(s) and instruction.
- **interrupt** A temporary break in the sequential execution of a program to respond to signals from peripheral devices by executing a subroutine.
- **interrupt request** A signal from a peripheral to the CPU intended to cause the CPU to execute a subroutine.
- I/O See "input/output (I/0)."
- IRQ See "external interrupt module (IRQ)."
- jitter Short-term signal instability.
- **latch** A circuit that retains the voltage level (logic 1 or logic 0) written to it for as long as power is applied to the circuit.
- latency The time lag between instruction completion and data movement.
- least significant bit (LSB) The rightmost digit of a binary number.
- **logic 1** A voltage level approximately equal to the input power voltage ( $V_{DD}$ ).
- **logic 0** A voltage level approximately equal to the ground voltage ( $V_{ss}$ ).
- low byte The least significant eight bits of a word.
- **Iow voltage inhibit module (LVI)** A module in the M68HC08 Family that monitors power supply voltage.
- LVI See "low voltage inhibit module (LVI)."
- M68HC08 A Freescale family of 8-bit MCUs.
- mark/space The logic 1/logic 0 convention used in formatting data in serial communication.
- **mask** 1. A logic circuit that forces a bit or group of bits to a desired state. 2. A photomask used in integrated circuit fabrication to transfer an image onto silicon.



- **mask option** A optional microcontroller feature that the customer chooses to enable or disable.
- **mask option register (MOR)** An EPROM location containing bits that enable or disable certain MCU features.
- MCU Microcontroller unit. See "microcontroller."
- **memory location** Each M68HC08 memory location holds one byte of data and has a unique address. To store information in a memory location, the CPU places the address of the location on the address bus, the data information on the data bus, and asserts the write signal. To read information from a memory location, the CPU places the address of the location on the address bus and asserts the read signal. In response to the read signal, the selected memory location places its data onto the data bus.

memory map — A pictorial representation of all memory locations in a computer system.

- **microcontroller** Microcontroller unit (MCU). A complete computer system, including a CPU, memory, a clock oscillator, and input/output (I/O) on a single integrated circuit.
- **modulo counter** A counter that can be programmed to count to any number from zero to its maximum possible modulus.
- **monitor ROM** A section of ROM that can execute commands from a host computer for testing purposes.
- MOR See "mask option register (MOR)."
- most significant bit (MSB) The leftmost digit of a binary number.
- **multiplexer** A device that can select one of a number of inputs and pass the logic level of that input on to the output.
- N The negative bit in the condition code register of the CPU08. The CPU sets the negative bit when an arithmetic operation, logical operation, or data manipulation produces a negative result.
- **nibble** A set of four bits (half of a byte).
- **object code** The output from an assembler or compiler that is itself executable machine code, or is suitable for processing to produce executable machine code.



Glossary

- opcode A binary code that instructs the CPU to perform an operation.
- **open-drain** An output that has no pullup transistor. An external pullup device can be connected to the power supply to provide the logic 1 output voltage.
- **operand** Data on which an operation is performed. Usually a statement consists of an operator and an operand. For example, the operator may be an add instruction, and the operand may be the quantity to be added.
- **oscillator** A circuit that produces a constant frequency square wave that is used by the computer as a timing and sequencing reference.
- **OTPROM** One-time programmable read-only memory. A nonvolatile type of memory that cannot be reprogrammed.
- overflow A quantity that is too large to be contained in one byte or one word.
- page zero The first 256 bytes of memory (addresses \$0000-\$00FF).
- parity An error-checking scheme that counts the number of logic 1s in each byte transmitted. In a system that uses odd parity, every byte is expected to have an odd number of logic 1s. In an even parity system, every byte should have an even number of logic 1s. In the transmitter, a parity generator appends an extra bit to each byte to make the number of logic 1s odd for odd parity or even for even parity. A parity checker in the receiver counts the number of logic 1s in each byte. The parity checker generates an error signal if it finds a byte with an incorrect number of logic 1s.
- PC See "program counter (PC)."
- peripheral A circuit not under direct CPU control.
- **phase-locked loop (PLL)** A oscillator circuit in which the frequency of the oscillator is synchronized to a reference signal.
- PLL See "phase-locked loop (PLL)."
- **pointer** Pointer register. An index register is sometimes called a pointer register because its contents are used in the calculation of the address of an operand, and therefore points to the operand.
- **polarity** The two opposite logic levels, logic 1 and logic 0, which correspond to two different voltage levels,  $V_{DD}$  and  $V_{SS}$ .
- **polling** Periodically reading a status bit to monitor the condition of a peripheral device.



- **port** A set of wires for communicating with off-chip devices.
- **prescaler** A circuit that generates an output signal related to the input signal by a fractional scale factor such as 1/2, 1/8, 1/10 etc.
- **program** A set of computer instructions that cause a computer to perform a desired operation or operations.
- **program counter (PC)** A 16-bit register in the CPU08. The PC register holds the address of the next instruction or operand that the CPU will use.
- **pull** An instruction that copies into the accumulator the contents of a stack RAM location. The stack RAM address is in the stack pointer.
- **pullup** A transistor in the output of a logic gate that connects the output to the logic 1 voltage of the power supply.
- pulse-width The amount of time a signal is on as opposed to being in its off state.
- **pulse-width modulation (PWM)** Controlled variation (modulation) of the pulse width of a signal with a constant frequency.
- **push** An instruction that copies the contents of the accumulator to the stack RAM. The stack RAM address is in the stack pointer.
- **PWM period** The time required for one complete cycle of a PWM waveform.
- RAM Random access memory. All RAM locations can be read or written by the CPU. The contents of a RAM memory location remain valid until the CPU writes a different value or until power is turned off.
- **RC circuit** A circuit consisting of capacitors and resistors having a defined time constant.
- read To copy the contents of a memory location to the accumulator.
- register A circuit that stores a group of bits.
- **reserved memory location** A memory location that is used only in special factory test modes. Writing to a reserved location has no effect. Reading a reserved location returns an unpredictable value.
- reset To force a device to a known condition.



Glossary

# Freescale Semiconductor, Inc.

- **ROM** Read-only memory. A type of memory that can be read but cannot be changed (written). The contents of ROM must be specified before manufacturing the MCU.
- SCI See "serial communication interface module (SCI)."
- serial Pertaining to sequential transmission over a single line.
- serial communications interface module (SCI) A module in the M68HC08 Family that supports asynchronous communication.
- serial peripheral interface module (SPI) A module in the M68HC08 Family that supports synchronous communication.
- set To change a bit from logic 0 to logic 1; opposite of clear.
- shift register A chain of circuits that can retain the logic levels (logic 1 or logic 0) written to them and that can shift the logic levels to the right or left through adjacent circuits in the chain.
- signed A binary number notation that accommodates both positive and negative numbers. The most significant bit is used to indicate whether the number is positive or negative, normally logic 0 for positive and logic 1 for negative. The other seven bits indicate the magnitude of the number.
- software Instructions and data that control the operation of a microcontroller.
- **software interrupt (SWI)** An instruction that causes an interrupt and its associated vector fetch.
- **SPI** See "serial peripheral interface module (SPI)."
- **stack** A portion of RAM reserved for storage of CPU register contents and subroutine return addresses.
- stack pointer (SP) A 16-bit register in the CPU08 containing the address of the next available storage location on the stack.
- start bit A bit that signals the beginning of an asynchronous serial transmission.
- status bit A register bit that indicates the condition of a device.
- **stop bit** A bit that signals the end of an asynchronous serial transmission.



- subroutine A sequence of instructions to be used more than once in the course of a program. The last instruction in a subroutine is a return from subroutine (RTS) instruction. At each place in the main program where the subroutine instructions are needed, a jump or branch to subroutine (JSR or BSR) instruction is used to call the subroutine. The CPU leaves the flow of the main program to execute the instructions in the subroutine. When the RTS instruction is executed, the CPU returns to the main program where it left off.
- **synchronous** Refers to logic circuits and operations that are synchronized by a common reference signal.
- TIM See "timer interface module (TIM)."
- timer interface module (TIM) A module used to relate events in a system to a point in time.
- timer A module used to relate events in a system to a point in time.
- **toggle** To change the state of an output from a logic 0 to a logic 1 or from a logic 1 to a logic 0.
- tracking mode Mode of low-jitter PLL operation during which the PLL is locked on a frequency. Also see "acquisition mode."
- two's complement A means of performing binary subtraction using addition techniques. The most significant bit of a two's complement number indicates the sign of the number (1 indicates negative). The two's complement negative of a number is obtained by inverting each bit in the number and then adding 1 to the result.
- unbuffered Utilizes only one register for data; new data overwrites current data.
- unimplemented memory location A memory location that is not used. Writing to an unimplemented location has no effect. Reading an unimplemented location returns an unpredictable value. Executing an opcode at an unimplemented location causes an illegal address reset.
- V The overflow bit in the condition code register of the CPU08. The CPU08 sets the V bit when a two's complement overflow occurs. The signed branch instructions BGT, BGE, BLE, and BLT use the overflow bit.
- variable A value that changes during the course of program execution.
- VCO See "voltage-controlled oscillator."



Glossary

# Freescale Semiconductor, Inc.

- **vector** A memory location that contains the address of the beginning of a subroutine written to service an interrupt or reset.
- **voltage-controlled oscillator (VCO)** A circuit that produces an oscillating output signal of a frequency that is controlled by a dc voltage applied to a control input.
- waveform A graphical representation in which the amplitude of a wave is plotted against time.
- **wired-OR** Connection of circuit outputs so that if any output is high, the connection point is high.
- **word** A set of two bytes (16 bits).
- write The transfer of a byte of data from the CPU to a memory location.
- X The lower byte of the index register (H:X) in the CPU08.
- Z The zero bit in the condition code register of the CPU08. The CPU08 sets the zero bit when an arithmetic operation, logical operation, or data manipulation produces a result of \$00.



# Index

# Numerics

| 16-bit timer interrupt | .49 |
|------------------------|-----|
| 40-pin PDIP            |     |
| mechanical dimensions  | 112 |
| pinout                 | .18 |
| 44-pin PLCC            |     |
| mechanical dimensions  | 113 |
| pinout                 | .18 |

#### Α

| accumulator                 |  |
|-----------------------------|--|
| addressing modes            |  |
| ALU — arithmetic/logic unit |  |

# В

| BAUD – baud rate register                     |
|-----------------------------------------------|
| SCR2, SCR1, SCR0 – SCI rate select bits<br>97 |
| bit manipulation instructions                 |
| 40-pin PDIP pinout                            |
| PWM                                           |
| mode                                          |

# С

| carry/borrow flag             |
|-------------------------------|
| C-bit in CCR                  |
| ceramic resonator             |
| clock monitor reset           |
| condition code register (CCR) |
| control instructions          |
| COP                           |
| COPCR – COP control register  |
| CM1, CM0 – COP mode bits      |
| CME – clock monitor enable    |
| COPE – COP enable             |
| COPF – COP failure            |
| CPU                           |
| programming model120, 124     |
| crystal                       |
|                               |

#### D

| _                       |  |
|-------------------------|--|
| direct addressing mode. |  |

# Ε

| ELAT bit in PCR131                    |
|---------------------------------------|
| EPGM bit in PCR131                    |
| EPROM                                 |
| MOR – EPROM mask option register .131 |
| PCR – program control register130     |
| programming sequence                  |
| test features                         |
| EXCOL, EXROW bits in PCR131           |
| extended addressing mode              |



# F

| features      |    |
|---------------|----|
| MC68HC05D9    | 10 |
| flowcharts    |    |
| interrupt     | 51 |
| STOP and WAIT | 52 |

## н

| half-carry flag. |  |  |  |  |   |  |  |  |  |  |  | .26 |
|------------------|--|--|--|--|---|--|--|--|--|--|--|-----|
| H-bit in CCR .   |  |  |  |  | ł |  |  |  |  |  |  | .26 |

## L

| I/O port structure                       |
|------------------------------------------|
| index register                           |
| indexed addressing mode                  |
| inherent addressing mode                 |
| Input                                    |
| instruction types                        |
| interrupt priorities                     |
| interrupts                               |
| interrupt flowchart51                    |
| interrupt priorities                     |
| maskable hardware interrupts             |
| SWI – non-maskable software interrupt.48 |
| IRQ                                      |
| IRQ – external interrupt49               |

#### J

| L                               |      |
|---------------------------------|------|
| literature distribution centers | .151 |
| low power modes                 | 50   |
| data retention mode             | 50   |
| STOP                            | 50   |

#### Μ

| maskable hardware interrupts48 |
|--------------------------------|
| 16-bit timer interrupt49       |
| IRQ – external interrupt       |
| SCI interrupt                  |
| MC68HC05D24                    |
| block diagram11                |
| memory map                     |
| register assignment            |
| MC68HC05D32                    |
| block diagram11                |
| memory map                     |
| register assignment            |
| MC68HC05D9                     |
| block diagram11                |
| MC68HC705D32                   |
| block diagram11                |
| memory map                     |
| register assignment            |
| MC68HC705D9                    |
| block diagram11                |
| memory                         |
| EPROM                          |
| memory map                     |
| RAM53                          |
| ROM                            |
| memory map                     |
| MC68HC05D24118                 |
| MC68HC05D32122                 |
| MC68HC705D32128                |
| modes of operation             |
| self-check14                   |
| single chip14                  |



# Ν

| N-bit in CCR  | 27 |
|---------------|----|
| negative flag | 27 |

# 0

# Ρ

| VPP                                    |
|----------------------------------------|
| port registers                         |
| data direction registers61             |
| port data registers                    |
| ports                                  |
| I/O port structure                     |
| I/O programming57                      |
| port D                                 |
| ports A, B and C59                     |
| power-on reset                         |
| program counter                        |
| programmable timer                     |
| block diagram64                        |
| counter                                |
| during STOP mode73                     |
| during WAIT mode72                     |
| input capture register                 |
| output compare register71              |
| TCR – timer control register67         |
| timer state diagrams                   |
| TSR – timer status register68          |
| programming model24                    |
| PWM                                    |
| block diagram100                       |
| counter                                |
| output waveforms102                    |
| PWM0–PWM4 – PWM channel data regis-    |
| ters                                   |
| PWMM – PWM mode register 100           |
| PWMM                                   |
| PWM0–4 – PWM channel enable bits. 100  |
| SCIB – serial communications interface |
| baud                                   |



# R

| RAM                            |
|--------------------------------|
| read-modify-write instructions |
| register assignment            |
| register summary               |
| register/memory instructions   |
| relative addressing mode       |
| RESET                          |
| RESET pin                      |
| resets                         |
| clock monitor reset            |
| COP                            |
| power-on reset                 |
| RESET pin                      |
| reset timing diagram44         |
| timing diagram                 |
| ROM                            |
|                                |

# S

| SCCR1                                     |
|-------------------------------------------|
| M – mode                                  |
| R8 – receive data bit 8                   |
| T8 – transmit data bit 8                  |
| WAKE – wake-up mode select91              |
| SCCR2                                     |
| ILIE – idle line interrupt enable92       |
| RE – receiver enable                      |
| RIE – receiver interrupt enable92         |
| RWU – receiver wake up                    |
| SBK – send break92                        |
| TCIE – transmit complete interrupt enable |
| · · ·                                     |
| 92                                        |
| 92<br>TE – transmitter enable             |
| TE – transmitter enable                   |
| TE – transmitter enable                   |
| TE – transmitter enable                   |
| TE – transmitter enable                   |
| TE – transmitter enable                   |
| TE – transmitter enable                   |
| TE – transmitter enable                   |

| SCCR1 – serial communications control                                                                                                                                                                                                                                                                                                                                                                               |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| register1                                                                                                                                                                                                                                                                                                                                                                                                           |
| SCCR2 – serial communications control                                                                                                                                                                                                                                                                                                                                                                               |
| register2                                                                                                                                                                                                                                                                                                                                                                                                           |
| SCDR – serial communications data regis-                                                                                                                                                                                                                                                                                                                                                                            |
| ter                                                                                                                                                                                                                                                                                                                                                                                                                 |
| SCSR – serial communications status reg-                                                                                                                                                                                                                                                                                                                                                                            |
| ister94                                                                                                                                                                                                                                                                                                                                                                                                             |
| start bit detection                                                                                                                                                                                                                                                                                                                                                                                                 |
| TDO – transmit data                                                                                                                                                                                                                                                                                                                                                                                                 |
| transmitter                                                                                                                                                                                                                                                                                                                                                                                                         |
| two-wire system                                                                                                                                                                                                                                                                                                                                                                                                     |
| SCI interrupt                                                                                                                                                                                                                                                                                                                                                                                                       |
|                                                                                                                                                                                                                                                                                                                                                                                                                     |
| SUSR – serial communications status redister                                                                                                                                                                                                                                                                                                                                                                        |
| SCSR – serial communications status register<br>FF – framing error flag                                                                                                                                                                                                                                                                                                                                             |
| FE – framing error flag                                                                                                                                                                                                                                                                                                                                                                                             |
| FE – framing error flag                                                                                                                                                                                                                                                                                                                                                                                             |
| FE – framing error flag                                                                                                                                                                                                                                                                                                                                                                                             |
| FE – framing error flag95IDLE – idle line detected flag94NF – noise error flag.95OR – overrun error flag.95                                                                                                                                                                                                                                                                                                         |
| FE – framing error flag95IDLE – idle line detected flag94NF – noise error flag.95OR – overrun error flag.95RDRF - receive data register full flag.94                                                                                                                                                                                                                                                                |
| FE – framing error flag95IDLE – idle line detected flag94NF – noise error flag.95OR – overrun error flag.95RDRF - receive data register full flag.94TC – transmission complete flag.94                                                                                                                                                                                                                              |
| FE – framing error flag95IDLE – idle line detected flag94NF – noise error flag.95OR – overrun error flag.95RDRF - receive data register full flag.94TC – transmission complete flag.94TDRE – transmit data register empty flag.                                                                                                                                                                                     |
| FE – framing error flag95IDLE – idle line detected flag94NF – noise error flag.95OR – overrun error flag.95RDRF - receive data register full flag.94TC – transmission complete flag.94TDRE – transmit data register empty flag94                                                                                                                                                                                    |
| FE – framing error flag95IDLE – idle line detected flag94NF – noise error flag.95OR – overrun error flag.95RDRF - receive data register full flag.94TC – transmission complete flag.94TDRE – transmit data register empty flag.94self-check mode.14                                                                                                                                                                 |
| FE – framing error flag.       .95         IDLE – idle line detected flag.       .94         NF – noise error flag       .95         OR – overrun error flag       .95         RDRF - receive data register full flag       .94         TC – transmission complete flag.       .94         TDRE – transmit data register empty flag.       .94         self-check mode       .14         single chip mode       .14 |
| FE – framing error flag95IDLE – idle line detected flag94NF – noise error flag.95OR – overrun error flag.95RDRF - receive data register full flag.94TC – transmission complete flag.94TDRE – transmit data register empty flag.94self-check mode.14                                                                                                                                                                 |

## Т

| TCAP                                       |
|--------------------------------------------|
| TCR – timer control register               |
| ICIE – input capture interrupt enable 67   |
| IEDG – input edge                          |
| OCIE – output compare interrupt enable.    |
| 67                                         |
| OLVL – output level                        |
| TOIE – timer overflow interrupt enable .67 |
| TSR – timer status register                |
| ICF – input capture flag                   |
| TOF – timer overflow flag                  |



| V        |    |
|----------|----|
| VDD, VSS | 14 |
| VPP      |    |
| VSS, VSS | 19 |

# W Web server .152 Web site .152

| Z            |
|--------------|
| Z-bit in CCR |
| zero flag    |





# Literature Updates

This document contains the latest data available at publication time. For updates, contact one of the centers listed below:

| Literature Distribution Centers |                                                                                                                                                                               |  |
|---------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|                                 | Order literature by mail or phone.                                                                                                                                            |  |
| USA/Europe                      | Freescale Literature Distribution<br>P.O. Box 5405<br>Denver, Colorado, 80217<br>Phone 1-303-675-2140                                                                         |  |
| US & Canada only                | http://freescale.com                                                                                                                                                          |  |
| Japan                           | Nippon Freescale Semiconductor, Inc.<br>Tatsumi-SPD-JLDC<br>Toshikatsu Otsuki<br>6F Seibu-Butsuryu Center<br>3-14-2 Tatsumi Koto-Ku<br>Tokyo 135, Japan<br>Phone 03-3521-8315 |  |



Literature Updates

Hong Kong Freescale Semiconductors H.K. Ltd. 8B Tai Ping Industrial Park 51 Ting Kok Road Tai Po, N.T., Hong Kong Phone 852-26629298

# **Customer Focus Center**

1-800-521-6274

# World Marketing World Wide Web Server

Use the Internet to access Freescale's World Wide Web server. Use the following URL: www.freescale.com

# **Microcontroller Division's Web Site**

:

Directly access the Microcontroller Division's web site with the following URL:

http://design-net.com/csic/CSIC\_home.html





Home Page: www.freescale.com email: support@freescale.com USA/Europe or Locations Not Listed: Freescale Semiconductor Technical Information Center, CH370 1300 N. Alma School Road Chandler, Arizona 85224 (800) 521-6274 480-768-2130 support@freescale.com Europe, Middle East, and Africa: Freescale Halbleiter Deutschland GmbH **Technical Information Center** Schatzbogen 7 81829 Muenchen, Germany +44 1296 380 456 (English) +46 8 52200080 (English) +49 89 92103 559 (German) +33 1 69 35 48 48 (French) support@freescale.com Japan: Freescale Semiconductor Japan Ltd. Headquarters ARCO Tower 15F 1-8-1, Shimo-Meguro, Meguro-ku Tokyo 153-0064, Japan 0120 191014 +81 2666 8080 support.japan@freescale.com Asia/Pacific: Freescale Semiconductor Hong Kong Ltd. **Technical Information Center** 2 Dai King Street Tai Po Industrial Estate, Tai Po, N.T., Hong Kong +800 2666 8080 support.asia@freescale.com For Literature Requests Only: Freescale Semiconductor Literature Distribution Center P.O. Box 5405 Denver, Colorado 80217 (800) 441-2447 303-675-2140 Fax: 303-675-2150 LDCForFreescaleSemiconductor

@hibbertgroup.com

RoHS-compliant and/or Pb- free versions of Freescale products have the functionality and electrical characteristics of their non-RoHS-compliant and/or non-Pb- free counterparts. For further information, see http://www.freescale.com or contact your Freescale sales representative.

For information on Freescale.s Environmental Products program, go to http://www.freescale.com/epp.

Information in this document is provided solely to enable system and software implementers to use Freescale Semiconductor products. There are no express or implied copyright licenses granted hereunder to design or fabricate any integrated circuits or integrated circuits based on the information in this document. Freescale Semiconductor reserves the right to make changes without further notice to any products herein. Freescale Semiconductor makes no warranty, representation or guarantee regarding the suitability of its products for any particular purpose, nor does Freescale Semiconductor 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 which may be provided in Freescale Semiconductor data sheets and/or specifications can and do vary in different applications and actual performance may vary over time. All operating parameters, including "Typicals" must be validated for each customer application by customer's technical experts. Freescale Semiconductor does not convey any license under its patent rights nor the rights of others. Freescale Semiconductor 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 Freescale Semiconductor product could create a situation where personal injury or death may occur. Should Buyer purchase or use Freescale Semiconductor products for any such unintended or unauthorized application, Buyer shall indemnify and hold Freescale Semiconductor 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 Freescale Semiconductor was negligent regarding the design or manufacture of the part.



MC68HC05D9/D