# MC68HC11A8 MC68HC11A1 MC68HC11A0

# *Technical Summary* 8-Bit Microcontrollers

### **1** Introduction

The MC68HC11A8, MC68HC11A1, and MC68HC11A0 high-performance microcontroller units (MCUs) are based on the M68HC11 Family. These high speed, low power consumption chips have multiplexed buses and a fully static design. The chips can operate at frequencies from 3 MHz to dc. The three MCUs are created from the same masks; the only differences are the value stored in the CONFIG register, and whether or not the ROM or EEPROM is tested and guaranteed.

For detailed information about specific characteristics of these MCUs, refer to the *M68HC11 Reference Manual* (M68HC11RM/AD).

#### 1.1 Features

- M68HC11 CPU
- Power Saving STOP and WAIT Modes
- 8 Kbytes ROM
- 512 Bytes of On-Chip EEPROM
- 256 Bytes of On-Chip RAM (All Saved During Standby)
- 16-Bit Timer System
  - 3 Input Capture Channels
  - 5 Output Compare Channels
- 8-Bit Pulse Accumulator
- Real-Time Interrupt Circuit
- Computer Operating Properly (COP) Watchdog System
- Synchronous Serial Peripheral Interface (SPI)
- Asynchronous Nonreturn to Zero (NRZ) Serial Communications Interface (SCI)
- 8-Channel, 8-Bit Analog-to-Digital (A/D) Converter
- 38 General-Purpose Input/Output (I/O) Pins
  - 15 Bidirectional I/O Pins
  - 11 Input-Only Pins and 12 Output-Only Pins (Eight Output-Only Pins in 48-Pin Package)
- Available in 48-Pin Dual In-Line Package (DIP) or 52-Pin Plastic Leaded Chip Carrier (PLCC)

This document contains information on a new product. Specifications and information herein are subject to change without notice.



MOTOROLA

## Table 1 MC68HC11Ax Family Members

| Device Number | ROM | EEPROM | M RAM CONFIG* Cor |      | Comments                        |
|---------------|-----|--------|-------------------|------|---------------------------------|
| MC68HC11A8    | 8K  | 512    | 256               | \$0F | Family built around this device |
| MC68HC11A1    | 0   | 512    | 256               | \$0D | ROM disabled                    |
| MC68HC11A0    | 0   | 0      | 256               | \$0C | ROM and EEPROM disabled         |

## **Table 2 Ordering Information**

| Package            | Temperature    | CONFIG | Description       | MC Order Number |
|--------------------|----------------|--------|-------------------|-----------------|
| 48-Pin Plastic DIP | −40°to + 85°C  | \$0F   | BUFFALO ROM       | MC68HC11A8P1    |
| (P suffix)         | –40°to + 85°C  | \$0D   | No ROM            | MC68HC11A1P     |
|                    | –40°to + 105°C | \$0D   | No ROM            | MC68HC11A1VP    |
|                    | –40°to + 125°C | \$0D   | No ROM            | MC68HC11A1MP    |
|                    | −40°to + 85°C  | \$09   | No ROM, COP On    | MC68HCP11A1P    |
|                    | _40°to + 105°C | \$09   | No ROM, COP On    | MC68HCP11A1VP   |
|                    | –40°to + 125°C | \$09   | No ROM, COP On    | MC68HCP11A1MP   |
|                    | -40°to + 85°C  | \$0C   | No ROM, No EEPROM | MC68HC11A0P     |

| 52-Pin PLCC | -40°to + 85°C  | \$0F | BUFFALO ROM       | MC68HC11A8FN1  |
|-------------|----------------|------|-------------------|----------------|
| (FN suffix) | _40°to + 85°C  | \$0D | No ROM            | MC68HC11A1FN   |
|             | -40°to + 105°C | \$0D | No ROM            | MC68HC11A1VFN  |
|             | –40°to + 125°C | \$0D | No ROM            | MC68HC11A1MFN  |
|             | −40°to + 85°C  | \$09 | No ROM, COP On    | MC68HCP11A1FN  |
|             | -40°to + 105°C | \$09 | No ROM, COP On    | MC68HCP11A1VFN |
|             | –40°to + 125°C | \$09 | No ROM, COP On    | MC68HCP11A1MFN |
|             | -40°to + 85°C  | \$0C | No ROM, No EEPROM | MC68HC11A0FN   |

## TABLE OF CONTENTS

## Section

## Page

| 1 Introduction                                                 | 1  |
|----------------------------------------------------------------|----|
| 1.1 Features                                                   | 1  |
| 2 Operating Modes and Memory Maps                              | 6  |
| 2.1 Memory Maps                                                | 7  |
| 3 Resets and Interrupts                                        | 13 |
| 4 Electrically Erasable Programmable Read-Only Memory (EEPROM) | 17 |
| 5 Parallel Input/Output                                        | 19 |
| 6 Serial Communications Interface (SCI)                        | 23 |
| 7 Serial Peripheral Interface (SPI)                            | 29 |
| 8 Main Timer                                                   |    |
| 9 Pulse Accumulator                                            | 38 |
| 10 Analog-to-Digital Converter                                 | 41 |



Figure 1 MC68HC11A8 Block Diagram



Figure 2 52-Pin PLCC Pin Assignments

|                        |    | <i></i>    |    | ן                 |
|------------------------|----|------------|----|-------------------|
| PA7/PAI/OC1            | 1  | $\bigcirc$ | 48 | D V <sub>DD</sub> |
| PA6/OC2/OC1            | 2  |            | 47 | DPD5/SS           |
| PA5/OC3/OC1            | 3  |            | 46 | DPD4/SCK          |
| PA4/OC4/OC1            | 4  |            | 45 | D PD3/MOSI        |
| PA3/OC5/OC1            | 5  |            | 44 | DPD2/MISO         |
| PA2/IC1                | 6  |            | 43 | DPD1/TxD          |
| PA1/IC2                | 7  |            | 42 | ] PD0/RxD         |
| PA0/IC3                | 8  |            | 41 |                   |
| PB7/A15                | 9  |            | 40 |                   |
| PB6/A14                | 10 |            | 39 | ] RESET           |
| PB5/A13                | 11 |            | 38 | D PC7/A7/D7       |
| PB4/A12                | 12 |            | 37 | D PC6/A6/D6       |
| PB3/A11                | 13 |            | 36 | D PC5/A5/D5       |
| PB2/A10                | 14 |            | 35 | DPC4/A4/D4        |
| PB1/A9                 | 15 |            | 34 | D PC3/A3/D3       |
| PB0/A8                 | 16 |            | 33 | D PC2/A2/D2       |
| PE0/AN0                | 17 |            | 32 | D PC1/A1/D1       |
| PE1/AN1                | 18 |            | 31 | D PC0/A0/D0       |
| PE2/AN2                | 19 |            | 30 | D XTAL            |
| PE3/AN3                | 20 |            | 29 | EXTAL             |
| V <sub>RL</sub> [      | 21 |            | 28 | STRB/ R/W         |
| V <sub>RH</sub> [      | 22 |            | 27 | ΞE                |
| V <sub>SS</sub> [      | 23 |            | 26 | □ STRA/AS         |
| MODB/V <sub>STBY</sub> | 24 |            | 25 | D MODA/LIR        |
|                        |    |            |    | J                 |

| Figure 3 48-Pin | DIP | Pin | Assignments |
|-----------------|-----|-----|-------------|
|-----------------|-----|-----|-------------|

## 2 Operating Modes and Memory Maps

In single-chip operating mode, the MC68HC11A8 is a monolithic microcontroller without external address or data buses.

In expanded multiplexed operating mode, the MCU can access a 64 Kbyte address space. The space includes the same on-chip memory addresses used for single-chip mode plus external peripheral and memory devices. The expansion bus is made up of ports B and C and control signals AS and  $R/\overline{W}$ . The address,  $R/\overline{W}$ , and AS signals are active and valid for all bus cycles including accesses to internal memory locations. The following figure illustrates a recommended method of demultiplexing low-order addresses from data at port C.



Figure 4 Address/Data Demultiplexing

Special bootstrap mode allows special purpose programs to be entered into internal RAM. The bootloader program uses the SCI to read a 256-byte program into on-chip RAM at \$0000 through \$00FF. After receiving the character for address \$00FF, control passes to the loaded program at \$0000.

Special test mode is used primarily for factory testing.

#### 2.1 Memory Maps

Memory locations are the same for expanded multiplexed and single-chip modes. The on-board 256byte RAM is initially located at \$0000 after reset. The 64-byte register block originates at \$1000 after reset. RAM and/or the register block can be placed at any other 4K boundary (\$x000) after reset by writing an appropriate value to the INIT register. The 512-byte EEPROM is located at \$B600 through \$B7FF after reset if it is enabled. The 8 Kbyte ROM is located at \$E000 through \$FFFF if it is enabled.

Hardware priority is built into the memory remapping. Registers have priority over RAM, and RAM has priority over ROM. The higher priority resource covers the lower, making the underlying locations inaccessible.

In special bootstrap mode, a bootloader ROM is enabled at locations \$BF40 through \$BFFF.

In special test and special bootstrap modes, reset and interrupt vectors are located at \$BFC0 through \$BFFF.



Figure 5 Memory Map

Table 3 MC68HC11A8 Register and Control Bit Assignments (Sheet 1 of 2)(The register block can be remapped to any 4K boundary.)

|        | Bit 7  | 6     | 5     | 4     | 3     | 2     | 1     | Bit 0 |             |
|--------|--------|-------|-------|-------|-------|-------|-------|-------|-------------|
| \$1000 | PA7    | PA6   | PA5   | PA4   | PA3   | PA2   | PA1   | PA0   | PORTA       |
| \$1001 |        |       |       |       |       |       |       |       | Reserved    |
| \$1002 | STAF   | STAI  | CWOM  | HNDS  | OIN   | PLS   | EGA   | INVB  | PIOC        |
| \$1003 | PC7    | PC6   | PC5   | PC4   | PC3   | PC2   | PC1   | PC0   | PORTC       |
| \$1004 | PB7    | PB6   | PB5   | PB4   | PB3   | PB2   | PB1   | PB0   | PORTB       |
| \$1005 | PCL7   | PCL6  | PCL5  | PCL4  | PCL3  | PCL2  | PCL1  | PCL0  | PORTCL      |
| \$1006 |        |       |       |       |       |       |       |       | Reserved    |
| \$1007 | DDC7   | DDC6  | DDC5  | DDC4  | DDC3  | DDC2  | DDC1  | DDC0  | DDRC        |
| \$1008 | 0      | 0     | PD5   | PD4   | PD3   | PD2   | PD1   | PD0   | PORTD       |
| \$1009 | 0      | 0     | DDD5  | DDD4  | DDD3  | DDD2  | DDD1  | DDD0  | DDRD        |
| \$100A | PE7    | PE6   | PE5   | PE4   | PE3   | PE2   | PE1   | PE0   | PORTE       |
| \$100B | FOC1   | FOC2  | FOC3  | FOC4  | FOC5  | 0     | 0     | 0     | CFORC       |
| \$100C | OC1M7  | OC1M6 | OC1M5 | OC1M4 | OC1M3 | 0     | 0     | 0     | OC1M        |
| \$100D | OC1D7  | OC1D6 | OC1D5 | OC1D4 | OC1D3 | 0     | 0     | 0     | OC1D        |
| \$100E | Bit 15 | 14    | 13    | 12    | 11    | 10    | 9     | Bit 8 | TCNT (High) |
| \$100F | Bit 7  | 6     | 5     | 4     | 3     | 2     | 1     | Bit 0 | TCNT (Low)  |
| \$1010 | Bit 15 | 14    | 13    | 12    | 11    | 10    | 9     | Bit 8 | TIC1 (High) |
| \$1011 | Bit 7  | 6     | 5     | 4     | 3     | 2     | 1     | Bit 0 | TIC1 (Low)  |
| \$1012 | Bit 15 | 14    | 13    | 12    | 11    | 10    | 9     | Bit 8 | TIC2 (High) |
| \$1013 | Bit 7  | 6     | 5     | 4     | 3     | 2     | 1     | Bit 0 | TIC2 (Low)  |
| \$1014 | Bit 15 | 14    | 13    | 12    | 11    | 10    | 9     | Bit 8 | TIC3 (High) |
| \$1015 | Bit 7  | 6     | 5     | 4     | 3     | 2     | 1     | Bit 0 | TIC3 (Low)  |
| \$1016 | Bit 15 | 14    | 13    | 12    | 11    | 10    | 9     | Bit 8 | TOC1(High)  |
| \$1017 | Bit 7  | 6     | 5     | 4     | 3     | 2     | 1     | Bit 0 | TOC1 (Low)  |
| \$1018 | Bit 15 | 14    | 13    | 12    | 11    | 10    | 9     | Bit 8 | TOC2 (High) |
| \$1019 | Bit 7  | 6     | 5     | 4     | 3     | 2     | 1     | Bit 0 | TOC2 (Low)  |
| \$101A | Bit 15 | 14    | 13    | 12    | 11    | 10    | 9     | Bit 8 | TOC3 (High) |
| \$101B | Bit 7  | 6     | 5     | 4     | 3     | 2     | 1     | Bit 0 | TOC3 (Low)  |
| \$101C | Bit 15 | 14    | 13    | 12    | 11    | 10    | 9     | Bit 8 | TOC4 (High) |
| \$101D | Bit 7  | 6     | 5     | 4     | 3     | 2     | 1     | Bit 0 | TOC4 (Low)  |
| \$101E | Bit 15 | 14    | 13    | 12    | 11    | 10    | 9     | Bit 8 | TOC5 (High) |
| \$101F | Bit 7  | 6     | 5     | 4     | 3     | 2     | 1     | Bit 0 | TOC5 (Low)  |
| \$1020 | OM2    | OL2   | OM3   | OL3   | OM4   | OL4   | OM5   | OL5   | TCTL1       |
| \$1021 | 0      | 0     | EDG1B | EDG1A | EDG2B | EDG2A | EDG3B | EDG3A | TCTL2       |
| \$1022 | OC1I   | OC2I  | OC3I  | OC4I  | OC5I  | IC1I  | IC2I  | IC3I  | TMSK1       |
| \$1023 | OC1F   | OC2F  | OC3F  | OC4F  | OC5F  | IC1F  | IC2F  | IC3F  | TFLG1       |
| \$1024 | ΤΟΙ    | RTII  | PAOVI | PAII  | 0     | 0     | PR1   | PR0   | TMSK2       |
| \$1025 | TOF    | RTIF  | PAOVF | PAIF  | 0     | 0     | 0     | 0     | TFLG2       |

|        | Bit 7 | 6     | 5     | 4     | 3     | 2     | 1     | Bit 0 |          |
|--------|-------|-------|-------|-------|-------|-------|-------|-------|----------|
| \$1026 | DDRA7 | PAEN  | PAMOD | PEDGE | 0     | 0     | RTR1  | RTR0  | PACTL    |
| \$1027 | Bit 7 | 6     | 5     | 4     | 3     | 2     | 1     | Bit 0 | PACNT    |
| \$1028 | SPIE  | SPE   | DWOM  | MSTR  | CPOL  | CPHA  | SPR1  | SPR0  | SPCR     |
| \$1029 | SPIF  | WCOL  | 0     | MODF  | 0     | 0     | 0     | 0     | SPSR     |
| \$102A | Bit 7 | 6     | 5     | 4     | 3     | 2     | 1     | Bit 0 | SPDR     |
| \$102B | TCLR  | 0     | SCP1  | SCP0  | RCKB  | SCR2  | SCR1  | SCR0  | BAUD     |
| \$102C | R8    | Т8    | 0     | М     | WAKE  | 0     | 0     | 0     | SCCR1    |
| \$102D | TIE   | TCIE  | RIE   | ILIE  | TE    | RE    | RWU   | SBK   | SCCR2    |
| \$102E | TDRE  | TC    | RDRF  | IDLE  | OR    | NF    | FE    | 0     | SCSR     |
| \$102F | R7/T7 | R6/T6 | R5/T5 | R4/T4 | R3/T3 | R2/T2 | R1/T1 | R0/T0 | SCDR     |
| \$1030 | CCF   | 0     | SCAN  | MULT  | CD    | CC    | СВ    | CA    | ADCTL    |
| \$1031 | Bit 7 | 6     | 5     | 4     | 3     | 2     | 1     | Bit 0 | ADR1     |
| \$1032 | Bit 7 | 6     | 5     | 4     | 3     | 2     | 1     | Bit 0 | ADR2     |
| \$1033 | Bit 7 | 6     | 5     | 4     | 3     | 2     | 1     | Bit 0 | ADR3     |
| \$1034 | Bit 7 | 6     | 5     | 4     | 3     | 2     | 1     | Bit 0 | ADR4     |
| \$1035 |       |       |       |       |       |       |       |       | Reserved |
| \$1038 |       |       |       |       |       |       |       |       | Reserved |
| \$1039 | ADPU  | CSEL  | IRQE  | DLY   | CME   | 0     | CR1   | CR0   | OPTION   |
| \$103A | Bit 7 | 6     | 5     | 4     | 3     | 2     | 1     | Bit 0 | COPRST   |
| \$103B | ODD   | EVEN  | 0     | BYTE  | ROW   | ERASE | EELAT | EEPGM | PPROG    |
| \$103C | RBOOT | SMOD  | MDA   | IRV   | PSEL3 | PSEL2 | PSEL1 | PSEL0 | HPRIO    |
| \$103D | RAM3  | RAM2  | RAM1  | RAM0  | REG3  | REG2  | REG1  | REG0  | INIT     |
| \$103E | TILOP | 0     | OCCR  | CBYP  | DISR  | FCM   | FCOP  | TCON  | TEST1    |
| \$103F | 0     | 0     | 0     | 0     | NOSEC | NOCOP | ROMON | EEON  | CONFIG   |

## Table 3 MC68HC11A8 Register and Control Bit Assignments (Sheet 2 of 2)

(The register block can be remapped to any 4K boundary.)

#### HPRIO — Highest Priority I-Bit Interrupt and Miscellaneous

|        | Bit 7 | 6    | 5   | 4   | 3     | 2     | 1     | Bit 0 |
|--------|-------|------|-----|-----|-------|-------|-------|-------|
|        | RBOOT | SMOD | MDA | IRV | PSEL3 | PSEL2 | PSEL1 | PSEL0 |
| RESET: | _     | _    |     |     | 0     | 1     | 0     | 1     |

RBOOT, SMOD, and MDA reset depend on conditions at reset and can only be written in special modes (SMOD = 1).

#### RBOOT — Read Bootstrap ROM

0 = Bootloader ROM disabled and not in map

1 = Bootloader ROM enabled and in map at \$BF40-\$BFFF

SMOD — Special Mode Select

MDA — Mode Select A

| Inputs | 6    | Mode                 | Latched at Reset |      |     |  |
|--------|------|----------------------|------------------|------|-----|--|
| MODB   | MODA | -                    | RBOOT            | SMOD | MDA |  |
| 1      | 0    | Single Chip          | 0                | 0    | 0   |  |
| 1      | 1    | Expanded Multiplexed | 0                | 0    | 1   |  |
| 0      | 0    | Special Bootstrap    | 1                | 1    | 0   |  |
| 0      | 1    | Special Test         | 0                | 1    | 1   |  |

#### IRV — Internal Read Visibility

0 = No internal read visibility on external bus

1 = Data from internal reads is driven out through the external data bus

#### PSEL3–PSEL0 — Priority Select Bits 3 through 0 Refer to **3 Resets and Interrupts**.

| <b>INIT</b> — RAM and I/O Mapping |       |      |      |      |      |      |      |       |
|-----------------------------------|-------|------|------|------|------|------|------|-------|
|                                   | Bit 7 | 6    | 5    | 4    | 3    | 2    | 1    | Bit 0 |
|                                   | RAM3  | RAM2 | RAM1 | RAM0 | REG3 | REG2 | REG1 | REG0  |
| RESET:                            | 0     | 0    | 0    | 0    | 0    | 0    | 0    | 1     |

#### RAM[3:0] —256-Byte Internal RAM Map Position

RAM[3:0] determine the upper four bits of the RAM address, positioning RAM at the selected 4K boundary.

#### REG[3:0] -64-Byte Register Block Map Position

REG[3:0] determine the upper four bits of the register address, positioning registers at the selected 4K boundary. Register can be written only once in the first 64 cycles out of reset in normal modes, or any time in special modes.

| TEST1 —                                                                                                                     | - Factory T                                                                                                                                 | Test       |            |             |          |       |       | \$103E |
|-----------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------|------------|------------|-------------|----------|-------|-------|--------|
|                                                                                                                             | Bit 7                                                                                                                                       | 6          | 5          | 4           | 3        | 2     | 1     | Bit 0  |
|                                                                                                                             | TILOP                                                                                                                                       | 0          | OCCR       | CBYP        | DISR     | FCM   | FCOP  | TCON   |
| RESET:                                                                                                                      | 0                                                                                                                                           | 0          | 0          | 0           | _        | 0     | 0     | 0      |
| Test                                                                                                                        | Modes On                                                                                                                                    | ly         |            |             |          |       |       |        |
| TILOP — Test Illegal Opcode                                                                                                 |                                                                                                                                             |            |            |             |          |       |       |        |
| OCCR —                                                                                                                      | Output Co                                                                                                                                   | ondition C | Code Regi  | ster to Tir | ner Port |       |       |        |
| CBYP —                                                                                                                      | Timer Divi                                                                                                                                  | ider Chaiı | n Bypass   |             |          |       |       |        |
| DISR — Disable Resets from COP and Clock Monitor<br>DISR is forced to one out of reset in special test and bootstrap modes. |                                                                                                                                             |            |            |             |          |       |       |        |
| FCM — F                                                                                                                     | orce Cloc                                                                                                                                   | k Monitor  | Failure    |             |          |       |       |        |
| FCOP —                                                                                                                      | Force CO                                                                                                                                    | P Watcho   | dog Failur | е           |          |       |       |        |
| TCON —                                                                                                                      | Test Conf                                                                                                                                   | iguration  | Register   |             |          |       |       |        |
| CONFIG                                                                                                                      | — COP, F                                                                                                                                    | ROM, EEF   | PROM En    | ables       |          |       |       | \$103F |
|                                                                                                                             | Bit 7                                                                                                                                       | 6          | 5          | 4           | 3        | 2     | 1     | Bit 0  |
|                                                                                                                             | 0                                                                                                                                           | 0          | 0          | 0           | NOSEC    | NOCOP | ROMON | EEON   |
| RESET:                                                                                                                      | 0                                                                                                                                           | 0          | 0          | 0           |          | _     |       |        |
|                                                                                                                             |                                                                                                                                             |            |            |             | NOTE     |       |       |        |
|                                                                                                                             | The bits of this register are implemented with EEPROM cells. Programi<br>erasing follow normal EEPROM procedures. The erased state of CONFL |            |            |             |          |       |       |        |

The bits of this register are implemented with EEPROM cells. Programming and erasing follow normal EEPROM procedures. The erased state of CONFIG is \$0F. A new value is not readable until after a subsequent reset sequence. CONFIG can only be programmed or erased in special modes.

#### NOSEC — EEPROM Security Disable

Refer to 4 Electrically Erasable Programmable Read-Only Memory (EEPROM).

#### NOCOP — COP System Disable

Refer to 3 Resets and Interrupts.

### ROMON — ROM Enable

In single-chip mode, ROMON is forced to one out of reset.

- 0 = 8K ROM removed from the memory map
- 1 = 8K ROM present in the memory map

### EEON — EEPROM Enable

- 0 = EEPROM is removed from the memory map
- 1 = EEPROM is present in the memory map

## **3 Resets and Interrupts**

The MC68HC11A8 has three reset vectors and 18 interrupt vectors. The reset vectors are as follows:

- RESET, or Power-On
- COP Clock Monitor Fail
- COP Failure

The eight interrupt vectors service 23 interrupt sources (three non-maskable, 20 maskable). The three non-maskable interrupt vectors are as follows:

- Illegal Opcode Trap
- Software Interrupt
- XIRQ Pin (Pseudo Non-Maskable Interrupt)

The 20 maskable interrupt sources are subject to masking by a global interrupt mask, the I bit in the condition code register (CCR). In addition to the global I bit, all of these sources except the external interrupt ( $\overline{IRQ}$ ) pin are controlled by local enable bits in control registers. Most interrupt sources in the M68HC11 have separate interrupt vectors. For this reason, there is usually no need for software to poll control registers to determine the cause of an interrupt. The maskable interrupt sources respond to a fixed priority relationship, except that any one source can be dynamically elevated to the highest priority position of any maskable source. Refer to the table of interrupt and reset vector assignments.

On-chip peripheral systems generate maskable interrupts that are recognized only if the I bit in the CCR is clear. Maskable interrupts are prioritized according to a default arrangement, but any one source can be elevated to the highest maskable priority position by the HPRIO register. The HPRIO register can be written at any time, provided the I bit in the CCR is set.

For some interrupt sources, such as the parallel I/O and SCI interrupts, the flags are automatically cleared during the course of responding to the interrupt requests. For example, the RDRF flag in the SCI system is cleared by the automatic clearing mechanism, which consists of a read of the SCI status register while RDRF is set, followed by a read of the SCI data register. The normal response to an RDRF interrupt request is to read the SCI status register to check for receive errors, then to read the received data from the SCI data register. These two steps satisfy the automatic clearing mechanism without requiring any special instructions.

The real-time interrupt (RTI) function generates hardware interrupts at a fixed periodic rate. These hardware interrupts provide a time reference signal for routines that measure real time. The routine notes the number of times a particular interrupt has occurred and multiplies that number by the predetermined subroutine execution time.

There are four RTI signal rates available in the MC68HC11A8. The MCU oscillator frequency and the value of two software-accessible control bits, RTR1 and RTR0, in the pulse accumulator control register (PACTL) determine these signal rates. Refer to **8 Main Timer** for more information about PACTL.

| Vector Address      | Interrupt Source                       | CCR Mask | Local Mask |
|---------------------|----------------------------------------|----------|------------|
| FFC0, C1 – FFD4, D5 | Reserved                               | —        | _          |
| FFD6, D7            | SCI Serial System                      | l Bit    |            |
|                     | SCI Transmit Complete                  |          | TCIE       |
|                     | SCI Transmit Data Register Empty       |          | TIE        |
|                     | SCI Idle Line Detect                   |          | ILIE       |
|                     | SCI Receiver Overrun                   |          | RIE        |
|                     | SCI Receive Data Register Full         |          | RIE        |
| FFD8, D9            | SPI Serial Transfer Complete           | l Bit    | SPIE       |
| FFDA, DB            | Pulse Accumulator Input Edge           | l Bit    | PAII       |
| FFDC, DD            | Pulse Accumulator Overflow             | l Bit    | PAOVI      |
| FFDE, DF            | Timer Overflow                         | l Bit    | TOI        |
| FFE0, E1            | Timer Input Capture 4/Output Compare 5 | l Bit    | 14051      |
| FFE3, E2            | Timer Output Compare 4                 | l Bit    | OC4I       |
| FFE4, E5            | Timer Output Compare 3                 | l Bit    | OC3I       |
| FFE6, E7            | Timer Output Compare 2                 | l Bit    | OC2I       |
| FFE8, E9            | Timer Output Compare 1                 | l Bit    | OC1I       |
| FFEA, EB            | Timer Input Capture 3                  | l Bit    | IC3        |
| FFEC, ED            | Timer Input Capture 2                  | l Bit    | IC2I       |
| FFEE, EF            | Timer Input Capture 1                  | l Bit    | IC1I       |
| FFF0, F1            | Real-Time Interrupt                    | l Bit    | RTII       |
| FFF2, F3            | Parallel I/O Handshake                 | l Bit    | STAI       |
|                     | ĪRQ                                    |          | None       |
| FFF4, F5            | XIRQ Pin                               | X Bit    | None       |
| FFF6, F7            | Software Interrupt                     | None     | None       |
| FFF8, F9            | Illegal Opcode Trap                    | None     | None       |
| FFFA, FB            | COP Failure                            | None     | NOCOP      |
| FFFC, FD            | COP Clock Monitor Fail                 | None     | CME        |
| FFFE, FF            | RESET                                  | None     | None       |

#### **Table 4 Interrupt and Reset Vector Assignments**

| <b>OPTION</b> | -System | Configuration | Options |
|---------------|---------|---------------|---------|
|---------------|---------|---------------|---------|

#### \$1039

|        | Bit 7 | 6    | 5     | 4    | 3   | 2 | 1    | Bit 0 |
|--------|-------|------|-------|------|-----|---|------|-------|
|        | ADPU  | CSEL | IRQE* | DLY* | CME | 0 | CR1* | CR0*  |
| RESET: | 0     | 0    | 0     | 1    | 0   | 0 | 0    | 0     |

\*Can be written only once in first 64 cycles out of reset in normal modes, or any time in special modes.

#### ADPU —A/D Converter Power-up Refer to **10 Analog-to-Digital Converter**.

### CSEL —Clock Select Refer to **10 Analog-to-Digital Converter**.

IRQE — IRQ Select Edge-Sensitive Only

- 0 = Low logic level recognition
- 1 = Falling edge recognition

DLY — Enable Oscillator Start-Up Delay on Exit from STOP

0 = No stabilization delay on exit from STOP

1 = Stabilization delay enabled on exit from STOP

- CME Clock Monitor Enable
  - 0 = Clock monitor disabled; slow clocks can be used
  - 1 = Slow or stopped clocks cause clock failure reset

CR1, CR0 — COP Timer Rate Select

| CR [1:0] | Divide<br>E/2 <sup>15</sup><br>By | XTAL = 4.0 Mhz<br>Timeout<br>–0/+32.8 ms | XTAL = 8.0 MHz<br>Timeout<br>–0/+16.4 ms | XTAL = 12.0 MHz<br>Timeout<br>–0/+10.9 ms |  |
|----------|-----------------------------------|------------------------------------------|------------------------------------------|-------------------------------------------|--|
| 0 0      | 1                                 | 32.768 ms                                | 16.384 ms                                | 10.923 ms                                 |  |
| 0 1      | 4                                 | 131.072 ms                               | 65.536 ms                                | 43.691 ms                                 |  |
| 1 0      | 16                                | 524.288 ms                               | 262.140 ms                               | 174.76 ms                                 |  |
| 1 1      | 64                                | 2.097 sec                                | 1.049 sec                                | 699.05 ms                                 |  |
|          | E =                               | 1.0 MHz                                  | 2.0 MHz                                  | 3.0 MHz                                   |  |

#### **COPRST** — Arm/Reset COP Timer Circuitry

|        | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
|--------|-------|---|---|---|---|---|---|-------|
|        | 7     | 6 | 5 | 4 | 3 | 2 | 1 | 0     |
| RESET: | 0     | 0 | 0 | 0 | 0 | 0 | 0 | 0     |

Write \$55 to COPRST to arm COP watchdog clearing mechanism. Write \$AA to COPRST to reset COP watchdog.

\$103A

\$103C

#### **HPRIO** — Highest Priority I-Bit Interrupt and Miscellaneous

|        | Bit 7 | 6    | 5   | 4   | 3     | 2     | 1     | Bit 0 |
|--------|-------|------|-----|-----|-------|-------|-------|-------|
|        | RBOOT | SMOD | MDA | IRV | PSEL3 | PSEL2 | PSEL1 | PSEL0 |
| RESET: |       | _    |     |     | 0     | 1     | 0     | 1     |

#### RBOOT — Read Bootstrap ROM Bits 7–4 Refer to **2 Operating Modes and Memory Maps**.

#### SMOD — Special Mode Select

Refer to 2 Operating Modes and Memory Maps.

#### MDA — Mode Select A

Refer to 2 Operating Modes and Memory Maps.

#### IRV — Internal Read Visibility

Refer to 2 Operating Modes and Memory Maps.

PSEL[3:0] — Priority Select Bits 3 through 0

Can be written only while the I bit in the CCR is set (interrupts disabled). These bits select one interrupt source to be elevated above all other I-bit related sources.

| PSEL[3:0] | Interrupt Source Promoted    |
|-----------|------------------------------|
| 0000      | Timer Overflow               |
| 0001      | Pulse Accumulator Overflow   |
| 0010      | Pulse Accumulator Input Edge |
| 0011      | SPI Serial Transfer Complete |
| 0100      | SCI Serial System            |
| 0101      | Reserved (Default to IRQ)    |
| 0110      | IRQ                          |
| 0111      | Real-Time Interrupt          |
| 1000      | Timer Input Capture 1        |
| 1001      | Timer Input Capture 2        |
| 1010      | Timer Input Capture 3        |
| 1011      | Timer Output Compare 1       |
| 1100      | Timer Output Compare 2       |
| 1101      | Timer Output Compare 3       |
| 1110      | Timer Output Compare 4       |
| 1111      | Timer Output Compare 5       |



#### NOTE

The bits of this register are implemented with EEPROM cells. Programming and erasing follow normal EEPROM procedures. The erased state of CONFIG is \$0F. A new value is not readable until after a subsequent reset sequence. CONFIG can only be programmed or erased in special modes.

NOSEC — EEPROM Security Disable

Refer to 4 Electrically Erasable Programmable Read-Only Memory (EEPROM).

NOCOP — COP system disable

0 = COP enabled (forces reset on timeout)

1 = COP disabled (does not force reset on timeout)

ROMON — ROM Enable

Refer to 2 Operating Modes and Memory Maps.

#### EEON — EEPROM Enable

Refer to 2 Operating Modes and Memory Maps.

## 4 Electrically Erasable Programmable Read-Only Memory (EEPROM)

The 512 bytes of EEPROM in the MC68HC11A8 are located at \$B600 through \$B7FF. The EEON bit in CONFIG controls the presence or absence of the EEPROM in the memory map. When EEON = 1 (erased state), the EEPROM is enabled. When EEON = 0, the EEPROM is disabled and out of the memory map. EEON is reset to the value last programmed into CONFIG. An on-chip charge pump develops the high voltage required for programming and erasing. When the E clock is less than 1 MHz, select an internal clock. This drives the EEPROM charge pump by writing a one to the CSEL bit in the OPTION register.

The PPROG register controls the programming and erasing of the EEPROM. To erase the EEPROM, complete the following steps using the PPROG register:

- 1. Write to PPROG with the ERASE, EELAT, and appropriate BYTE and ROW bits set.
- 2. Write to the appropriate EEPROM address with any data. Row erase only requires a write to any location in the row. Bulk erase is accomplished by writing to any location in the array.
- 3. Write to PPROG with ERASE, EELAT, EEPGM, and the appropriate BYTE and ROW bits set.
- 4. Delay for 10 ms or more, as appropriate.
- 5. Clear the EEPGM bit in PPROG to turn off the high voltage.
- 6. Clear the PPROG register to reconfigure the EEPROM address and data buses for normal operation.

To program the EEPROM, complete the following steps using the PPROG register:

- 1. Write to PPROG with the EELAT bit set.
- 2. Write data to the desired address.
- 3. Write to PPROG with the EELAT and EEPGM bits set.
- 4. Delay for 10 ms or more, as appropriate.
- 5. Clear the EEPGM bit in PPROG to turn off the high voltage.
- 6. Clear the PPROG register to reconfigure the EEPROM address and data buses for normal operation.

#### **PPROG** — EEPROM Programming Control

\$103B

|        | Bit 7 | 6    | 5 | 4    | 3   | 2     | 1     | Bit 0 |
|--------|-------|------|---|------|-----|-------|-------|-------|
|        | ODD   | EVEN | 0 | BYTE | ROW | ERASE | EELAT | EEPGM |
| RESET: | 0     | 0    | 0 | 0    | 0   | 0     | 0     | 0     |

- ODD Program Odd Rows in Half of EEPROM (TEST)
- EVEN Program Even Rows in Half of EEPROM (TEST)

#### BYTE — Byte/Other EEPROM Erase Mode

- The BYTE bit overrides the ROW bit.
  - 0 = Row or bulk erase mode is used
  - 1 = Erase only one byte of EEPROM

#### ROW — Row/All EEPROM Erase Mode

- The ROW bit is only valid when BYTE = 0.
  - 0 = All 512 bytes of EEPROM are erased
  - 1 = Erase only one 16-byte row of EEPROM

| BYTE | ROW | Action                     |
|------|-----|----------------------------|
| 0    | 0   | Bulk Erase (All 512 Bytes) |
| 0    | 1   | Row Erase (16 Bytes)       |
| 1    | 0   | Byte Erase                 |
| 1    | 1   | Byte Erase                 |

ERASE — Erase/Normal Control for EEPROM

- 0 = Normal read or program mode
- 1 = Erase mode

#### EELAT — EEPROM Latch Control

0 = EEPROM address and data bus configured for normal reads

1 = EEPROM address and data bus configured for programming or erasing

#### EEPGM — EEPROM Program Command

- 0 = Programming or erase voltage switched off to EEPROM array
- 1 = Programming or erase voltage switched on to EEPROM array

| CONFIG - | — COP, F | ROM, EEF | PROM En | ables |       |       |       | \$103F |
|----------|----------|----------|---------|-------|-------|-------|-------|--------|
|          | Bit 7    | 6        | 5       | 4     | 3     | 2     | 1     | Bit 0  |
|          | 0        | 0        | 0       | 0     | NOSEC | NOCOP | ROMON | EEON   |
| RESET:   | 0        | 0        | 0       | 0     | _     | _     | _     | _      |

#### 0 0 0

#### NOTE

The bits of this register are implemented with EEPROM cells. Programming and erasing follow normal EEPROM procedures. The erased state of CONFIG is \$0F. A new value is not readable until after a subsequent reset sequence. CONFIG can only be programmed or erased in special modes.

Bit 0 EEON

#### NOSEC — EEPROM Security Disable

NOSEC has no meaning unless the security mask option was specified before the MCU was manufactured.

0 = Security enabled (available as a mask option on MC68HC11A8 only)

- 1 = Security disabled
- NOCOP COP system disable

Refer to 3 Resets and Interrupts.

ROMON — ROM Enable

Refer to 2 Operating Modes and Memory Maps.

#### EEON — EEPROM Enable

- 0 = EEPROM is removed from the memory map
- 1 = EEPROM is present in the memory map

## **5** Parallel Input/Output

The MC68HC11A8 has up to 38 input/output lines, depending on the operating mode. Port A has three input-only pins, four output-only pins, and one bidirectional I/O pin. Port A shares functions with the timer system.

Port B is an 8-bit output-only port in single-chip modes and is the high-order address in expanded modes.

Port C is an 8-bit bidirectional port in single-chip modes and the multiplexed address and data bus in expanded modes.

Port D is a 6-bit bidirectional port that shares functions with the serial systems.

Port E is an 8-bit input-only port that shares functions with the A/D system.

Simple and full handshake input and output functions are available on ports B and C lines in single-chip mode. A description of the handshake functions follows.

In port B simple strobed output mode, the STRB output is pulsed for two E-clock periods each time there is a write to the PORTB register. The INVB bit in the PIOC register controls the polarity of STRB pulses.

In port C simple strobed input mode, port C levels are latched into the alternate port C latch (PORTCL) register on each assertion of the STRA input. STRA edge select, flag and interrupt enable bits are located in the PIOC register. Any or all of the port C lines can still be used as general purpose I/O while in strobed input mode.

Port C full handshake mode involves port C pins and the STRA and STRB lines. Input and output handshake modes are supported, and output handshake mode has a three-stated variation. STRA is an edge detecting input, and STRB is a handshake output. Control and enable bits are located in the PIOC register.

In full input handshake mode, the MCU uses STRB as a "ready" line to an external system. Port C logic levels are latched into PORTCL when the STRA line is asserted by the external system. The MCU then negates STRB. The MCU reasserts STRB after the PORTCL register is read. A mix of latched inputs, static inputs, and static outputs is allowed on port C, differentiated by the data direction bits and use of the PORTC and PORTCL registers.

In full output handshake mode, the MCU writes data to PORTCL, which in turn asserts the STRB output to indicate that data is ready. The external system reads port C (the STRB output) and asserts the STRA input to acknowledge that data has been received.

In the three-state variation of output handshake mode, lines intended as three-state handshake outputs are configured as inputs by clearing the corresponding DDRC bits. The MCU writes data to PORTCL and asserts STRB. The external system responds by activating the STRA input, which forces the MCU to drive the data in PORTCL out on all of the port C lines. This mode variation does not allow part of port C to be used for static inputs while other port C pins are being used for handshake outputs. Refer to the PIOC register description.

| PORTA — Port A Data \$        |              |            |            |            |            |          |          |          |  |
|-------------------------------|--------------|------------|------------|------------|------------|----------|----------|----------|--|
|                               | Bit 7        | 6          | 5          | 4          | 3          | 2        | 1        | Bit 0    |  |
|                               | PA7          | PA6        | PA5        | PA4        | PA3        | PA2      | PA1      | PA0      |  |
| RESET:                        | HiZ          | 0          | 0          | 0          | 0          | HiZ      | HiZ      | HiZ      |  |
| Alt. Pin<br>Func.:<br>And/or: | PAI<br>OC1   | OC2<br>OC1 | OC3<br>OC1 | OC4<br>OC1 | OC5<br>OC1 | IC1<br>— | IC2<br>— | IC3<br>— |  |
|                               | Parallel I/C | O Control  |            |            |            |          |          | \$1002   |  |
|                               | Bit 7        | 6          | 5          | 4          | 3          | 2        | 1        | Bit 0    |  |
|                               | STAF         | STAI       | CWOM       | HNDS       | OIN        | PLS      | EGA      | INVB     |  |
| RESET:                        | 0            | 0          | 0          | 0          | 0          | U        | 1        | 1        |  |

#### STAF — Strobe A Interrupt Status Flag

Set when selected edge occurs on Strobe A. Cleared by PIOC read with STAF set followed by PORTCL read (simple strobed or full input handshake mode) or PORTCL write (output handshake mode).

STAI — Strobe A Interrupt Enable Mask

0 = STAF interrupts disabled

1 = STAF interrupts enabled

CWOM — Port C Wire-OR Mode (affects all eight port C pins)

- 0 = Port C outputs are normal CMOS outputs
- 1 = Port C outputs are open-drain outputs

#### HNDS — Handshake Mode

0 =Simple strobe mode

1 = Full input or output handshake mode

OIN — Output or Input Handshake Select

HNDS must be set to one for this bit to have meaning.

- 0 = Input handshake
- 1 = Output handshake

### PLS — Pulse/Interlocked Handshake Operation

HNDS must be set to one for this bit to have meaning.

- 0 = Interlocked handshake
- 1 = Pulsed handshake (strobe B pulses high for two E-clock cycles)
- EGA Active Edge for Strobe A
  - 0 = STRA falling edge selected
  - 1 = STRA rising edge selected

### INVB — Invert Strobe B

- 0 = Active level is logic zero
- 1 = Active level is logic one

### Table 5 Parallel I/O Control

|                           | STAF<br>Clearing<br>Sequence                        | HNDS | OIN | PLS                                                  | EGA                                                     | Port C                                                                                               | Port B                                                               |
|---------------------------|-----------------------------------------------------|------|-----|------------------------------------------------------|---------------------------------------------------------|------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|
| Simple<br>strobed<br>mode | Read PIOC<br>with STAF=1<br>then read<br>PORTCL     | 0    | X   | Х                                                    |                                                         | Inputs latched<br>into PORTCL<br>on any active<br>edge on STRA                                       | STRB<br>pulses on<br>writes to<br>port B                             |
| Full input<br>handshake   | Read PIOC<br>with STAF=1<br>then read<br>PORTCL     | 1    | 0   | 0 = STRB<br>active level<br>1 = STRB<br>active pulse | 1<br>0                                                  | Inputs latched<br>into PORTCL<br>on any active<br>edge on STRA                                       | Normal out-<br>put port,<br>unaffected<br>in hand-<br>shake<br>modes |
| Full output<br>handshake  | Read PIOC<br>with STAF=1<br>then write to<br>PORTCL | 1    | 1   | 0 = STRB<br>active level<br>1 = STRB<br>active pulse | 0<br>Port C<br>Driven<br>STRA<br>Follow<br>DDRC<br>DDRC | Driven as out-<br>puts if STRA at<br>active level,<br>follows DDRC<br>if STRA not at<br>active level | Normal out-<br>put port,<br>unaffected<br>in hand-<br>shake<br>modes |

| PORTC -             | – Port C [      | Data            |                 |                 |                 |                 |                 | \$1003          |
|---------------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|-----------------|
|                     | Bit 7           | 6               | 5               | 4               | 3               | 2               | 1               | Bit 0           |
|                     | PC7             | PC6             | PC5             | PC4             | PC3             | PC2             | PC1             | PC0             |
| S. Chip<br>or Boot: | PC7             | PC6             | PC5             | PC4             | PC3             | PC2             | PC1             | PC0             |
| RESET:              | 0               | 0               | 0               | 0               | 0               | 0               | 0               | 0               |
| Expan. or<br>Test:  | ADDR7/<br>DATA7 | ADDR6/<br>DATA6 | ADDR5/<br>DATA5 | ADDR4/<br>DATA4 | ADDR3/<br>DATA3 | ADDR2/<br>DATA2 | ADDR1/<br>DATA1 | ADDR0/<br>DATA0 |

#### NOTE

In single chip and boot modes, port C pins reset to high impedance inputs (DDRC registers are set to zero). In expanded and special test modes, port C is a multiplexed address/data bus and the port C register address is treated as an external memory location.

| PORTB -             | – Port B [ | Data    |        |        |        |        |       | \$1004 |
|---------------------|------------|---------|--------|--------|--------|--------|-------|--------|
|                     | Bit 7      | 6       | 5      | 4      | 3      | 2      | 1     | Bit 0  |
|                     | PB7        | PB6     | PB5    | PB4    | PB3    | PB2    | PB1   | PB0    |
| S. Chip<br>or Boot: | PB7        | PB6     | PB5    | PB4    | PB3    | PB2    | PB1   | PB0    |
| RESET:              | 0          | 0       | 0      | 0      | 0      | 0      | 0     | 0      |
| Expan.or<br>Test:   | ADDR15     | ADDR14  | ADDR13 | ADDR12 | ADDR11 | ADDR10 | ADDR9 | ADDR8  |
| PORTCL              | — Port C   | Latched |        |        |        |        |       | \$1005 |
|                     | Bit 7      | 6       | 5      | 4      | 3      | 2      | 1     | Bit 0  |
|                     | PCL7       | PCL6    | PCL5   | PCL4   | PCL3   | PCL2   | PCL1  | PCL0   |
| RESET:              | U          | U       | U      | U      | U      | U      | U     | U      |
|                     |            | - ·     |        |        |        |        |       |        |

Writes affect port C pins. PORTCL is used in the handshake clearing mechanism. When an active edge occurs on the STRA pin, port C data is latched into the PORTCL register.

| DDRC —             | — Data Direction Register for Port C \$1007                                        |             |                        |           |      |      |      |        |
|--------------------|------------------------------------------------------------------------------------|-------------|------------------------|-----------|------|------|------|--------|
|                    | Bit 7                                                                              | 6           | 5                      | 4         | 3    | 2    | 1    | Bit 0  |
|                    | DDC7                                                                               | DDC6        | DDC5                   | DDC4      | DDC3 | DDC2 | DDC1 | DDC0   |
| RESET:             | 0                                                                                  | 0           | 0                      | 0         | 0    | 0    | 0    | 0      |
|                    | — Data E<br>= Input<br>= Output                                                    | Direction F | Register fo            | or Port C |      |      |      |        |
| PORTD -            | – Port D [                                                                         | Data        |                        |           |      |      |      | \$1008 |
|                    | Bit 7                                                                              | 6           | 5                      | 4         | 3    | 2    | 1    | Bit 0  |
|                    | 0                                                                                  | 0           | PD5                    | PD4       | PD3  | PD2  | PD1  | PD0    |
| RESET:             | 0                                                                                  | 0           | 0                      | 0         | 0    | 0    | 0    | 0      |
| Alt. Pin<br>Func.: | _                                                                                  | _           | SS                     | SCK       | MOSI | MISO | TxD  | RxD    |
| DDRD —             | Data Dire                                                                          | ection Reg  | gister for F           | Port D    |      |      |      | \$1009 |
|                    | Bit 7                                                                              | 6           | 5                      | 4         | 3    | 2    | 1    | Bit 0  |
|                    | 0                                                                                  | 0           | DDD5                   | DDD4      | DDD3 | DDD2 | DDD1 | DDD0   |
| RESET:             | 0                                                                                  | 0           | 0                      | 0         | 0    | 0    | 0    | 0      |
| Alt. Pin           | —                                                                                  | —           | PD5/                   | PD4/      | PD3/ | PD2/ | PD1/ | PD0/   |
| Func.:             |                                                                                    |             | SS                     | SCK       | MOSI | MISO | TxD  | RxD    |
|                    | — Data E<br>= Input<br>= Output                                                    | Direction f | or Port D              |           |      |      |      |        |
| PORTE -            | – Port E D                                                                         | Data        |                        |           |      |      |      | \$100A |
|                    | Bit 7                                                                              | 6           | 5                      | 4         | 3    | 2    | 1    | Bit 0  |
|                    | PE7                                                                                | PE6         | PE5                    | PE4       | PE3  | PE2  | PE1  | PE0    |
| RESET:             | U                                                                                  | U           | U                      | U         | U    | U    | U    | U      |
| Alt. Pin<br>Func.: | AN7                                                                                | AN6         | AN5                    | AN4       | AN3  | AN2  | AN1  | AN0    |
| PACTL -            | - Pulse A                                                                          | ccumulato   | or Control             |           |      |      |      | \$1026 |
|                    | Bit 7                                                                              | 6           | 5                      | 4         | 3    | 2    | 1    | Bit 0  |
|                    | DDRA7                                                                              | PAEN        | PAMOD                  | PEDGE     | 0    | 0    | RTR1 | RTR0   |
| RESET:             | 0                                                                                  | 0           | 0                      | 0         | 0    | 0    | 0    | 0      |
|                    | - Data Dir<br>= Input<br>= Output                                                  | rection for | <sup>.</sup> Port A Bi | t 7       |      |      |      |        |
|                    | <ul> <li>Pulse Accumulator System Enable<br/>er to 9 Pulse Accumulator.</li> </ul> |             |                        |           |      |      |      |        |
|                    | OD — Pulse Accumulator Mode<br>Refer to <b>9 Pulse Accumulator</b> .               |             |                        |           |      |      |      |        |
|                    | DGE — Pulse Accumulator Edge Control<br>Refer to <b>9 Pulse Accumulator</b> .      |             |                        |           |      |      |      |        |
| RTR1, RT<br>Refer  | FR0 — Re<br>to <b>8 Mair</b>                                                       |             | nterrupt R             | ate       |      |      |      |        |

## 6 Serial Communications Interface (SCI)

The SCI, a universal asynchronous receiver transmitter (UART) serial communications interface, is one of two independent serial I/O subsystems in the MC68HC11A8. It has a standard NRZ format (one start, eight or nine data, and one stop bit) and several baud rates available. The SCI transmitter and receiver are independent, but use the same data format and bit rate.



11 SCI TX BLOCK







|        | Bit 7 | 6 | 5    | 4    | 3    | 2    | 1    | Bit 0 |
|--------|-------|---|------|------|------|------|------|-------|
|        | TCLR  | 0 | SCP1 | SCP0 | RCKB | SCR2 | SCR1 | SCR0  |
| RESET: | 0     | 0 | 0    | 0    | 0    | U    | U    | U     |

TCLR — Clear Baud Rate Counters (TEST)

SCP1, SCP0 — SCI Baud Rate Prescaler Selects

|          | Divide                  | Crystal Frequency in MHz |                   |                    |                    |  |  |  |
|----------|-------------------------|--------------------------|-------------------|--------------------|--------------------|--|--|--|
| SCP[1:0] | Internal<br>Clock<br>By | 4.0 MHz<br>(Baud)        | 8.0 MHz<br>(Baud) | 10.0 MHz<br>(Baud) | 12.0 MHz<br>(Baud) |  |  |  |
| 00       | 1                       | 62.50K                   | 125.0K            | 156.25K            | 187.5K             |  |  |  |
| 01       | 3                       | 20.83K                   | 41.67K            | 52.08K             | 62.5K              |  |  |  |
| 10       | 4                       | 15.625K                  | 31.25K            | 38.4K              | 46.88K             |  |  |  |
| 11       | 13                      | 4800                     | 9600              | 12.02K             | 14.42K             |  |  |  |

RCKB — SCI Baud Rate Clock Check (TEST)

SCR2, SCR1, and SCR0 — SCI Baud Rate Selects

Selects receiver and transmitter bit rate based on output from baud rate prescaler stage.

| SCP[2:0] | Divide<br>Prescaler | Highest Baud Rate<br>(Prescaler Output from Previous Table) |      |       |  |  |  |  |
|----------|---------------------|-------------------------------------------------------------|------|-------|--|--|--|--|
|          | Ву                  | 4800                                                        | 9600 | 38.4K |  |  |  |  |
| 000      | 1                   | 4800                                                        | 9600 | 38.4K |  |  |  |  |
| 001      | 2                   | 2400                                                        | 4800 | 19.2K |  |  |  |  |
| 010      | 4                   | 1200                                                        | 2400 | 9600  |  |  |  |  |
| 011      | 8                   | 600                                                         | 1200 | 4800  |  |  |  |  |
| 100      | 16                  | 300                                                         | 600  | 2400  |  |  |  |  |
| 101      | 32                  | 150                                                         | 300  | 1200  |  |  |  |  |
| 110      | 64                  | —                                                           | 150  | 600   |  |  |  |  |
| 111      | 128                 | _                                                           |      | 300   |  |  |  |  |



SCI BAUD GENERATOR

#### Figure 8 SCI Baud Rate Diagram

| SCCR1 - | SCCR1 — SCI Control Register 1 |    |   |   |      |   |   |       |  |
|---------|--------------------------------|----|---|---|------|---|---|-------|--|
|         | Bit 7                          | 6  | 5 | 4 | 3    | 2 | 1 | Bit 0 |  |
|         | R8                             | T8 | 0 | М | WAKE | 0 | 0 | 0     |  |
| RESET:  | U                              | U  | 0 | 0 | 0    | 0 | 0 | 0     |  |

R8 — Receive Data Bit 8

If M bit is set, R8 stores ninth bit in receive data character.

#### T8 — Transmit Data Bit 8

If M bit is set, T8 stores ninth bit in transmit data character.

#### M — Mode (Select Character Format)

- 0 = Start bit, 8 data bits, 1 stop bit
- 1 = Start bit, 9 data bits, 1 stop bit

WAKE — Wake Up by Address Mark/Idle

- 0 = Wake up by IDLE line recognition
- 1 = Wake up by address mark (most significant data bit set)

| SCCR2 –  | - SCI Coi  |                                         |                  | \$102D                          |             |             |            |           |
|----------|------------|-----------------------------------------|------------------|---------------------------------|-------------|-------------|------------|-----------|
|          | Bit 7      | 6                                       | 5                | 4                               | 3           | 2           | 1          | Bit 0     |
|          | TIE        | TCIE                                    | RIE              | ILIE                            | TE          | RE          | RWU        | SBK       |
| RESET:   | 0          | 0                                       | 0                | 0                               | 0           | 0           | 0          | 0         |
| 0        | = TDRE     | terrupt Ena<br>interrupts<br>errupt req | disabled         | nen TDRE                        | status fla  | ıg is set   |            |           |
| 0        | = TC inte  | Complete<br>errupts dis<br>errupt req   | abled            | Enable<br>TC is set t           | o one       |             |            |           |
| 0        | = RDRF     | terrupt En<br>and OR ir<br>errupt req   | terrupts c       | lisabled<br>hen RDRF            | flag or th  | e OR stat   | us flag is | set       |
| 0        | = IDLE ir  | terrupt En<br>nterrupts d<br>errupt req | isabled          | nen IDLE s                      | status flag | is set      |            |           |
|          | = Transn   | Enable<br>nitter disat<br>nitter enab   |                  |                                 |             |             |            |           |
|          | = Receiv   | able<br>er disable<br>er enable         |                  |                                 |             |             |            |           |
| 0        | = Norma    | Wake Up<br>I SCI rece<br>up enablee     | iver             | eiver interr                    | upts inhit  | bited       |            |           |
|          | = Break    | generator                               |                  | long as S                       | BK is set   | to one      |            |           |
| SCSR —   | SCI Statu  | us Registe                              | r                |                                 |             |             |            | \$102E    |
|          | Bit 7      | 6                                       | 5                | 4                               | 3           | 2           | 1          | Bit 0     |
|          | TDRE       | TC                                      | RDRF             | IDLE                            | OR          | NF          | FE         | 0         |
| RESET:   | 1          | 1                                       | 0                | 0                               | 0           | 0           | 0          | 0         |
| Set if   | transmit o |                                         | e written        | ty Flag<br>to SCDR;<br>d by SCD |             | s zero, tra | insmit dat | a registe |
| TC — Tra | insmit Co  | mplete Fla                              | ag<br>Na data in | wa a wakila 🗸                   |             | onomiosis   | n in nroa  |           |

Set if transmitter is idle (no data, preamble, or break transmission in progress). Cleared by SCSR read with TC set followed by SCDR write.

RDRF — Receive Data Register Full Flag

Set if a received character is ready to be read from SCDR. Cleared by SCSR read with RDRF set followed by SCDR read.

#### IDLE — Idle Line Detected Flag

Set if the RxD line is idle. IDLE flag is inhibited when RWU is set to one. Cleared by SCSR read with IDLE set followed by SCDR read. Once cleared, IDLE is not set again until the RxD line has been active and becomes idle again.

#### OR — Overrun Error Flag

Set if a new character is received before a previously received character is read from SCDR. Cleared by SCSR read with OR set followed by SCDR read.

#### NF - Noise Error Flag

Set if majority sample logic detects anything other than a unanimous decision. Cleared by SCSR read with NF set followed by SCDR read.

#### FE — Framing Error

Set if a zero is detected where a stop bit was expected. Cleared by SCSR read with FE set followed by SCDR read.

\$102F

#### SCDR — SCI Data Register

|        | Bit 7 | 6     | 5     | 4     | 3     | 2     | 1     | Bit 0 |
|--------|-------|-------|-------|-------|-------|-------|-------|-------|
|        | R7/T7 | R6/T6 | R5/T5 | R4/T4 | R3/T3 | R2/T2 | R1/T1 | R0/T0 |
| RESET: | U     | U     | U     | U     | U     | U     | U     | U     |

#### NOTE

Receive and transmit are double buffered. Reads access the receive data buffer and writes access the transmit data buffer.

## 7 Serial Peripheral Interface (SPI)

The SPI is one of two independent serial communications subsystems that allow the MCU to communicate synchronously with peripheral devices and other microprocessors. Data rates can be as high as one half of the E-clock rate when configured as master, and as fast as the E clock when configured as slave.





| DDRD —             | DRD — Data Direction Register for Port D |   |            |             |              |              |             |             |  |
|--------------------|------------------------------------------|---|------------|-------------|--------------|--------------|-------------|-------------|--|
|                    | Bit 7                                    | 6 | 5          | 4           | 3            | 2            | 1           | Bit 0       |  |
|                    | 0                                        | 0 | DDD5       | DDD4        | DDD3         | DDD2         | DDD1        | DDD0        |  |
| RESET:             | 0                                        | 0 | 0          | 0           | 0            | 0            | 0           | 0           |  |
| Alt. Pin<br>Func.: |                                          |   | PD5/<br>SS | PD4/<br>SCK | PD3/<br>MOSI | PD2/<br>MISO | PD1/<br>TxD | PD0/<br>RxD |  |

#### DDD[5:0] - Data Direction for Port D

When DDRD bit 5 is zero and MSTR = 1 in SPCR, PD5/SS is a general-purpose output and mode fault logic is disabled.

0 = Input

1 = Output



SPI TRANSFER FORMAT

#### Figure 10 SPI Transfer Format

#### SPR1 and SPR0 — SPI Clock Rate Selects

| SPR [1:0] | E-Clock<br>Divide By | Frequency at<br>E = 2 MHz (Baud) |
|-----------|----------------------|----------------------------------|
| 00        | 2                    | 1.0 MHz                          |
| 01        | 4                    | 500 kHz                          |
| 10        | 16                   | 125 kHz                          |
| 11        | 32                   | 62.5 kHz                         |

#### SPSR — Serial Peripheral Status Register

\$1029

|        | Bit 7 | 6    | 5 | 4    | 3 | 2 | 1 | Bit 0 |
|--------|-------|------|---|------|---|---|---|-------|
|        | SPIF  | WCOL | 0 | MODF | 0 | 0 | 0 | 0     |
| RESET: | 0     | 0    | 0 | 0    | 0 | 0 | 0 | 0     |

#### SPIF — SPI Transfer Complete Flag

Set when an SPI transfer is complete. Cleared by reading SPSR with SPIF set followed by SPDR access.

#### WCOL — Write Collision

Set when SPDR is written while transfer is in progress. Cleared by SPSR with WCOL set followed by SPDR access.

#### MODF — Mode Fault (A Mode Fault Terminates SPI Operation)

Set when  $\overline{SS}$  is pulled low while MSTR = 1. Cleared by SPSR read with MODF set followed by SPCR write.

| SPDR — SPI Data Register\$102/\$102/ |       |   |   |   |   |   |   |       |
|--------------------------------------|-------|---|---|---|---|---|---|-------|
|                                      | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| [                                    | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |

#### NOTE

SPI is double buffered in, single buffered out.

## 8 Main Timer

The main timer is based on a free-running 16-bit counter with a four-stage programmable prescaler. A timer overflow function allows software to extend the system's timing capability beyond the counter's 16-bit range.

The timer has three channels of input capture and five channels of output compare.

Refer to the following table for a summary of crystal-related frequencies and periods.

|                                | XTAL Frequencies                                |                                                |                                                |                                                                                              |  |  |  |  |  |
|--------------------------------|-------------------------------------------------|------------------------------------------------|------------------------------------------------|----------------------------------------------------------------------------------------------|--|--|--|--|--|
| Control                        | 4.0 MHz                                         | 8.0 MHz                                        | 12.0 MHz                                       | Other Rates                                                                                  |  |  |  |  |  |
| Bits                           | 1.0 MHz                                         | 2.0 MHz                                        | 3.0 MHz                                        | (E)                                                                                          |  |  |  |  |  |
|                                | 1000 ns                                         | 500 ns                                         | 333 ns                                         | (1/E)                                                                                        |  |  |  |  |  |
| PR[1:0]                        |                                                 | Main Timer                                     | Count Rates                                    |                                                                                              |  |  |  |  |  |
| 0 0<br>1 count —<br>overflow — | 1.0 μs<br>65.536 ms                             | 500 ns<br>32.768 ms                            | 333 ns<br>21.845 ms                            | (E/1)<br>(E/2 <sup>16</sup> )                                                                |  |  |  |  |  |
| 0 1<br>1 count —<br>overflow — | 4.0 μs<br>262.14 ms                             | 2.0 μs<br>131.07 ms                            | 1.333 μs<br>87.381 ms                          | (E/4)<br>(E/2 <sup>18</sup> )                                                                |  |  |  |  |  |
| 1 0<br>1 count —<br>overflow — | 8.0 μs<br>524.29 ms                             | 4.0 μs<br>262.14 ms                            | 2.667 μs<br>174.76 ms                          | (E/8)<br>(E/2 <sup>19</sup> )                                                                |  |  |  |  |  |
| 1 1<br>1 count —<br>overflow — | 16.0 μs<br>1.049 s                              | 8.0 μs<br>524.29 ms                            | 5.333 μs<br>349.52 ms                          | (E/16)<br>(E/2 <sup>20</sup> )                                                               |  |  |  |  |  |
| RTR[1:0]                       |                                                 | Periodic (RTI)                                 | Interrupt Rates                                |                                                                                              |  |  |  |  |  |
| 0 0<br>0 1<br>1 0<br>1 1       | 8.192 ms<br>16.384 ms<br>32.768 ms<br>65.536 ms | 4.096 ms<br>8.192 ms<br>16.384 ms<br>32.768 ms | 2.731 ms<br>5.461 ms<br>10.923 ms<br>21.845 ms | (E/2 <sup>13</sup> )<br>(E/2 <sup>14</sup> )<br>(E/2 <sup>15</sup> )<br>(E/2 <sup>16</sup> ) |  |  |  |  |  |

### Table 6 Timer Summary





NOTE: Port A pin actions are controlled by OC1M, OC1D, PACTL, TCTL1, and TCTL2 registers.

| CFORC -         | — Timer C                          | compare F          | orce        |             |            |         |          | \$100     | В         |                  |
|-----------------|------------------------------------|--------------------|-------------|-------------|------------|---------|----------|-----------|-----------|------------------|
|                 | Bit 7                              | 6                  | 5           | 4           | 3          | 2       | 1        | Bit       | 0         |                  |
|                 | FOC1                               | FOC2               | FOC3        | FOC4        | FOC5       | 0       | C        | ) 0       |           |                  |
| RESET:          | 0                                  | 0                  | 0           | 0           | 0          | 0       | C        | 0 0       |           |                  |
|                 |                                    | rite ones to       | o Force Co  | ompare(s    | )          |         |          |           |           |                  |
|                 | = Not affe                         | ected<br>compare > | action or   | curs but    | OCxF fla   | a hit r | not set  |           |           |                  |
|                 |                                    |                    |             | ouro, our   |            | goitt   | 101 001  | • • • • • | _         |                  |
| OC1M —          | Output C                           | ompare 1           |             | \$100       | C          |         |          |           |           |                  |
|                 | Bit 7                              | 6                  | 5           | 4           | 3          | 2       | 1        | Bit       | 0         |                  |
|                 | OC1M7                              | OC1M6              | OC1M5       | OC1M4       | OC1M3      | 0       | C        |           |           |                  |
| RESET:          | 0                                  | 0                  | 0           | 0           | 0          | 0       | C        | 0 0       |           |                  |
| Set b           | it(s) to ena                       | able OC1 t         | o control o | correspor   | nding pin( | s) of p | ort A.   |           |           |                  |
| OC1D —          | OC1D — Output Compare 1 Data \$100 |                    |             |             |            |         |          |           |           |                  |
|                 | Bit 7                              | 6                  | 5           | 4           | 3          | 2       | 1        | Bit       | 0         |                  |
|                 | OC1D7                              | OC1D6              | OC1D5       | OC1D4       | OC1D3      | 0       | C        | ) 0       |           |                  |
| RESET:          | 0                                  | 0                  | 0           | 0           | 0          | 0       | C        | ) 0       |           |                  |
| If OC           | 1Mx is set                         | t, data in C       | OC1Dx is c  | output to p | oort A bit | x on s  | uccessfu | I OC1 com | pares.    |                  |
| TCNT —          | Timer Co                           | unter              |             |             |            |         |          | \$100     | E, \$100F |                  |
| \$ <b>1</b> 00E | Bit 15                             | 14                 | 13          | 12          | 11         | 10      | g        | ) Bit a   | 8 High    | TCNT             |
|                 | Bit 7                              | 6                  | 5           | 4           | 3          | 2       | 1        | Bit       | 0 Low     |                  |
| TCN             | resets to                          | \$0000. In         | normal m    | odes, TC    | NT is rea  | d-only  | /.       |           |           |                  |
| TIC1-TIC        | 3 — Timei                          | r Input Car        | oture       |             |            |         |          | \$1010    | -\$1015   |                  |
| г               |                                    |                    | 1           |             |            |         |          | -         | -         |                  |
| \$ <b>1</b> 010 | Bit 15                             | 14                 | 13          | 12          | 11         |         | 10       | 9         | Bit 8     | High <b>TIC1</b> |
| \$ <b>1</b> 011 | Bit 7                              | 6                  | 5           | 4           | 3          |         | 2        | 1         | Bit 0     | Low              |
| \$ <b>1</b> 012 | Bit 15                             | 14                 | 13          | 12          | 11         |         | 10       | 9         | Bit 8     | High TIC2        |
| \$ <b>1</b> 013 | Bit 7                              | 6                  | 5           | 4           | 3          |         | 2        | 1         | Bit 0     | Low              |
| \$ <b>1</b> 014 | Bit 15                             | 14                 | 13          | 12          | 11         |         | 10       | 9         | Bit 8     | High TIC3        |
| \$ <b>1</b> 015 | Bit 7                              | 6                  | 5           | 4           | 3          |         | 2        | 1         | Bit 0     | Low              |

TICx not affected by reset.

## **TOC1–TOC5** — Timer Output Compare

#### \$1016-\$101F

| \$ <b>1</b> 016 | Bit 15 | 14 | 13 | 12 | 11 | 10 | 9 | Bit 8 | High <b>TOC1</b> |
|-----------------|--------|----|----|----|----|----|---|-------|------------------|
| \$ <b>1</b> 017 | Bit 7  | 6  | 5  | 4  | 3  | 2  | 1 | Bit 0 | Low              |
| \$ <b>1</b> 018 | Bit 15 | 14 | 13 | 12 | 11 | 10 | 9 | Bit 8 | High <b>TOC2</b> |
| \$ <b>1</b> 019 | Bit 7  | 6  | 5  | 4  | 3  | 2  | 1 | Bit 0 | Low              |
| \$ <b>1</b> 01A | Bit 15 | 14 | 13 | 12 | 11 | 10 | 9 | Bit 8 | High <b>TOC3</b> |
| \$ <b>1</b> 01B | Bit 7  | 6  | 5  | 4  | 3  | 2  | 1 | Bit 0 | Low              |
| \$ <b>1</b> 01C | Bit 15 | 14 | 13 | 12 | 11 | 10 | 9 | Bit 8 | High <b>TOC4</b> |
| \$ <b>1</b> 01D | Bit 7  | 6  | 5  | 4  | 3  | 2  | 1 | Bit 0 | Low              |
| \$ <b>1</b> 01E | Bit 15 | 14 | 13 | 12 | 11 | 10 | 9 | Bit 8 | High <b>TOC5</b> |
| \$ <b>1</b> 01F | Bit 7  | 6  | 5  | 4  | 3  | 2  | 1 | Bit 0 | Low              |
|                 |        |    | -  |    |    | -  | - | -     |                  |

All TOCx register pairs reset to ones (\$FFFF).

| TCTL1 — Timer Control 1 |       |     |     |     |     |     |     | \$1020 |
|-------------------------|-------|-----|-----|-----|-----|-----|-----|--------|
|                         | Bit 7 | 6   | 5   | 4   | 3   | 2   | 1   | Bit 0  |
|                         | OM2   | OL2 | OM3 | OL3 | OM4 | OL4 | OM5 | OL5    |
| RESET:                  | 0     | 0   | 0   | 0   | 0   | 0   | 0   | 0      |

OM2-OM5 - Output Mode

OL2-OL5 - Output Level

| ОМх | OLx | Action Taken on Successful Compare       |
|-----|-----|------------------------------------------|
| 0   | 0   | Timer disconnected from output pin logic |
| 0   | 1   | Toggle OCx output line                   |
| 1   | 0   | Clear OCx output line to 0               |
| 1   | 1   | Set OCx output line to 1                 |



#### **Table 7 Timer Control Configuration**

| EDGxB | EDGxA | Configuration                 |
|-------|-------|-------------------------------|
| 0     | 0     | Capture disabled              |
| 0     | 1     | Capture on rising edges only  |
| 1     | 0     | Capture on falling edges only |
| 1     | 1     | Capture on any edge           |

| TMSK1 -                               | – Timer Ir | nterrupt Ma                              | ask 1     |            |              |              |             | \$1022     |                     |
|---------------------------------------|------------|------------------------------------------|-----------|------------|--------------|--------------|-------------|------------|---------------------|
|                                       | Bit 7      | 6                                        | 5         | 4          | 3            | 2            | 1           | Bit 0      |                     |
|                                       | OC1I       | OC2I                                     | OC3I      | OC4I       | OC5I         | IC1I         | IC2I        | IC3I       |                     |
| RESET:                                | 0          | 0                                        | 0         | 0          | 0            | 0            | 0           | 0          |                     |
|                                       |            | put Comp<br>Ible bit is s                |           |            |              | set, a haro  | dware inte  | errupt seq | uence is requested. |
|                                       |            | Capture x<br>ble bit is se               |           |            | ıg bit is se | t, a hardw   | vare interr | upt seque  | ence is requested.  |
|                                       |            |                                          |           |            | NOTE         |              |             |            |                     |
|                                       |            | s in TMSK<br>correspo                    |           |            |              | ag bits in T | FLG1. O     | nes in TM  | SK1 enable          |
| <b>TFLG1</b> — Timer Interrupt Flag 1 |            |                                          |           |            |              |              |             | \$1023     |                     |
|                                       | Bit 7      | 6                                        | 5         | 4          | 3            | 2            | 1           | Bit 0      | _                   |
|                                       | OC1F       | OC2F                                     | OC3F      | OC4F       | OC5F         | IC1F         | IC2F        | IC3F       |                     |
| RESET:                                | 0          | 0                                        | 0         | 0          | 0            | 0            | 0           | 0          |                     |
| Clear                                 | flags by   | writing a o                              | ne to the | correspon  | nding bit po | osition(s).  |             |            |                     |
|                                       |            | utput Com<br>the counte                  | •         | -          | ompare x     | value.       |             |            |                     |
|                                       | •          | t Capture<br>a selected                  | -         | ge is dete | ected on th  | e ICx inp    | ut line.    |            |                     |
| TMSK2 -                               | – Timer Ir | nterrupt Ma                              | ask 2     |            |              |              |             | \$1024     |                     |
|                                       | Bit 7      | 6                                        | 5         | 4          | 3            | 2            | 1           | Bit 0      |                     |
|                                       | ΤΟΙ        | RTII                                     | PAOVI     | PAII       | 0            | 0            | PR1         | PR0        |                     |
| RESET:                                | 0          | 0                                        | 0         | 0          | 0            | 0            | 0           | 0          | 1                   |
| 0                                     | = TOF in   | flow Interr<br>terrupts di<br>ot request | sabled    |            | to one       |              |             |            |                     |
| 0                                     | = RTIF ir  | Interrupt E<br>nterrupts d<br>ot request | isabled   | RTIF is se | t to one     |              |             |            |                     |
|                                       |            | ccumulato<br>se Accum                    |           | Interrupt  | Enable       |              |             |            |                     |
|                                       |            | imulator Ir<br>se Accum                  |           | Interrupt  | Enable       |              |             |            |                     |
|                                       |            |                                          |           |            | NOTE         |              |             |            |                     |
|                                       |            | s in TMSK<br>e correspo                  |           |            |              | ag bits in T | FLG2. O     | nes in TM  | SK2 enable          |

PR1 and PR0 — Timer Prescaler Select

In normal modes, PR1 and PR0 can only be written once, and the write must be within 64 cycles after reset. Refer to **Table 6** for specific timing values.

| PR[1:0] | Prescaler |
|---------|-----------|
| 0 0     | 1         |
| 0 1     | 4         |
| 1 0     | 8         |
| 1 1     | 16        |

\$1025

TFLG2 — Timer Interrupt Flag 2

|        | Bit 7 | 6    | 5     | 4    | 3 | 2 | 1 | Bit 0 |
|--------|-------|------|-------|------|---|---|---|-------|
|        | TOF   | RTIF | PAOVF | PAIF | 0 | 0 | 0 | 0     |
| RESET: | 0     | 0    | 0     | 0    | 0 | 0 | 0 | 0     |

Clear flags by writing a one to the corresponding bit position(s).

TOF — Timer Overflow Flag

Set when TCNT changes from \$FFFF to \$0000.

- RTIF Real-Time (Periodic) Interrupt Flag Set periodically. Refer to RTR[1:0] bits in PACTL register.
- PAOVF Pulse Accumulator Overflow Interrupt Flag Refer to **9 Pulse Accumulator**.
- PAIF Pulse Accumulator Input Edge Interrupt Flag Refer to **9 Pulse Accumulator**.

| PACTL - | - Pulse Ad |      |       | \$1026 |   |   |      |       |  |
|---------|------------|------|-------|--------|---|---|------|-------|--|
|         | Bit 7      | 6    | 5     | 4      | 3 | 2 | 1    | Bit 0 |  |
|         | DDRA7      | PAEN | PAMOD | PEDGE  | 0 | 0 | RTR1 | RTR0  |  |
| RESET:  | 0          | 0    | 0     | 0      | 0 | 0 | 0    | 0     |  |

- DDRA7 Data Direction for Port A Bit 7 Refer to **5 Parallel Input/Output**.
- PAEN Pulse Accumulator Enable Refer to **9 Pulse Accumulator**.
- PAMOD Pulse Accumulator Mode Select Refer to **9 Pulse Accumulator**.
- PEDGE Pulse Accumulator Edge Select Refer to **9 Pulse Accumulator**.
- RTR [1:0] Real-Time Interrupt (RTI) Rate

#### **Table 8 Real-Time Interrupt Rates**

| RTR[1:0] | Divide E By     | XTAL = 4.0 MHz | XTAL = 8.0 MHz | XTAL = 12.0 MHz |
|----------|-----------------|----------------|----------------|-----------------|
| 0 0      | 2 <sup>13</sup> | 8.19 ms        | 4.096 ms       | 2.731 ms        |
| 0 1      | 2 <sup>14</sup> | 16.38 ms       | 8.192 ms       | 5.461 ms        |
| 10       | 2 <sup>15</sup> | 32.77 ms       | 16.384 ms      | 10.923 ms       |
| 1 1      | 2 <sup>16</sup> | 65.54 ms       | 32.768 ms      | 21.845 ms       |
|          | E =             | 1.0 MHz        | 2.0 MHz        | 3.0 MHz         |

## 9 Pulse Accumulator

The MC68HC11A8 has an 8-bit counter that can be configured to operate as a simple event counter or for gated time accumulation, depending on the PAMOD bit in the PACTL register. The pulse accumulator counter can be read or written at any time.

The port A bit 7 I/O pin can be configured as a clock in event counting mode, or as a gate signal to enable a free-running clock (E divided by 64) in gated time accumulation mode.

|                                             |                         | Common XTAL Frequencies |                     |                      |  |  |  |  |
|---------------------------------------------|-------------------------|-------------------------|---------------------|----------------------|--|--|--|--|
|                                             | Selected Crystal        | 4.0 MHz                 | 8.0 MHz             | 12.0 MHz             |  |  |  |  |
| CPU Clock                                   | (E)                     | 1.0 MHz                 | 2.0 MHz             | 3.0 MHz              |  |  |  |  |
| Cycle Time                                  | (1/E)                   | 1000 ns                 | 500 ns              | 333 ns               |  |  |  |  |
| Pulse Accumulator (in (                     | Gated Mode)             |                         |                     |                      |  |  |  |  |
| (E/2 <sup>6</sup> )<br>(E/2 <sup>14</sup> ) | 1 count —<br>overflow — | 64.0 μs<br>16.384 ms    | 32.0 μs<br>8.192 ms | 21.33 μs<br>5.461 ms |  |  |  |  |

#### **Table 9 Pulse Accumulator Timing**



Figure 12 Pulse Accumulator System Block Diagram

#### TMSK2 — Timer Interrupt Mask 2

```
$1024
```

|        | Bit 7 | 6    | 5     | 4    | 3 | 2 | 1   | Bit 0 |
|--------|-------|------|-------|------|---|---|-----|-------|
|        | TOI   | RTII | PAOVI | PAII | 0 | 0 | PR1 | PR0   |
| RESET: | 0     | 0    | 0     | 0    | 0 | 0 | 0   | 0     |

- TOI Timer Overflow Interrupt Enable Refer to 8 Main Timer.
- RTII Real-Time Interrupt Enable Refer to 8 Main Timer.
- PAOVI Pulse Accumulator Overflow Interrupt Enable 0 = PAOVF interrupts disabled 1 = Interrupt requested when RTIF is set to one
- PAII Pulse Accumulator Input Edge Interrupt Enable 0 = PAIF interrupts disabled
  - 1 = Interrupt requested when PAIF is set to one
- PR1. PR0 Timer Prescaler Select Refer to 8 Main Timer.

#### NOTE

Bits in TMSK2 correspond bit for bit with flag bits in TFLG2. Ones in TMSK2 enable the corresponding interrupt sources.

| TFLG2 — Timer Interrupt Flag 2 |       |      |       |      |   |   |   |       |   |  |
|--------------------------------|-------|------|-------|------|---|---|---|-------|---|--|
|                                | Bit 7 | 6    | 5     | 4    | 3 | 2 | 1 | Bit 0 |   |  |
|                                | TOF   | RTIF | PAOVF | PAIF | 0 | 0 | 0 | 0     | ] |  |
| RESET:                         | 0     | 0    | 0     | 0    | 0 | 0 | 0 | 0     | - |  |

Clear flags by writing a one to the corresponding bit position(s).

TOF — Timer Overflow Flag Refer to 8 Main Timer.

- RTIF Real-Time Interrupt Flag Refer to 8 Main Timer.
- PAOVF Pulse Accumulator Overflow Flag Set when PACNT changes from \$FF to \$00.

PAIF — Pulse Accumulator Input Edge Flag Set each time a selected active edge is detected on the PAI input line.

**PACTL** — Pulse Accumulator Control \$1026 Bit 7 6 5 4 3 2 1 Bit 0 DDRA7 PAEN PAMOD PEDGE 0 RTR1 0 RTR0 RESET: 0 0 0 0 0 0 0 0

DDRA7 — Data Direction for Port A Bit 7 Refer to 5 Parallel Input/Output.

### PAEN — Pulse Accumulator System Enable

- 0 = Pulse Accumulator disabled
- 1 = Pulse Accumulator enabled
- PAMOD Pulse Accumulator Mode
  - 0 = Event counter
  - 1 = Gated time accumulation

#### PEDGE — Pulse Accumulator Edge Control

| PAMOD | PEDGE | Action on Clock                         |
|-------|-------|-----------------------------------------|
| 0     | 0     | PAI falling edge increments the counter |
| 0     | 1     | PAI rising edge increments the counter  |
| 1     | 0     | A zero on PAI inhibits counting         |
| 1     | 1     | A one on PAI inhibits counting          |

RTR1 and RTR0 — Real-Time Interrupt (RTI) Rate Refer to 8 Main Timer.

PACNT — Pulse Accumulator Counter





Can be read and written.

## **10 Analog-to-Digital Converter**

The A/D converter system uses an all capacitive charge redistribution technique to convert analog signals to digital values. The MC68HC11A8 A/D system is an 8-channel, 8-bit, multiplexed-input, successive-approximation converter and is accurate to  $\pm 1$  least significant bit (LSB). It does not require external sample and hold circuits because of the type of charge redistribution technique used.

Dedicated lines  $V_{RH}$  and  $V_{RL}$  provide the reference supply voltage inputs. Refer to the A/D converter block diagram.

A multiplexer allows the single A/D converter to select one of 16 analog signals, as shown in the ADCTL register description.



EA9 A/D BLOCK

Figure 13 A/D Converter Block Diagram



A/D CONVERSION TIM

Figure 14 A/D Conversion Sequence



\* THIS ANALOG SWITCH IS CLOSED ONLY DURING THE 12-CYCLE SAMPLE TIME.

ANALOG INPUT PIN

#### Figure 15 Electrical Model of an Analog Input Pin (Sample Mode)

| ADCTL — A/D Control/Status \$10 |       |   |      |      |    |    |    |       |  |  |
|---------------------------------|-------|---|------|------|----|----|----|-------|--|--|
|                                 | Bit 7 | 6 | 5    | 4    | 3  | 2  | 1  | Bit 0 |  |  |
|                                 | CCF   | 0 | SCAN | MULT | CD | CC | СВ | CA    |  |  |
| RESET:                          | U     | 0 | U    | U    | U  | U  | U  | U     |  |  |

CCF — Conversions Complete Flag

Set after an A/D conversion cycle. Cleared when ADCTL is written.

SCAN — Continuous Scan Control

0 = Do four conversions and stop

1 = Convert four channels in selected group continuously

#### MULT — Multiple Channel/Single Channel Control

- 0 = Convert single channel selected
- 1 = Convert four channels in selected group

#### CD-CA — Channel Select D through A

| С  | hannel Select | Control Bits | Channel | Result in ADRx if      |           |
|----|---------------|--------------|---------|------------------------|-----------|
| CD | CC            | СВ           | CA      | Signal                 | MULT = 1  |
| 0  | 0             | 0            | 0       | AN0                    | ADR1      |
| 0  | 0             | 0            | 1       | AN1                    | ADR2      |
| 0  | 0             | 1            | 0       | AN2                    | ADR3      |
| 0  | 0             | 1            | 1       | AN3                    | ADR4      |
| 0  | 1             | 0            | 0       | AN4*                   | ADR1      |
| 0  | 1             | 0            | 1       | AN5*                   | ADR2      |
| 0  | 1             | 1            | 0       | AN6*                   | ADR3      |
| 0  | 1             | 1            | 1       | AN7*                   | ADR4      |
| 1  | 0             | Х            | Х       | Reserved               | ADR1–ADR4 |
| 1  | 1             | 0            | 0       | V <sub>RH</sub> **     | ADR1      |
| 1  | 1             | 0            | 1       | V <sub>RL</sub> **     | ADR2      |
| 1  | 1             | 1            | 0       | (V <sub>RH</sub> )/2** | ADR3      |
| 1  | 1             | 1            | 1       | Reserved**             | ADR4      |

#### Table 10 A/D Converter Channel Assignments

\* Not available in 48-pin package

\*\*Used for factory testing

#### ADR1–ADR4 — A/D Results

#### \$1031-\$1034

\$1039

|                 | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |      |
|-----------------|-------|---|---|---|---|---|---|-------|------|
| \$ <b>1</b> 031 | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | ADR1 |
| \$ <b>1</b> 032 | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | ADR2 |
| <b>\$1</b> 033  | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | ADR3 |
| \$ <b>1</b> 034 | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | ADR4 |

#### Table 11 Analog Input to 8-Bit Result Translation Table

|                                                                                                       | Bit 7 | 6     | 5     | 4      | 3      | 2      | 1      | Bit 0  |
|-------------------------------------------------------------------------------------------------------|-------|-------|-------|--------|--------|--------|--------|--------|
| % (1)                                                                                                 | 50%   | 25%   | 12.5% | 6.25%  | 3.12%  | 1.56%  | 0.78%  | 0.39%  |
| Volts <sup>(2)</sup>                                                                                  | 2.500 | 1.250 | 0.625 | 0.3125 | 0.1562 | 0.0781 | 0.0391 | 0.0195 |
| <sup>(1)</sup> % of $V_{RH} - V_{RL}$ <sup>(2)</sup> $V_{RL} = 0.0 \text{ V}; V_{RH} = 5.0 \text{ V}$ |       |       |       |        |        |        |        |        |

#### **OPTION** — System Configuration Options

|        | Bit 7 | 6    | 5     | 4    | 3   | 2 | 1    | Bit 0 |
|--------|-------|------|-------|------|-----|---|------|-------|
|        | ADPU  | CSEL | IRQE* | DLY* | CME | 0 | CR1* | CR0*  |
| RESET: | 0     | 0    | 0     | 1    | 0   | 0 | 0    | 0     |

\*Can be written only once in first 64 cycles out of reset in normal modes, or any time in special modes.

#### ADPU — A/D Power Up

0 = A/D Converter powered down

1 = A/D Converter powered up

CSEL — Clock Select

0 = A/D and EEPROM use system E clock

1 = A/D and EEPROM use internal RC clock

- IRQE IRQ Select Edge Sensitive Only Refer to **3 Resets and Interrupts**.
- DLY Enable Oscillator Start-Up Delay on Exit from STOP Refer to **3 Resets and Interrupts**.
- CME Clock Monitor Enable Refer to **3 Resets and Interrupts**.
- CR1, CR0 COP Timer Rate Select Refer to **3 Resets and Interrupts**.

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

MC68HC11A8TS/D

#### How to reach us:

USA/EUROPE: Motorola Literature Distribution; P.O. Box 20912; Phoenix, Arizona 85036. 1-800-441-2447 MFAX: RMFAX0@email.sps.mot.com - TOUCHTONE (602) 244-6609 INTERNET: http://Design-NET.com JAPAN: Nippon Motorola Ltd.; Tatsumi-SPD-JLDC, Toshikatsu Otsuki, 6F Seibu-Butsuryu-Center, 3-14-2 Tatsumi Koto-Ku, Tokyo 135, Japan. 03-3521-8315 HONG KONG: Motorola Semiconductors H.K. Ltd.; 8B Tai Ping Industrial Park, 51 Ting Kok Road, Tai Po, N.T., Hong Kong. 852-26629298

