

## MC68HC11A8

TECHNICAL<br>DATA

## MC68HC11A8

## HCMOS Single-Chip Microcontroller


#### Abstract

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


## TABLE OF CONTENTS

Paragraph
Title
Page
Number
SECTION 1
INTRODUCTION
1.1 Features ..... 1-1
1.2 General Description ..... 1-1
1.3 Programmer's Model ..... 1-2
1.4 Summary of M68HC11 Family ..... 1-3
SECTION 2 SIGNAL DESCRIPTIONS AND OPERATING MODES
2.1 Signal Pin Descriptions ..... 2-1
2.1.1 Input Power (VDD) and Ground (VSS) ..... 2-1
2.1.2 Reset (RESET) ..... 2-1
2.1.3 Crystal Driver and External Clock Input (XTAL, EXTAL) ..... 2-1
2.1.4 E Clock Output (E) ..... 2-3
2.1.5 Interrupt Request (IRQ) ..... 2-3
2.1.6 Non-Maskable Interrupt (XIRQ) ..... 2-3
2.1.7 Mode A/Load Instruction Register and Mode B/Standby Voltage (MODA/LIR, MODB/VSTBY) ..... 2-3
2.1.8 A/D Converter Reference Voltages (VRL, $\mathrm{V}_{\mathrm{RH}}$ ) ..... 2-3
2.1.9 Strobe B and Read/Write (STRB/R/W) ..... 2-4
2.1.10 Strobe A and Address Strobe (STRA/AS) ..... 2-4
2.1.11 Port Signals ..... 2-4
2.1.11.1 PORT A ..... 2-4
2.1.11.2 PORT B ..... 2-5
2.1.11.3 PORT C ..... 2-5
2.1.11.4 PORT D ..... 2-5
2.1.11.5 PORT E ..... 2-5
2.2 Operating Modes ..... 2-5
2.2.1 Single-Chip Operating Mode. ..... 2-6
2.2.2 Expanded Multiplexed Operating Mode ..... 2-6
2.2.3 Special Bootstrap Operating Mode ..... 2-7
2.2.4 Additional Boot Loader Program Options ..... 2-7
2.2.5 Special Test Operating Mode ..... 2-8
SECTION 3 ON-CHIP MEMORIES
3.1 Memory Maps ..... 3-1
$3.2 \quad$ RAM and I/O Mapping Register (INIT) ..... 3-4
3.3 ROM ..... 3-5
3.4 RAM ..... 3-5

## TABLE OF CONTENTS (Continued)

| Paragraph | Page |  |
| :--- | :---: | :---: |
| Number | Title | Number |

3.5 EEPROM ..... 3-5
3.5.1 EEPROM Programming Control Register (PPROG) ..... 3-6
3.5.2 Programming/Erasing Internal EEPROM ..... 3-7
3.5.2.1 Read ..... 3-7
3.5.2.2 Programming ..... 3-7
3.5.2.3 Bulk Erase ..... 3-7
3.5.2.4 Row Erase ..... 3-8
3.5.2.5 Byte Erase ..... 3-8
3.5.3 System Configuration Register (CONFIG) ..... 3-9
3.5.3.1 Programming and Erasure of the CONFIG Register ..... 3-9
3.5.3.2 Operation of the Configuration Mechanism ..... 3-10
SECTION 4
PARALLEL I/O
$4.1 \quad$ General Purpose I/O (Ports C and D) ..... 4-1
4.2 Fixed Direction I/O (Ports A, B, and E) ..... 4-1
4.3 Simple Strobed I/O ..... 4-1
4.3.1 Strobed Input Port C ..... 4-2
4.3.2 Strobed Output Port B ..... 4-2
4.4 Full Handshake I/O ..... 4-2
4.4.1 Input Handshake Protocol ..... 4-2
4.4.2 Output Handshake Protocol ..... 4-3
4.5 Parallel I/O Control Register (PIOC) ..... 4-3
SECTION 5
SERIAL COMMUNICATIONS INTERFACE (SCI)
$5.1 \quad$ Overview and Features ..... 5-1
$5.2 \quad$ Data Format ..... 5-1
5.3 Wake-Up Feature ..... 5-2
5.4 Receive Data (RxD) ..... 5-2
5.5 Start Bit Detection ..... 5-3
$5.6 \quad$ Transmit Data (TxD) ..... 5-5
5.7 Functional Description ..... 5-5
$5.8 \quad$ SCI Registers ..... 5-5
5.8.1 Serial Communications Data Register (SCDR) ..... 5-5
5.8.2 Serial Communications Control Register 1 (SCCR1) ..... 5-7
5.8.3 Serial Communications Control Register 2 (SCCR2) ..... 5-7
5.8.4 Serial Communications Status Register (SCSR) ..... 5-8
5.8.5 Baud Rate Register (BAUD) ..... 5-9

## TABLE OF CONTENTS (Continued)

Paragraph
Title
Page
Number
SECTION 6
SERIAL PERIPHERAL INTERFACE (SPI)
6.1 Overview and Features ..... 6-1
6.2 SPI Signal Descriptions ..... 6-1
6.2 .1 Master In Slave Out (MISO) ..... 6-1
6.2.2 Master Out Slave In (MOSI) ..... 6-2
6.2.3 Serial Clock (SCK) ..... 6-2
6.2 .4 Slave Select (SS) ..... 6-2
6.3 Functional Description ..... 6-3
6.4 SPI Registers ..... 6-4
6.4.1 Serial Peripheral Control Register (SPCR) ..... 6-4
6.4.2 Serial Peripheral Status Register (SPSR) ..... 6-5
6.4.3 Serial Peripheral Data I/O Register (SPDR) ..... 6-6
SECTION 7
ANALOG-TO-DIGITAL CONVERTER
7.1 Conversion Process ..... 7-1
7.2 Channel Assignments ..... 7-1
$7.3 \quad$ Single-Channel Operation ..... 7-1
7.4 Multiple-Channel Operation ..... 7-2
7.5 Operation in STOP and WAIT Modes ..... 7-3
7.6 A/D Control/Status Register (ADCTL) ..... 7-3
7.7 A/D Result Registers 1, 2, 3, and 4 (ADR1, ADR2, ADR3, and ADR4) ..... 7-4
7.8 A/D Power Up and Clock Select ..... 7-5
SECTION 8
PROGRAMMABLE TIMER, REAL TIME INTERRUPT, AND PULSE ACCUMULATOR
8.1 Programmable Timer ..... 8-1
8.1.1 Counter ..... 8-1
8.1.2 Input Capture ..... 8-1
8.1.3 Output Compare ..... 8-2
8.1.4 Output Compare 1 I/O Pin Control ..... 8-2
8.1.5 Timer Compare Force Register (CFORC) ..... 8-3
8.1 .6 Output Compare 1 Mask Register (OC1M) ..... 8-3
8.1.7 Output Compare 1 Data Register (OC1D) ..... 8-4
8.1.8 Timer Control Register 1 (TCTL1) ..... 8-4
8.1.9 Timer Control Register 2 (TCTL2) ..... 8-4
8.1.10 Timer Interrupt Mask Register 1 (TMSK1) ..... 8-5
8.1.11 Timer Interrupt Flag Register 1 (TFLG1) ..... 8-5
8.1.12 Timer Interrupt Mask Register 2 (TMSK2) ..... 8-5

## TABLE OF CONTENTS (Continued)

Paragraph ..... Title
Page
Number Title Number
8.1.13 Timer Interrupt Flag Register 2 (TFLG2) ..... 8-6
8.2 Real Time Interrupt ..... 8-7
8.3 Pulse Accumulator ..... 8-7
8.4 Pulse Accumulator Control Register (PACTL) ..... 8-7
SECTION 9
RESETS, INTERRUPTS, AND LOW POWER MODES
9.1 Resets ..... 9-1
9.1.1 External RESET Pin ..... 9-1
9.1.2 Power-On Reset ..... 9-1
9.1.2.1 CPU ..... 9-2
9.1.2.2 Memory Map ..... 9-4
9.1.2.3 Parallel I/O ..... 9-49.1.2.49.1.2.5
Timer ..... 9-4
Real Time Interrupt ..... 9-4
9.1.2.6 Pulse Accumulator ..... 9-4
9.1.2.7 COP ..... 9-4
9.1.2.8 SCI Serial I/O ..... 9-4
9.1.2.9 SPI Serial I/O ..... 9-4
9.1.2.10 A/D Converter ..... 9-4
9.1.2.11 System ..... 9-4
9.1.3 Computer Operating Properly (COP) Reset ..... 9-5
9.1.4 Clock Monitor Reset ..... 9-6
9.1.5 Configuration Options Register (OPTION) ..... 9-6
9.2 Interrupts ..... 9-7
9.2.1 Software Interrupt (SWI) ..... 9-8
9.2.2 Illegal Opcode Trap ..... 9-9
9.2.3 Interrupt Mask Bits in Condition Code Register ..... 9-9
9.2.4 Priority Structure ..... 9-9
9.2.5 Highest Priority I Interrupt Register (HPRIO) ..... 9-10
9.3 Low Power Modes ..... 9-16
9.3.1 WAIT Instruction ..... 9-16
9.3.2 STOP Instruction ..... 9-16
SECTION 10
CPU, ADDRESSING MODES, AND INSTRUCTION SET
10.1 CPU Registers ..... 10-1
10.1.1 Accumulators $A$ and $B$ ..... 10-1
10.1.2 Index Register X (IX) ..... 10-1
10.1.3 Index Register Y (IY) ..... 10-2
10.1.4 Stack Pointer (SP) ..... 10-2
10.1.5 Program Counter (PC) ..... 10-2

## TABLE OF CONTENTS (Concluded)

Paragraph
Title
Page
Number Number
10.1.6Condition Code Register (CCR)10-2
10.1.6.1 Carry/Borrow (C) ..... 10-2
10.1.6.2 Overflow (V) ..... 10-2
10.1.6.3 Zero (Z) ..... 10-2
10.1.6.4 Negative (N) ..... 10-2
10.1.6.5 Interrupt Mask (I) ..... 10-2
10.1.6.6 Half Carry (H) ..... 10-2
10.1.6.7 X Interrupt Mask (X) ..... 10-3
10.1.6.8 Stop Disable (S) ..... 10-3
10.2 Addressing Modes ..... 10-3
10.2.1 Immediate Addressing ..... 10-3
10.2.2 Direct Addressing ..... 10-3
10.2.3 Extended Addressing ..... 10-3
10.2.4 Indexed Addressing ..... 10-3
10.2.5 Inherent Addressing ..... 10-4
10.2.6 Relative Addressing ..... 10-4
10.2.7 Prebyte ..... 10-4
10.3 Instruction Set ..... 10-4
APPENDIX A ELECTRICAL CHARACTERISTICS
APPENDIX B
MECHANICAL DATA and ORDERING INFORMATION
B. 1 Pin Assignments ..... B-1
B. 2 Package Dimensions ..... B-4
B. 3 Ordering Information ..... B-7
SUMMARY OF CHANGES

## LIST OF ILLUSTRATIONS

Figure Page
Title Number
Number
1-1 Block Diagram ..... 1-2
1-2 Programming Model ..... 1-3
2-1 Common Crystal Connections ..... 2-2
2-2 External Oscillator Connections ..... 2-2
2-3 One Crystal Driving 2 MCUs ..... 2-2
2-4 Address/Data Demultiplexing ..... 2-6
3-1 Memory Maps ..... 3-1
5-1 Data Format ..... 5-2
5-2 Sampling Technique Used on All Bits ..... 5-3
5-3 Examples of Start Bit Sampling Techniques ..... 5-3
5-4 SCI Artificial Start Following a Framing Error ..... 5-4
5-5 SCI Start Bit Following a Break ..... 5-4
5-6 Serial Communications Interface Block Diagram ..... 5-6
5-7 Rate Generator Division ..... 5-10
6-1 Data Clock Timing Diagram ..... 6-2
6-2 Serial Peripheral Interface Block Diagram ..... 6-3
6-3 Serial Peripheral Interface Master-Slave Interconnection ..... 6-4
7-1 A/D Conversion Sequence ..... 7-2
7-2 A/D Pin Model ..... 7-2
9-1 Reset Timing ..... 9-2
9-2 Reset Circuit with LVI and RC Delay ..... 9-3
9-3 Simple LVI Reset Circuit ..... 9-3
9-4 Interrupt Stacking Order ..... 9-9
9-5 Processing Flow Out of Resets ..... 9-11
9-6 Interrupt Priority Resolution ..... 9-13
9-7 Interrupt Source Resolution Within SCI ..... 9-15
10-1 Programming Model ..... 10-1
10-2 Special Operations ..... 10-12
A-1 Test Methods ..... A-5
A-2 Timer Inputs ..... A-7
A-3 POR and External Reset Timing Diagram ..... A-8
A-4 STOP Recovery Timing Diagram ..... A-9
A-5 WAIT Recovery Timing Diagram ..... A-10
A-6 Interrupt Timing Diagram ..... A-11

## LIST OF ILLUSTRATIONS (Continued)

Figure PageTitleNumber
Number
A-7 Port Write Timing Diagram ..... A-14
A-8 Port Read Timing Diagram ..... A-14
A-9 Simple Output Strobe Timing Diagram ..... A-14
A-10 Simple Input Strobe Timing Diagram ..... A-15
A-11 Port C Input Handshake Timing Diagram ..... A-15
A-12 Port C Output Handshake Timing Diagram ..... A-15
A-13 Three-State Variation of Output Handshake Timing Diagram ..... A-16
A-14 Multiplexed Expansion Bus Timing Diagram ..... A-21
A-15 SPI Timing Diagram (1 of 2) ..... A-24
A-15 SPI Timing Diagram (2 of 2) ..... A-25
B-1 52-Pin PLCC ..... B-1
B-2 $48-\mathrm{Pin}$ DIP ..... B-2
B-3 64-Pin QFP ..... B-3
B-4 Case Outline 778-02 ..... B-4
B-5 Case Outline 767-02 ..... B-5
B-6 Case Outline 840B-01 ..... B-6
B-7 M68HC11 P/N Options ..... B-8

## LIST OF TABLES

Table Page Number Title Number
1-1 MC68HC11 Family Members ..... 1-4
2-1 Operating Modes versus MODA and MODB ..... 2-3
2-2 Port Signal Summary ..... 2-4
2-3 Bootstrap Mode Interrupt Vectors ..... 2-7
3-1 Register and Control Bit Assignments ..... 3-2
4-1 Handshake I/O Operations Summary ..... 4-4
5-1 First Prescaler Stage ..... 5-10
5-2 Second Prescaler Stage ..... 5-10
5-3 Prescaler Highest Baud Rate Frequency Output ..... 5-10
5-4 Transmit Baud Rate Output for a Given Prescaler Output ..... 5-11
6-1 Serial Peripheral Rate Selection ..... 6-5
7-1 Analog-to-Digital Channel Assignments ..... 7-4
8-1 Real Time Interrupt Rate versus RTR1 and RTR0 ..... 8-8
9-1 COP Timeout Period versus CR1 and CR0 ..... 9-5
9-2 Interrupt Vector Assignments ..... 9-8
9-3 SCI Serial System Interrupts ..... 9-8
9-4 IRQ Vector Interrupts ..... $9-8$
9-5 Mode Bits Relationship ..... 9-10
9-6 Highest Priority I Interrupt versus PSEL3-PSELO ..... 9-16
9-7 Pin State Summary for RESET, STOP and WAIT ..... 9-17
10-1 MC68HC11A8 Instructions, Addressing Modes, and Execution Times ..... 10-5
10-2 Cycle-by-Cycle Operation - Inherent Model ..... 10-13
10-3 Cycle-by-Cycle Operation - Immediate Mode ..... 10-16
10-4 Cycle-by-Cycle Operation - Direct Mode ..... 10-16
10-5 Cycle-by-Cycle Operation - Extended Mode ..... 10-17
10-6 Cycle-by-Cycle Operation - Indexed X Mode ..... 10-19
10-7 Cycle-by-Cycle Operation - Indexed Y Mode ..... 10-20
$10-8$ Cycle-by-Cycle Operation - Relative Mode ..... 10-22

## LIST OF TABLES (Continued)

Table
Title
Page Number Number
A-1 Maximum Ratings ..... A-1
A-2 Thermal Characteristics ..... A-2
A-3 DC Electrical Characteristics ..... A-3
A-3a DC Electrical Characteristics (MC68L11A8) ..... A-4
A-4 Control Timing ..... A-6
A-4a Control Timing (MC68L11A8) ..... A-7
A-5 Peripheral Port Timing ..... A-12
A-5a Peripheral Port Timing (MC68L11A8) ..... A-13
A-6 Analog-to-Digital Converter Characteristics ..... A-17
A-6a Analog-to-Digital Converter Characteristics (MC68L11A8) ..... A-18
A-7 Expansion Bus Timing ..... A-19
A-7a Expansion Bus Timing (MC68L11A8) ..... A-20
A-8 Serial Peripheral Interface ..... A-22
A-8a Serial Peripheral Interface (MC68L11A8) ..... A-23
A-9 EEPROM Characteristics ..... A-26
A-9a EEPROM Characteristics (MC68L11A8) ..... A-26
B-1 Ordering Information ..... B-7
C-1 M68HC11 Development Tools ..... C-1

## SECTION 1 INTRODUCTION

The HCMOS MC68HC11A8 is an advanced 8-bit microcontroller (MCU) with highly sophisticated on-chip peripheral capabilities. A fully static design and high-density complementary metal-oxide semiconductor (HCMOS) fabrication process allow E-series devices to operate at frequencies from 3 MHz to dc, with very low power consumption.

### 1.1 FEATURES

The following are some of the hardware and software highlights.

## Hardware Features

- 8 Kbytes of ROM
- 512 Bytes of EEPROM
- 256 Bytes of RAM (All Saved During Standby) Relocatable to Any 4K Boundary
- Enhanced 16-Bit Timer System:

Four Stage Programmable Prescaler
Three Input Capture Functions
Five Output Compare Functions

- 8-Bit Pulse Accumulator Circuit
- Enhanced NRZ Serial Communications Interface (SCI)
- Serial Peripheral Interface (SPI)
- Eight Channel, 8-Bit Analog-to-Digital Converter
- Real Time Interrupt Circuit
- Computer Operating Properly (COP) Watchdog System
- Available in Dual-In-Line or Leaded Chip Carrier Packages


## Software Features

- Enhanced M6800/M6801 Instruction Set
- $16 \times 16$ Integer and Fractional Divide Features
- Bit Manipulation
- WAIT Mode
- STOP Mode


### 1.2 GENERAL DESCRIPTION

The high-density CMOS technology (HCMOS) used on the MC68HC11A8 combines smaller size and higher speeds with the low power and high noise immunity of CMOS. On-chip memory systems include 8 Kbytes of ROM, 512 bytes of electrically erasable programmable ROM (EEPROM), and 256 bytes of static RAM.

Major peripheral functions are provided on-chip. An eight channel analog-to-digital (A/D) converter is included with eight bits of resolution. An asynchronous serial communications interface ( SCl ) and a separate synchronous serial peripheral interface (SPI) are included. The main 16-bit freerunning timer system has three input capture lines, five output compare lines, and a real-time interrupt function. An 8-bit pulse accumulator subsystem can count external events or measure external periods.

Self monitoring circuitry is included on-chip to protect against system errors. A computer operating properly (COP) watchdog system protects against software failures. A clock monitor system generates a system reset in case the clock is lost or runs too slow. An illegal opcode detection circuit provides a non-maskable interrupt if an illegal opcode is detected.

Two software controlled operating modes, WAIT and STOP, are available to conserve additional power.

A block diagram of the MC68HC11A8 is shown in Figure 1-1.

### 1.3 PROGRAMMER'S MODEL

In addition to being able to execute all M6800 and M6801 instructions, the MC68HC11A8 allows execution of 91 new opcodes. Figure 1-2 shows the seven CPU registers which are available to the programmer.


Figure 1-1. Block Diagram


Figure 1-2. Programming Model

### 1.4 SUMMARY OF M68HC11 FAMILY

Table 1-1 and the following paragraphs summarize the current members of the M 68 HC 11 family of MCUs. This technical data book describes the MC68HC11A8 version and can be used as a primary reference for several other versions of the M68HC11 family. However, with the exception of the CPU, some newer members differ greatly from the MC68HC11A8 MCU and their respective technical literature should be referenced.

Several of the device series within the M 68 HC 11 family have ' x 1 and ' x 0 versions. These are identical to the main member of the series but have some of their on-chip resources disabled. For instance, an MC68HC11A1 is identical to the MC68HC11A8 except that its ROM is disabled. An MC68HC11A0 has disabled EPROM and EEPROM arrays. Refer to Table 1-1.

Nearly all series within the M68HC11 family have both a ROM version and an EPROM version. Any device in the M68HC11 family that has a 7 preceding the 11 is a device containing EPROM instead of ROM (e.g., MC68HC711E9). These devices operate exactly as the custom ROM-based version (e.g., MC68HC11E9) but can be programmed by the user. EPROM-based devices in a windowed package can be erased and reprogrammed indefinitely. EPROM-based devices in standard packages are one-time-programmable (OTP). Refer to Table 1-1.

Table 1-1. M68HC11 Family Devices

| Device | RAM | ROM | EPROM | EEPROM | COMMENTS |
| :---: | :---: | :---: | :---: | :---: | :---: |
| MC68HC11A8 | 256 | 8K | 0 | 512 | 16-bit timer; 8 channel 8-bit A/D, SCI, SPI |
| MC68HC11A7. | 256 | 8K | 0 | 0 |  |
| MC68HC11A1 | 256 | 0 | 0 | 512 |  |
| MC68HC11A0 | 256 | 0 | 0 | 0 |  |
| MC68HC11D3 | 192 | 4K | 0 | 0 | 16-bit timer; SCI, SPI |
| MC68HC711D3 | 192 | 0 | 4K | 0 |  |
| MC68HC11D0 | 192 | 0 | 0 | 0 |  |
| MC68HC11ED0 | 512 | 0 | 0 | 0 | 16-bit timer; SCI, SPI |
| MC68HC11E9 | 512 | 12K | 0 | 512 | 16-bit timer; SCI, SPI, 8 channel 8-bit A/D |
| MC68HC711E9 | 512 | 0 | 12 K | 512 |  |
| MC68HC11E8 | 512 | 12 K | 0 | 0 |  |
| MC68HC11E1 | 512 | 0 | 0 | 512 |  |
| MC68HC11E0 | 512 | 0 | 0 | 0 |  |
| MC68HC811E2 | 256 | 0 | 0 | 2048 | 16-bit timer; SCI, SPI, 8 channel 8-bit A/D, 2K EEPROM |
| MC68HC11E20 | 768 | 20K | 0 | 512 | 16 -bit timer; SCI, SPI, 8 channel 8 -bit A/D, 20K ROM/EPROM |
| MC68HC711E20 | 768 | 0 | 20K | 512 |  |
| MC68HC11F1 | 1024 | 0 | 0 | 512 | nonmultiplexed bus, 8 channel 8 -bit A/D, 4 chip selects, SCI, SPI |
| MC68HC11G7 | 512 | 24K | 0 | 0 | nonmultiplexed bus, 8 channel 10-bit A/D, 4 channel PWM, SCI, SPI, 66 I/O pins |
| MC68HC11G5 | 512 | 16 K | 0 | 0 |  |
| MC68HC711G5 | 512 | 0 | 16K | 0 |  |
| MC68HC11G0 | 512 | 0 | 0 | 0 |  |
| MC68HC11K4 | 768 | 24 K | 0 | 640 | nonmultiplexed bus, memory expansion to 1 MB , 8 channel 8 -bit A/D, 4 channel PWM, 4 chip selects |
| MC68HC711K4 | 768 | 0 | 24K | 640 |  |
| MC68HC11K3 | 768 | 24K | 0 | 0 |  |
| MC68HC11K1 | 768 | 0 | 0 | 640 |  |
| MC68HC11K0 | 768 | 0 | 0 | 0 |  |
| MC68HC11KA4 | 768 | 24K | 0 | 640 | nonmultiplexed bus, 8 channel 8-bit A/D, SCI, SPI, 4 channel PWM |
| MC68HC711KA4 | 768 | 0 | 24K | 640 |  |
| MC68HC11KA2 | 1024 | 32 K | 0 | 640 |  |
| MC68HC711KA2 | 1024 | 0 | 32 K | 640 |  |
| MC68HC11L6 | 512 | 16K | 0 | 512 |  |
| MC68HC711L6 | 512 | 0 | 16 K | 512 | multiplexed bus, 16-bit timer; 8 channel 8-bit AD, SCI, SPI |
| MC68HC11L5 | 512 | 16 K | 0 | 0 |  |
| MC68HC11L1 | 512 | 0 | 0 | 512 |  |
| MC68HC11LO | 512 | 0 | 0 | 0 |  |
| MC68HC11M2 | 1280 | 32 K | 0 | 640 | nonmultiplexed bus, 8 channel 8-bit A/D, 4 channel PWM, DMA, on-chip math coprocessor, SCI, 2 SPI |
| MC68HC711M2 | 1280 | 0 | 32K | 640 |  |
| MC68HC11N4 | 768 | 24K | 0 | 640 | nonmultiplexed bus, 12 channel 8 -bit A/D, 2 channel 8 -bit D/A, 6 channel PWM, on-chip math coprocessor, SCI, SPI |
| MC68HC711N4 | 768 | 0 | 24K | 640 |  |
| MC68HC11P2 | 1024 | 32 K | 0 | 640 | nonmultiplexed bus, PLL, 8 channel 8 -bit A/D, 4 channel PWM, 3 SCl ( 2 with MI bus), SPI, 62 I/O pins |
| MC68HC711P2 | 1024 | 0 | 32 K | 640 |  |

## SECTION 2 SIGNAL DESCRIPTIONS AND OPERATING MODES

The signal descriptions and operating modes are presented in this section. When the microcontroller is in an expanded multiplexed operating mode, 18 pins change function to support a multiplexed address/data bus.

### 2.1 SIGNAL PIN DESCRIPTIONS

The following paragraphs provide a description of the input/output signals. Reference is made, where applicable, to other sections that contain more detail about the function being performed.

### 2.1.1 Input Power ( $\mathrm{V}_{\mathrm{DD}}$ ) and Ground ( $\mathrm{V}_{\mathrm{SS}}$ )

Power is supplied to the microcontroller using these pins. $\mathrm{V}_{\mathrm{DD}}$ is the positive power input and $\mathrm{V}_{\mathrm{SS}}$ is ground. Although the MC68HC11A8 is a CMOS device, very fast signal transitions are present on many of its pins. Short rise and fall times are present even when the microcontroller is operating at slow clock rates. Special care must be taken to provide good power supply bypassing at the MCU. Recommended bypassing would include a $0.1 \mu \mathrm{~F}$ ceramic capacitor between the $\mathrm{V}_{\mathrm{DD}}$ and $\mathrm{V}_{\text {SS }}$ pins and physically adjacent to one of the two pins. A bulk capacitance, whose size depends on the other circuitry in the system, should also be present on the circuit board.

### 2.1.2 Reset ( $\overline{\operatorname{RESET}}$ )

This active low bidirectional control signal is used as an input to initialize the MC68HC11A8 to a known start-up state, and as an open-drain output to indicate that an internal failure has been detected in either the clock monitor or computer operating properly (COP) watchdog circuit. This reset signal is significantly different from the reset signal used on other Motorola MCUs. Please refer to SECTION 9 RESETS, INTERRUPTS, AND LOW POWER MODES before designing circuitry to generate or monitor this signal.

### 2.1.3 Crystal Driver and External Clock Input (XTAL, EXTAL)

These two pins provide the interface for either a crystal or a CMOS compatible clock to control the internal clock generator circuitry. The frequency applied to these pins shall be four times higher than the desired E clock rate. The XTAL pin is normally left unterminated when using an external CMOS compatible clock input to the EXTAL pin. However, a 10 K to 100 K load resistor to ground may be used to reduce RFI noise emission. The XTAL output is normally intended to drive only a crystal.

The XTAL output may be buffered with a high-input-impedance buffer such as the 74 HC 04 , or it may be used to drive the EXTAL input of another M68HC11.

In all cases take extra care in the circuit board layout around the oscillator pins. Load capacitances shown in the oscillator circuits include all stray layout capacitances. Refer to Figures 2-1, 2-2, and 2-3 for diagrams of oscillator circuits.


* THis value includes all stray capacitances.

Figure 2-1. Common Crystal Connections


EXT EXTAL CONN
Figure 2-2. External Oscillator Connections


Figure 2-3. One Crystal Driving Two MCUs

### 2.1.4 E Clock Output (E)

This is the output connection for the internally generated E clock which can be used as a timing reference. The frequency of the E clock output is actually one fourth that of the input frequency at the XTAL and EXTAL pins. When the E clock output is low an internal process is taking place and, when high, data is being accessed. The E clock signal is halted when the MCU is in STOP mode.

### 2.1.5 Interrupt Request ( $\overline{\mathrm{RQ}}$ )

The $\overline{\mathrm{RQ}}$ input provides a means for requesting asynchronous interrupts to the MC68HC11A8. It is program selectable (OPTION register) with a choice of either negative edge-sensitive or levelsensitive triggering, and is always configured to level-sensitive triggering by reset. The $\overline{\mathrm{RQ}}$ pin requires an external pullup resistor to $\mathrm{V}_{\mathrm{DD}}$ (typically 4.7 K ohm ).

### 2.1.6 Non-Maskable Interrupt ( $\overline{\mathrm{XIRQ}}$ )

This input provides a means for requesting a non-maskable interrupt, after reset initialization. During reset, the X bit in the condition code register is set and any interrupt is masked until MCU software enables it. The XIRQ input is level sensitive and requires an external pullup resistor to $\mathrm{V}_{\mathrm{DD}}$.

### 2.1.7 Mode A/Load Instruction Register and Mode B/Standby Voltage (MODA/LIR, MODB/V ${ }_{\text {STBY }}$ )

During reset, MODA and MODB are used to select one of the four operating modes. Refer to Table 2-1. Paragraph 2.2 OPERATING MODES provides additional information.

After the operating mode has been selected, the $\overline{\operatorname{LIR}}$ pin provides an open-drain output to indicate that an instruction is starting. All instructions are made up of a series of E clock cycles. The LIR signal goes low during the first E clock cycle of each instruction (opcode fetch). This output is provided as an aid in program debugging.

The $\mathrm{V}_{\text {STBY }}$ signal is used as the input for RAM standby power. When the voltage on this pin is more than one MOS threshold (about 0.7 volts) above the $V_{\text {DD }}$ voltage, the internal 256 -byte RAM and part of the reset logic are powered from this signal rather than the $\mathrm{V}_{\mathrm{DD}}$ input. This allows RAM contents to be retained without

Table 2-1. Operating Modes versus
MODA and MODB

| MODB | MODA | Mode Selected |
| :---: | :---: | :--- |
| 1 | 0 | Single Chip |
| 1 | 1 | Expanded Multiplexed |
| 0 | 0 | Special Bootstrap |
| 0 | 1 | Special Test | $V_{\text {DD }}$ power applied to the MCU. Reset must be driven low before $V_{D D}$ is removed and must remain low until $V_{D D}$ has been restored to a valid level.

### 2.1.8 A/D Converter Reference Voltages ( $\mathbf{V R L}_{\mathbf{R}}, \mathbf{V}_{\mathbf{R H}}$ )

These two inputs provide the reference voltages for the analog-to-digital converter circuitry.

### 2.1.9 Strobe $B$ and Read/Write (STRB/R/W)

This signal acts as a strobe B output or as a data bus direction indicator depending on the operating mode.

In single-chip operating mode, the STRB output acts as a programmable strobe for handshake with other parallel I/O devices. Refer to SECTION 4 PARALLEL I/O for additional information.

In expanded multiplexed operating mode, $\mathrm{R} / \overline{\mathrm{W}}$ is used to control the direction of transfers on the external data bus. A low on the R/W signal indicates data is being written to the external data bus. A high on this signal indicates that a read cycle is in progress. $R / \bar{W}$ will stay low during consecutive data bus write cycles, such as in a double-byte store. The NAND of inverted R/W with the E clock should be used as the write enable signal for an external static RAM.

### 2.1.10 Strobe A and Address Strobe (STRA/AS)

This signal acts as an edge detecting strobe $\mathbf{A}$ input or as an address strobe bus control output depending on the operating mode.

In single-chip operating mode, the STRA input acts as a programmable strobe for handshake with other parallel I/O devices. Refer to SECTION 4 PARALLEL I/O for additional information.

In expanded multiplexed operating mode, the AS output is used to demultiplex the address and data signals at port C. Refer to 2.2.2 Expanded Multiplexed Operating Mode for additional information.

### 2.1.11 Port Signals

Ports A, D, and E signals are independent of the operating mode. Port B provides eight general purpose output signals in single-chip operating modes and provides eight high-order address signals when the microcontroller is in expanded multiplexed operating modes. Port C provides eight general purpose input/output signals when the microcontroller is in singlechip operating modes. When the microcontroller is in expanded multiplexed operating modes, port C is used for a multiplexed address/data bus. Table 2-2 shows a summary of the 40 port signals as they relate to the operating modes. Unused inputs and I/O pins configured as inputs should be terminated high or low.
2.1.11.1 PORT A. Port A may be configured for: three input capture functions (IC1, IC2, IC3),

Table 2-2. Port Signal Summary

| Port-Bit | Single-Chip <br> and Bootstrap Mode | Expanded Multiplexed and Special Test Mode |
| :---: | :---: | :---: |
| A-0 | PA0/IC3 | PA0/IC3 |
| A-1 | PA1/IC2 | PA1/IC2 |
| A-2 | PA2/IC1 | PA2/IC1 |
| A-3 | PA3/OC5/and-or OC1 | PA3/OC5/and-or OC1 |
| A-4 | PA4/OC4/and-or OC1 | PA4/OC4/and-or OC1 |
| A-5 | PA5/OC3/and-or OC1 | PA5/OC3/and or OC1 |
| A-6 | PA6/OC2/and-or OC1 | PA6/OC2/and or OC1 |
| A-7 | PA7/PAl/and-or OC1 | PA7/PAl/and-or OC1 |
| B-0 | PB0 | A8 |
| B-1 | PB1 | A9 |
| B-2 | PB2 | A10 |
| B-3 | PB3 | A11 |
| B-4 | PB4 | A12 |
| B-5 | PB5 | A13 |
| B-6 | PB6 | A14 |
| B-7 | PB7 | A15 |
| C-0 | PC0 | A0/D0 |
| C-1 | PC1 | A1/D1 |
| C-2 | PC2 | A2/D2 |
| C-3 | PC3 | A3/D3 |
| C-4 | PC4 | A4/D4 |
| C-5 | PC5 | A5/D5 |
| C-6 | PC6 | A6/D6 |
| C-7 | PC7 | A7/D7 |
| D-0 | PD0/RxD | PD0/RxD |
| D-1 | PD1/TxD | PD1/TxD |
| D-2 | PD2/MISO | PD2/MISO |
| D-3 | PD3/MOSI | PD3/MOSI |
| D-4 | PD4/SCK | PD4/SCK |
| D-5 | PD5/SS | PD5/SS |
|  | STRA | AS |
|  | STRB | R/W |
| E-0 | PEO/ANO | PEO/ANO |
| E-1 | PE1/AN1 | PE1/AN1 |
| E-2 | PE3/AN2 | PE2/AN2 |
| E-3 | PE3/AN3 | PE3/AN3 |
| E-4 | PE4/AN4\#\# | PE4/AN4\#\# |
| E-5 | PE5/AN5\#\# | PE5/AN5\#\# |
| E-6 | PE6/AN6\#\# | PE6/AN6\#\# |
| E-7 | PE7/AN7\#\# | PE7/AN7\#\# |

\#\# Not Bonded in 48-Pin Versions
four output compare functions (OC2, OC3, OC4, OC5), and either a pulse accumulator input (PAI) or a fifth output compare function (OC1). Refer to 8.1 PROGRAMMABLE TIMER for additional information.

Any port A pin that is not used for its alternate timer function may be used as a general-purpose input or output line.
2.1.11.2 PORT B. While in single-chip operating modes, all of the port B pins are general-purpose output pins. During MCU reads of this port, the level sensed at the input side of the port B output drivers is read. Port B may also be used in a simple strobed output mode where an output pulse appears at the STRB signal each time data is written to port $B$.

When in expanded multiplexed operating modes, all of the port B pins act as high order address output signals. During each MCU cycle, bits 8 through 15 of the address are output on the PBOPB7 lines respectively.
2.1.11.3 PORT C. While in single-chip operating modes, all port $C$ pins are general-purpose input/output pins. Port $C$ inputs can be latched by providing an input transition to the STRA signal. Port $C$ may also be used in full handshake modes of parallel I/O where the STRA input and STRB output act as handshake control lines.

When in expanded multiplexed operating modes, all port $C$ pins are configured as multiplexed address/data signals. During the address portion of each MCU cycle, bits 0 through 7 of the address are output on the PC0-PC7 lines. During the data portion of each MCU cycle ( E high), pins 0 through 7 are bidirectional data signals (D0-D7). The direction of data at the port $C$ pins is indicated by the R/W signal.
2.1.11.4 PORT D. Port D pins $0-5$ may be used for general-purpose $I / O$ signals. Port D pins alternately serve as the serial communications interface (SCI) and serial peripheral interface (SPI) signals when those subsystems are enabled.

Pin PDO is the receive data input (RxD) signal for the serial communication interface (SCI).
Pin PD1 is the transmit data output (TxD) signal for the SCI .
Pins PD2 through PD5 are dedicated to the SPI. PD2 is the master-in-slave-out (MISO) signal. PD3 is the master-out-slave-in (MOSI) signal. PD4 is the serial clock (SCK) signal and PD5 is the slave select ( $\overline{\mathrm{SS}}$ ) input.
2.1.11.5 PORT E. Port $E$ is used for general-purpose inputs and/or analog-to-digital ( $A / D$ ) input channels. Reading port $E$ during the sampling portion of an $A / D$ conversion could cause very small disturbances and affect the accuracy of that result. If very high accuracy is required, avoid reading port $E$ during conversions.

### 2.2 OPERATING MODES

There are four operating modes for the MC68HC11A8: single-chip operating mode, expanded multiplexed operating mode, special bootstrap operating mode, and special test operating mode.

Table 2-1 shows how the operating mode is selected. The following paragraphs describe these operating modes.

### 2.2.1 Single-Chip Operating Mode

In single-chip operating mode, the MC68HC11A8 functions as a monolithic microcontroller without external address or data buses. Port B, port C, strobe A, and strobe B function as general purpose I/O and handshake signals. Refer to SECTION 4 PARALLEL I/O for additional information.

### 2.2.2 Expanded Multiplexed Operating Mode

In expanded multiplexed operating mode, the MC68HC11A8 has the capability of accessing a 64 Kbyte address space. This total address space includes the same on-chip memory addresses used for single-chip operating mode plus external peripheral and memory devices. The expansion bus is made up of port $B$ and port $C$, and control signals $A S$ and $R / \bar{W}$. Figure $2-4$ shows a recommended way of demultiplexing low order addresses from data at port $C$. The address, $R / \bar{W}$, and AS signals are active and valid for all bus cycles including accesses to internal memory locations.


ADDRIDATA DEMUX
Figure 2-4. Address/Data Demultiplexing

### 2.2.3 Special Bootstrap Operating Mode

The bootstrap mode is considered a special operating mode as distinguished from the normal sin-gle-chip operating mode. This is a very versatile operating mode since there are essentially no limitations on the special purpose program that can be loaded into the internal RAM. The boot loader program is contained in the 192 byte bootstrap ROM. This ROM is enabled only if the MCU is reset in special bootstrap operating mode, and appears as internal memory space at locations \$BF40-\$BFFF. The boot loader program will use the SCI to read a 256 byte program into on-chip RAM at locations $\$ 0000-\$ 00 F F$. After the character for address $\$ 00 F F$ is received, control is automatically passed to that program at location $\$ 0000$.

The MC68HC11A8 communicates through the SCl port. After reset in special bootstrap operating mode, the SCl is running at E clock/16 ( 7812 baud for E clock equal 2 MHz ). If the security feature was specified and the security bit is set, \$FF is output by the SCI transmitter. The EEPROM is then erased. If erasure is unsuccessful, \$FF is output again and erasure is attempted again. Upon successful erasure of the EEPROM, all internal RAM is written over with \$FF. The CONFIG register is then erased. The boot loader program now proceeds as though the part had not been in security mode.

If the part is not in security mode (or has completed the above erase sequence), a break character is output by the SCI transmitter. For normal use of the boot loader program, the user sends $\$ \mathrm{FF}$ to the SCI receiver at either E clock/16 ( 7812 baud for E clock $=2 \mathrm{MHz}$ ) or E clock/104 (1200 baud for E clock $=2 \mathrm{MHz}$ ).

## NOTE

This \$FF is not echoed through the SCI transmitter.
Now the user must download 256 bytes of program data to be put into RAM starting at location $\$ 0000$. These characters are echoed through the transmitter. When loading is complete, the program jumps to location $\$ 0000$ and begins executing that code.

If the SCI transmitter pin is to be used, an external pullup resistor is required because port D pins are configured for wire-OR operation.

In special bootstrap operating mode the interrupt vectors are directed to RAM as shown in Table 2-3. This allows the user to use interrupts by way of a jump table. For example: to use the SWI interrupt, a jump instruction would be placed in RAM at locations \$00F4, \$00F5, and \$00F6. When an SWI is encountered, the vector (which is in the boot loader ROM program) will direct program control to location \$00F4 in RAM which in turn contains a JUMP instruction to the interrupt service routine.

### 2.2.4 Additional Boot Loader Program Options

The user may transmit a $\$ 55$ (only at E clock/16) as the first character rather than the normal \$FF. This will cause the program to jump directly to location $\$ 0000$, skipping the download.

Table 2-3. Bootstrap Mode Interrupt Vectors

| Address | Vector |
| :--- | :--- |
| 00C4 | SCI |
| 00C7 | SPI |
| 00CA | Pulse Accumulator Input Edge |
| 00CD | Pulse Accumulator Overflow |
| 00D0 | Timer Overflow |
| 00D3 | Timer Output Compare 5 |
| 00D6 | Timer Output Compare 4 |
| 00D9 | Timer Output Compare 3 |
| 00DC | Timer Output Compare 2 |
| 00DF | Timer Output Compare 1 |
| 00E2 | Timer Input Capture 3 |
| 00E5 | Timer Input Capture 2 |
| 00E8 | Timer Input Capture 1 |
| 00EB | Real Time Interrupt |
| 00EE | IRQ |
| 00F1 | XIRQ |
| 00F4 | SWI |
| 00F7 | Illegal Opcode |
| 00FA | COP Fail |
| 00FD | Clock Monitor |
| BF40 | Reset |
| (Boot) |  |

The user may tie the receiver to the transmitter (with an external pull-up resistor). This will cause the program to jump directly to the beginning of EEPROM (\$B600). Another way to cause the program to jump directly to EEPROM is to transmit either a break or $\$ 00$ as the first character rather than the normal \$FF.

Note that none of these options bypass the security check and so do not compromise those customers using security.

Keep in mind that upon entry to the downloaded program at location \$0000, some registers have been changed from their reset states. The SCI transmitter and receiver are enabled which cause port D pins 0 and 1 to be dedicated to SCI use. Also port D is configured for wired-OR operation. It may be necessary for the user to write to the SCCR2 and SPCR registers to disable the SCI and/or port D wire-OR operation.

### 2.2.5 Special Test Operating Mode

The test mode is a special operating mode intended primarily for factory testing. This mode is very similar to the expanded multiplexed operating mode. In special test operating mode, the reset and interrupt vectors are fetched from external memory locations \$BFC0-\$BFFF rather than \$FFC0\$FFFF. There are no time limits for protection of the TMSK2, OPTION, and INIT registers, so these registers may be written repeatedly. Also a special TEST1 register is enabled which allows several factory test functions to be invoked.

The special test operating mode is not recommended for use by an end user because of the reduced system security; however, an end user may wish to come out of reset in special test operating mode. Then, after some initialization, the SMOD and MDA bits could be rewritten to select a normal operating mode to re-enable the protection features.

## SECTION 3 ON-CHIP MEMORIES

This section describes the on-chip ROM, RAM, and EEPROM memories. The memory maps for each mode of operation are shown and the RAM and I/O mapping register (INIT) is described. The INIT register allows the on-chip RAM and the 64 control registers to be moved to suit the needs of a particular application.

### 3.1 MEMORY MAPS

Composite memory maps for each mode of operation are shown in Figure 3-1. Memory locations are shown in the shaded areas and the contents of these shaded areas are shown to the right. These modes include single-chip, expanded multiplexed, special bootstrap, and special test.

Single-chip operating modes do not generate external addresses. Refer to Table 3-1 for a full list of the registers.


AB MEM MAP
Figure 3-1. Memory Maps

Table 3-1. Register and Control Bit Assignments (Sheet 1 of 2)


Table 3-1. Register and Control Bit Assignments (Sheet 2 of 2)


In expanded multiplexed operating modes, memory locations are basically the same as the singlechip operating modes; however, the locations between the shaded areas (designated EXT) are for externally addressed memory and I/O. If an external memory or I/O device is located to overlap an enabled internal resource, the internal resource will take priority. For reads of such an address the data (if any) driving the port $C$ data inputs is ignored and will not result in any harmful conflict with the internal read. For writes to such an address data is driven out of the port C data pins as well as to the internal location. No external devices should drive port C during write accesses to internal locations; however, there is normally no conflict since the external address decode and/ or data direction control should incorporate the $R / \bar{W}$ signal in their development. The $R / \bar{W}, A S$, address, and write data signals are valid for all accesses including accesses to internal memory and registers.

The special bootstrap operating mode memory locations are similar to the single-chip operating mode memory locations except that a bootstrap program at memory locations \$BF40 through $\$ B F F F$ is enabled. The reset and interrupt vectors are addressed at \$BFCO-\$BFFF while in the special bootstrap operating mode. These vector addresses are within the 192 byte memory used for the bootstrap program.

The special test operating mode memory map is the same as the expanded multiplexed operating mode memory map except that the reset and interrupt vectors are located at external memory locations \$BFC0-\$BFFF.

### 3.2 RAM AND I/O MAPPING REGISTER (INIT)

There are 64 internal registers which are used to control the operation of the MCU. These registers can be relocated on 4 K boundaries within the memory space, using the INIT register. Refer to Table 3-1 for a complete list of the registers. The registers and control bits are explained throughout this document.

The INIT register is a special-purpose 8-bit register which may be used during initialization to change the default locations of RAM and control registers within the MCU memory map. It may be written to only once within the initial 64 E clock cycles after a reset and thereafter becomes a readonly register.

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | INIT |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \$103D | RAM3 | RAM2 | RAM1 | RAMO | REG3 | REG2 | REG1 | REGO |  |
| RESET | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 1 |  |

The default starting address for internal RAM is $\$ 0000$ and the default starting address for the 64 control registers is $\$ 1000$ (the INIT register is set to $\$ 01$ at reset). The upper four bits of the INIT register specify the starting address for the 256 byte RAM and the lower four bits of INIT specify the starting address for the 64 control registers. These four bits are matched to the upper four bits of the 16 -bit address.

Throughout this document, the control register addresses will be displayed with the high-order digit shown as a bold " 1 " to indicate that the register block may be relocated to some 4 K memory page other than its default position of $\$ 1000-\$ 103 F$.

Note that if the RAM is relocated to either \$E000 or \$F000, which is in conflict with the internal ROM, (no conflict if the ROMON bit in the configuration register is zero), RAM will take priority
and the conflicting ROM will become inaccessible. Also, if the 64 control registers are relocated so that they conflict with the RAM and/or ROM, then the 64 control registers take priority and the RAM and/or ROM at those locations become inaccessible. No harmful conflicts result, the lower priority resources simply become inaccessible. Similarly, if an internal resource conflicts with an external device no harmful conflict results. Data from the external device will not be applied to the internal data bus and cannot interfere with the internal read.

Note that there are unused register locations in the 64 byte control register block. Reads of these unused registers will return data from the undriven internal data bus and not from another resource that happens to be located at the same address.

### 3.3 ROM

The internal 8 K ROM occupies the highest 8 K of the memory map (\$E000-\$FFFF). This ROM is disabled when the ROMON bit in the CONFIG register is clear. The ROMON bit is implemented with an EEPROM cell and is programmed using the same procedures for programming the onchip EEPROM. For further information refer to 3.5.3 System Configuration Register (CONFIG).

In the single-chip operating mode, internal ROM is enabled regardless of the state of the ROMON bit.

There is also a 192 byte mask programmed boot ROM in the MC68HC11A8. This bootstrap program ROM controls the operation of the special bootstrap operating mode and is only enabled following reset in the special bootstrap operating mode. For more information refer to 2.2.3 Special Bootstrap Operating Mode.

### 3.4 RAM

The 256 byte internal RAM may be relocated during initialization by writing to the INIT register. The reset default position is $\$ 0000$ through $\$ 00 F F$. This RAM is implemented with static cells and retains its contents during the WAIT and STOP modes.

The contents of the 256 -byte RAM can also be retained by supplying a low current backup power source to the MODB/V ${ }_{\text {STBY }}$ pin. When using a standby power source, $\mathrm{V}_{\text {DD }}$ may be removed; however, $\overline{\text { RESET }}$ must go low before $\mathrm{V}_{\mathrm{DD}}$ is removed and remain low until $\mathrm{V}_{\mathrm{DD}}$ has been restored.

### 3.5 EEPROM

The 512 bytes of EEPROM are located at \$B600 through \$B7FF and have the same read cycle time as the internal ROM. The write (or programming) mechanism for the EEPROM is controlled by the PPROG register. The EEPROM is disabled when the EEON bit in the CONFIG register is zero. The EEON bit is implemented with an EEPROM cell.

The erased state of an EEPROM byte is \$FF. Programming changes ones to zeros. If any bit in a location needs to be changed from a zero to a one, the byte must be erased in a separate operation before it is reprogrammed. If a new data byte has no ones in bit positions which were already programmed to zero, it is acceptable to program the new data without erasing the EEPROM byte first. For example, programming $\$ 50$ to a location which was already $\$ 55$ would change the location to $\$ 50$.

Programming and erasure of the EEPROM relies on an internal high-voltage charge pump. At E clock frequencies below 2 MHz the efficiency of this charge pump decreases which increases the time required to program or erase a location. The recommended program and erase time is 10 milliseconds when the E clock is 2 MHz and should be increased to as much as 20 milliseconds when $E$ is between 1 MHz and 2 MHz . When the $E$ clock is below 1 MHz , the clock source for the charge pump should be switched from the system clock to an on-chip R-C oscillator clock. This is done by setting the CSEL bit in the OPTION register. A 10 millisecond period should be allowed after setting the CSEL bit to allow the charge pump to stabilize. Note that the CSEL bit also controls a clock to the analog-to-digital converter subsystem.

### 3.5.1 EEPROM Programming Control Register (PPROG)

This 8 -bit register is used to control programming and erasure of the 512-byte EEPROM. Reset clears this register so the EEPROM is configured for normal reads.

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | PPROG |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \$103B | ODD | EVEN | 0 | BYTE | ROW | ERASE | EELAT | EEPGM |  |
| RESET | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |

ODD — Program Odd Rows (TEST)
EVEN — Program Even Rows (TEST)
Bit 5 - Not implemented.
This bit always reads zero.
BYTE - Byte Erase Select
This bit overrides the ROW bit.
$0=$ Row or Bulk Erase
1 = Erase Only One Byte
ROW - Row Erase Select
If the BYTE bit is 1, ROW has no meaning.
0 = Bulk Erase
1 = Row Erase
ERASE - Erase Mode Select
$0=$ Normal Read or Program
1 = Erase Mode
EELAT - EEPROM Latch Control
$0=$ EEPROM Address and Data Configured for Read Mode
1 = EEPROM Address and Data Configured for Programming/Erasing
EEPGM - EEPROM Programming Voltage Enable
0 = Programming Voltage Switched Off
1 = Programming. Voltage Turned On

If an attempt is made to set both the EELAT and EEPGM bits in the same write cycle, neither will be set. If a write to an EEPROM address is performed while the EEPGM bit is set, the write is ignored and the programming operation currently in progress is not disturbed. These two safeguards were included to prevent accidental EEPROM changes in cases of program runaway. Mask sets A38P, A49N, and date codes before 86xx did not have these safeguards.

### 3.5.2 Programming/Erasing Internal EEPROM

The EEPROM programming and erasure process is controlled by the PPROG register. The following paragraphs describe the various operations performed on the EEPROM and include example program segments to demonstrate programming and erase operations.

These program segments are intended to be simple straightforward examples of the sequences needed for basic program and erase operations. There are no special restrictions on the address modes used and bit manipulation instructions may be used. Other MCU operations can continue to be performed during EEPROM programming and erasure provided these operations do not include reads of data from EEPROM (the EEPROM is disconnected from the read data bus during EEPROM program and erase operations). The subroutine DLY10 used in these program segments is not shown but can be any set of instructions which takes ten milliseconds.
3.5.2.1 READ. For the read operation the EELAT bit in the PPROG register must be clear. When this bit is cleared, the remaining bits in the PPROG register have no meaning or effect, and the EEPROM may be read as if it were a normal ROM.
3.5.2.2 PROGRAMMING. During EEPROM programming, the ROW and BYTE bits are not used. If the E clock frequency is 1 MHz or less, the CSEL bit in the OPTION register must be set. Recall that in this EEPROM, zeros must be erased by a separate erase operation before programming. The following program segment demonstrates how to program an EEPROM byte.

```
* On entry, A = data to be programmed and X = EEPROM address
    * crern
    STAB $103B Set EELAT Bit (EEPGM = 0)
    STAA 0,X Store Data to EEPROM Address
    LDAB #$03
    STAB $103B Set EEPGM Bit (EELAT = 1)
    JSR DLY10 Delay 10 ms
    CLR $103B Turn Off High Voltage and Set to READ Mode
        •
        -
            \bullet
```

3.5.2.3 BULK ERASE. The following program segment demonstrates how to bulk erase the 512-byte EEPROM. The CONFIG register is not affected in this example.

3.5.2.4 ROW ERASE. The following program segment demonstrates the row erase function. A 'row' is sixteen bytes (\$B600-\$B60F, \$B610-\$B61F... \$B7F0-\$B7FF). This type of erase operation saves time compared to byte erase when large sections of EEPROM are to be erased.

```
*On entry X = any address in the row to be erased
    •
    \bullet
ROWE LDAB #$0E
    STAB $103B Set to Row Erase Mode
    STAB 0,X Write any Data to any Address in Row
    LDAB #$0F
    STAB $103B Turn on High Voltage
    JSR DLY10 Delay 10 ms
    CLR $103B Turn Off High Voltage and Set to Read Mode
    \bullet
    -
    •
```

3.5.2.5 BYTE ERASE. The following program segment shows the byte erase function.
*On entry, $X=$ address of byte to be erased

| BYTEE | LDAB | \#\$16 |  |
| :---: | :---: | :---: | :---: |
|  | STAB | \$103B | Set to Byte Erase Mode |
|  | STAB | 0, X | Write any Data to the Address to Erase |
|  | LDAB | \#\$17 |  |
|  | STAB | \$103B | Turn on High Voltage |
|  | JSR | DLY10 | Delay 10 ms |
|  | CLR | \$103B | Turn off High Voltage and Set to Read Mode |

### 3.5.3 System Configuration Register (CONFIG)

The MC68HC11A8 can be configured to specific system requirements through the use of hardwired options such as the mode select pins, semi-permanent EEPROM control bit specifications (CONFIG register), or by use of control registers. The configuration control register (CONFIG) is implemented in EEPROM cells and controls the presence of ROM and EEPROM in the memory map, as well as enabling the COP watchdog system. A security feature to protect data in the EEPROM and RAM is also available on mask programmed MC68HC11A8s.


Bits 7, 6, 5, and 4 - Not Implemented These bits are always read as zero.

NOSEC - Security Mode Disable Bit
This bit is only implemented if it is specifically requested at the time mask ROM information is submitted. When this bit is not implemented it always reads one.
When RAM and EEPROM security are required, the NOSEC bit can be programmed to zero to enable the software anti-theft mechanism. When clear, the NOSEC bit prevents the selection of expanded multiplexed operating modes. If the MCU is reset in the special bootstrap operating mode while NOSEC is zero, EEPROM, RAM, and CONFIG are erased before the loading process continues.
$0=$ Enable Security Mode
1 = Disable Security Mode
NOCOP - COP System Disable
$0=$ COP Watchdog System Enabled
1 = COP Watchdog System Disabled
ROMON - Enable On-Chip ROM
When this bit is clear, the 8K ROM is disabled, and that memory space becomes externally accessed space. In the single-chip operating mode, the internal 8 K ROM is enabled regardless of the state of the ROMON bit.
EEON - Enable On-Chip EEPROM
When this bit is clear, the 512-byte EEPROM is disabled, and that memory space becomes externally accessed space.
3.5.3.1 PROGRAMMING AND ERASURE OF THE CONFIG REGISTER. Since the CONFIG register is implemented with EEPROM cells, special provisions must be made to erase and program this register. The normal EEPROM control bits in the PPROG register are used for this purpose. Programming follows the same procedure as programming a byte in the 512-byte EEPROM except the CONFIG register address is used. Erase also follows the same procedure as that used for the EEPROM except that only bulk erase can be used on the CONFIG register. When the CONFIG register is erased, the 512-byte EEPROM array is also erased. Be sure to check the Technical Summary for the particular MC68HC11 Family member you are using.

On mask set B96D and newer, the CONFIG register may only be programmed or erased while the MCU is operating in the test mode or the bootstrap mode. This interlock was added to help prevent accidental changes to the CONFIG register.

The following program segment demonstrates how to program the CONFIG register. This program assumes that the CONFIG register was previously erased.

```
*On entry, A = data to be programmed onto CONFIG
    \bullet
    •
    •
PROGC LDAB #$02
    STAB $103B Set EELAT Bit (EEPGM = 0)
    STAA $103F Store Data to CONFIG Address
    LDAB #$03
    STAB $103B Turn on Programming Voltage
    JSR DLY10 Delay 10 ms
    CLR $103B Turn Off High Voltage and Set to READ Mode
            •
            \bullet
            •
```

The following program segment demonstrates the erase procedure for the CONFIG register.


```
    STAB $103F Write any Data to CONFIG
    LDAB #$07
    STAB $103B Turn on Programming Voltage
    JSR DLY10 Delay 10 ms
    CLR $103B Turn Off High Voltage and Set to READ Mode
```

3.5.3.2 OPERATION OF THE CONFIGURATION MECHANISM. The CONFIG register consists of an EEPROM byte and static working latches. This register controls the start-up configuration of the MCU. The contents of the EEPROM CONFIG byte are transferred into static working latches during any reset sequence. The operation of the MCU is controlled directly by these latches and not the actual EEPROM byte. Changes to the EEPROM byte do not affect operation of the MCU until after the next reset sequence. When programming the CONFIG register, the EEPROM byte is being accessed. When the CONFIG register is being read, the static latches are being accessed.

To change the value in the CONFIG register proceed as follows:

1) Erase the CONFIG register.

## CAUTION

Do not issue a reset at this time.
2) Program the new value to the CONFIG register.
3) Issue a reset so the new configuration will take effect.

## SECTION 4 PARALLEL I/O

The MC68HC11A8 has $40 \mathrm{I} / \mathrm{O}$ pins arranged as five 8 -bit ports. All of these pins serve multiple functions depending on the operating mode and data in the control registers. This section explains the operation of these pins only when they are used for parallel I/O.

Ports $C$ and $D$ are used as general purpose input and/or output pins under direct control of their respective data direction registers. Ports A, B, and E, with the exception of port A pin 7, are fixed direction inputs or outputs and therefore do not have data direction registers. Port B, port C , the STRA pin, and the STRB pin are used for strobed and/or handshake modes of parallel I/O, as well as general purpose I/O.

### 4.1 GENERAL PURPOSE I/O (PORTS C AND D)

Each port I/O line has an associated bit in a specific port data register and port data direction register. The data direction register bits are used to specify the primary direction of data for each I/O line. When an output line is read, the value at the input to the pin driver is returned. When a line is configured as an input, that pin becomes a high-impedance input. If a write is executed to an input line, the value does not affect the I/O pin, but is stored in an internal latch. When the line becomes an output, this value appears at the I/O pin. Data direction register bits are cleared by reset to configure $\mathrm{I} / \mathrm{O}$ pins as inputs.

The AS and $R / \bar{W}$ pins are dedicated to bus control while in the expanded multiplexed operating modes, or parallel I/O strobes (STRA and STRB) while in the single chip operating modes.

### 4.2 FIXED DIRECTION I/O (PORTS A, B, AND E)

The lines for ports A, B, and E (except for port A bit 7) have fixed data directions. When port A is being used for general purpose I/O, bits 0,1 , and 2 are configured as input only and writes to these lines have no effect. Bits $3,4,5$, and 6 of port A are configured as output only and reads of these lines return the levels sensed at the input to the line drivers. Port A bit 7 can be configured as either a general-purpose input or output using the DDRA7 bit in the pulse accumulator control register. When port $B$ is being used for general purpose output, it is configured as output only and reads of these lines will return the levels sensed at the input of the pin drivers. Port E contains the eight A/D channel inputs, but these lines may also be used as general purpose digital inputs. Writes to the port E address have no effect.

### 4.3 SIMPLE STROBED I/O

The simple strobed mode of parallel I/O is invoked and controlled by the parallel I/O control register (PIOC). This mode is selected when the handshake bit (HNDS) in the PIOC register is clear. Port C becomes a strobed input port with the STRA line as the edge-detecting latch command input. Also, port B becomes a strobed output port with the STRB line as the output strobe. The logic sense of the STRB output is selected by the invert strobe B bit (INVB) in the PIOC register.

### 4.3.1 Strobed Input Port C

In this mode, there are two addresses where port C may be read, the PORTC data register and the alternate latched port C register (PORTCL). The data direction register still controls the data direction of all port C lines. Even when the strobed input mode is selected, any or all of the port C lines may still be used for general purpose I/O.

The STRA line is used as an edge-detecting input, and the edge-select for strobe A (EGA) bit in the PIOC register defines either falling or rising edge as the significant edge. Whenever the selected edge is detected at the STRA pin, the current logic levels at port C lines are latched into the PORTCL register and the strobe A flag (STAF) in the PIOC register is set. If the strobe A interrupt enable (STAI) bit in PIOC is also set, an internal interrupt sequence is requested. The strobe A flag (STAF) is automatically cleared by reading the PIOC register (with STAF set) followed by a read of the PORTCL register. Data is latched in the PORTCL register whether or not the STAF flag was previously clear.

### 4.3.2 Strobed Output Port B

In this mode, the STRB pin is a strobe output which is pulsed for two E clock periods each time there is a write to port B . The INVB bit in the PIOC register controls the polarity of the pulse on the STRB line.

### 4.4 FULL HANDSHAKE I/O

The full handshake modes of parallel I/O involve port C and the STRA and STRB lines. There are two basic modes (input and output) and an additional variation on the output handshake mode that allows three-stated operation of port C. In all handshake modes, STRA is an edge-detecting input, and STRB is a handshake output line.

When full input handshake protocol is specified, both general purpose input and/or general purpose output can coexist at port C . When full output handshake protocol is specified, general purpose output can coexist with the handshake outputs at port C , but the three-state feature of the output handshake mode interferes with general purpose input in two ways. First, in full output handshake, the port C lines are outputs whenever STRA is at its active level regardless of the data direction register bits. This potentially conflicts with any external device trying to drive port $C$ unless that external device has an open-drain type output driver. Second, the value returned on reads of port $C$ is the state of the outputs of an internal port $C$ output latch regardless of the states of the data direction register bits, so that the data written for output handshake can be read even if the pins are in a three-state condition.

### 4.4.1 Input Handshake Protocol

In the input handshake protocol, port C is a latching input port, STRA is an edge-sensitive latch command from the external system that is driving port C, and STRB is a "ready" output line controlled by logic in the MCU.

When a "ready" condition is recognized, the external device places data on the port $C$ lines, then pulses the STRA line. The active edge on the STRA line latches the port C data into the PORTCL register, sets the STAF flag (optionally causing an interrupt), and deasserts the STRB line. Deassertion of the STRB line automatically inhibits the external device from strobing new data into port C.

Reading the PORTCL latch register (independent of clearing the STAF flag) asserts the STRB line, indicating that new data may now be applied to port C.

The STRB line can be configured (with the PLS control bit) to be a pulse output (pulse mode) or a static output (interlocked mode).

The port $C$ data direction register bits should be cleared for each line that is to be used as a latched input line. However, some port C lines can be used as latched inputs with the input handshake protocol while, at the same time, using some port C lines as static inputs, and some port C lines as static outputs. The input handshake protocol has no effect on the use of port C lines as static inputs or as static outputs. Reads of the PORTC data register always return the static logic level at the port C lines (for lines configured as inputs). Writes to either the PORTC data register or the alternate latched port $C$ register (PORTCL) send information to the same port C output register without affecting the input handshake strobes.

### 4.4.2 Output Handshake Protocol

In the output handshake protocol, port C is an output port, STRB is a "ready" output, and STRA is an edge-sensitive acknowledge input signal, used to indicate to the MCU that the output data has been accepted by the external device. In a variation of this output handshake protocol, STRA is also used as an output-enable input, as well as an edge-sensitive acknowledge input.

The MCU places data on the port C output lines and then indicates stable data is available by asserting the STRB line. The external device then processes the available data and pulses the STRA line to indicate that new data may be placed on the port $C$ output lines. The active edge on the STRA line causes the STRB line to be deasserted and the STAF status flag to be set. In response to the STAF bit being set, the program transfers new data out of port C as required. Writing data to the PORTCL register causes the data to appear on port C lines and asserts the STRB line.

There is a variation to the output handshake protocol that allows three-state operation on port C . It is possible to directly connect this 8 -bit parallel port to other three-state devices with no additional parts.

While the STRA input line is inactive, all port C lines obey the data direction specified by the data direction register so that lines which are configured as inputs are high impedance. When the STRA line is activated, all port C lines are forced to outputs regardless of the data in the data direction register. Note that in output handshake protocol, reads of port $C$ always return the value sensed at the input to the output buffer regardless of the state of the data direction register bits because the lines would not necessarily have meaningful data on them in the three-state variation of this protocol. This operation makes it impractical to use some port C lines as static inputs, while using others as handshake outputs, but does not interfere with the use of some port C lines as static outputs. Port C lines intended as static outputs or normal handshake outputs should have their corresponding data direction register bits set, and lines intended as three-state handshake outputs should have their corresponding data direction register bits clear.

### 4.5 PARALLEL I/O CONTROL REGISTER (PIOC)

The parallel handshake I/O functions are available only in the single-chip operating mode. The PIOC is a read/write register except for bit 7 which is read only. Table $4-1$ shows a summary of handshake I/O operations.

Table 4-1. Handshake I/O Operations Summary

|  | STAI | CWOM | INVB |
| :---: | :--- | :--- | :--- |
| 0 | STAF Interrupts <br> Inhibited | Port C Outputs <br> Normal | STRB Active <br> Low |
| 1 | STAF Interrupts <br> Enabled | Port C Outputs <br> Open-Drain | STRB Active <br> High |


|  | STAF <br> Clearing Sequence ${ }^{1}$ | HNDS | OIN | PLS | EGA | Port C | Port B |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Simple Strobe Mode | Read PIOC with STAF = 1 then Read PORTCL | 0 | X | X |  | Inputs latched into PORTCL on any active edge on STRA. | STRB pulses on writes to port B. |
| Full Input Handshake | Read PIOC with STAF = 1 then Read PORTCL | 1 | 0 | $\begin{array}{\|c\|} 0= \\ \text { STRB } \\ \text { Active } \\ \text { Level } \\ 1= \\ \text { STRB } \\ \text { Active } \\ \text { Pulse } \end{array}$ |  | Inputs latched into PORTCL on any active edge on STRA. | Normal output port. Unaffected in handshake modes |
| Full Output Handshake | Read PIOC with STAF $=1$ then Write to PORTCL | 1 | 1 | $0=\begin{array}{r} \text { STRB } \\ \text { Active } \\ \text { Level } \\ 1=\begin{array}{l} \text { STRB } \\ \text { Active } \\ \text { Pulse } \end{array} \end{array}$ |  | Driven as outputs if STRA at active level. <br> Follows DDRC if STRA not at active level. | Normal output port. Unaffected in handshake modes |

NOTE:

1. Set by active edge on STRA
$\$ 1002$
RESET
 PIOC

## STAF - Strobe A Interrupt Status Flag

This bit is set when a selected edge occurs on strobe A. Clearing it depends on the state of HNDS and OIN bits. In simple strobed mode or in full input handshake mode, STAF is cleared by reading the PIOC register with STAF set followed by reading the PORTCL register. In output handshake, STAF is cleared by reading the PIOC register with STAF set followed by writing to the PORTCL register.

STAI - Strobe A Interrupt Enable Mask
When the I bit in the condition code register is clear and STAI is set, STAF (when set) will request an interrupt.

## CWOM - Port C Wire-OR Mode

CWOM affects all eight port C pins together
$0=$ Port C outputs are normal CMOS outputs
$1=$ Port C outputs act as open-drain outputs

HNDS - Handshake Mode
When clear, strobe A acts as a simple input strobe to latch data into PORTCL, and strobe B acts as a simple output strobe which pulses after a write to port $B$. When set, a handshake protocol involving port C, STRA, and STRB is selected (see the definition for the OIN bit).
$0=$ Simple strobe mode
1 = Full input or output handshake mode
OIN — Output or Input Handshaking
This bit has no meaning when HNDS $=0$.
$0=$ Input handshake
1 = Output handshake
PLS - Pulse/Interlocked Handshake Operation
This bit has no meaning if HNDS $=0$. When interlocked handshake operation is selected, strobe B, once activated, stays active until the selected edge of strobe A is detected. When pulsed handshake operation is selected, strobe $B$ is pulsed for two $E$ cycles.
$0=$ Interlocked handshake select
1 = Pulsed handshake selected
EGA - Active Edge for Strobe A
$0=$ Falling edge of STRA is selected. When output handshake is selected, port C lines obey the data direction register while STRA is low, but port C is forced to output when STRA is high.
$1=$ Rising edge of STRA is selected. When output handshake is selected, port C lines obey the data direction register while STRA is high, but port C is forced to output when STRA is low.

INVB - Invert Strobe B
$0=$ Active level is logic zero
1 = Active level is logic one

## SECTION 5 SERIAL COMMUNICATIONS INTERFACE (SCI)

This section contains a description of the serial communication interface (SCI).

### 5.1 OVERVIEW AND FEATURES

A full-duplex asynchronous Serial Communications Interface (SCI) is provided with a standard NRZ format (one start bit, eight or nine data bits, and one stop bit) and a variety of baud rates. The SCI transmitter and receiver are functionally independent, but use the same data format and bit rate. "Baud" and "bit rate" are used synonymously in the following description.

## SCI Two-Wire System Features

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


## SCI Receiver Features

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


## SCI Transmitter Features

- Transmit data register empty flag.
- Transmit complete flag.
- Send break.


### 5.2 DATA FORMAT

Receive data or transmit data is the serial data which is transferred to the internal data bus from the receive data input pin (RxD), or from the internal bus to the transmit data output pin (TxD).

The non-return-to-zero (NRZ) data format shown in Figure 5-1 is used and must meet the following criteria:

1) The idle line is brought to a logic one state prior to transmission/reception of a character.
2) A start bit (logic zero) is used to indicate the start of a frame.
3) The data is transmitted and received least-significant-bit first.
4) A stop bit (logic one) is used to indicate the end of a frame. A frame consists of a start bit, a character of eight or nine data bits, and a stop bit.
5) A break is defined as the transmission or reception of a low (logic zero) for at least one complete frame time.


* CONTROL BIT M IN SCCR1 SELECTS EITHER 8-BIT OR 9-BIT DATA.

Figure 5-1. Data Format

### 5.3 WAKE-UP FEATURE

The receiver wake-up feature reduces SCI service overhead in multiple receiver systems. Software in each receiver evaluates the first character(s) of each message. If the message is intended for a different receiver, the SCI can be placed in a sleep mode so that the rest of the message will not generate requests for service. Whenever a new message is started, logic in the sleeping receivers causes them to wake up so they can evaluate the initial character(s) of the new message.

A sleeping SCI receiver can be configured (using the WAKE control bit in serial communications control register 1 (SCCR1)) to wake up using either of two methods: idle line wake up or address mark wake up.

In idle line wake up, a sleeping receiver wakes up as soon as the RxD line becomes idle. Idle is defined as a continuous logic high on the RxD line for ten (or eleven) full bit times. Systems using this type of wake up must provide at least one character time of idle between messages to wake up sleeping receivers but must not allow any idle time between characters within a message.

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

### 5.4 RECEIVE DATA (RxD)

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

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


SCI BIT SAMPLING
Figure 5-2. Sampling Technique Used on All Bits

### 5.5 START BIT DETECTION

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

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

If the receiver detects that a break produced the framing error, the start bit will not be artificially induced and the receiver must actually detect a logic one before the start bit can be recognized. See Figure 5-5.


SCI SAMPLE EX

Figure 5-3. Examples of Start Bit Sampling Techniques

(a) Case 1, Receive Line Low During Artificial Edge

(b) Case 2, Receive Line High During Expected Start Edge

Figure 5-4. SCI Artificial Start Following a Framing Error


Figure 5-5. SCI Start Bit Following a Break

### 5.6 TRANSMIT DATA (TxD)

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

### 5.7 FUNCTIONAL DESCRIPTION

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

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

When the SCDR is read, it contains the last data byte received, provided that the receiver is enabled. The RDRF bit of the SCSR is set to indicate that a data byte has been transferred from the input serial shift register to the SCDR, which can cause an interrupt if the receiver interrupt is enabled. The data transfer from the input serial shift register to the SCDR is synchronized by the receiver bit rate clock. The OR (over-run), NF (noise), or FE (framing) error bits of the SCSR may be set if data reception errors occurred.

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

### 5.8 SCI REGISTERS

There are five registers used in the serial communications interface and the operation of these registers is discussed in the following paragraphs. Reference should be made to the block diagram shown in Figure 5-6.

### 5.8.1 Serial Communications Data Register (SCDR)

The serial communications data register performs two functions; i.e., it acts as the receive data register when it is read and as the transmit data register when it is written. Figure 5-6 shows this register as two separate registers, namely: the receive data register and the transmit data register.


Figure 5-6. Serial Communications Interface Block Diagram

### 5.8.2 Serial Communications Control Register 1 (SCCR1)

The serial communications control register 1 (SCCR1) provides the control bits which: (1) determine the word length, and (2) select the method used for the wake-up feature.


## R8 - Receive Data Bit 8

If the $M$ bit is set, this bit provides a storage location for the ninth bit in the receive data character.

## T8 -Transmit Data Bit 8

If the $M$ bit is set, this bit provides a storage location for the ninth bit in the transmit data character. It is not necessary to write to this bit for every character transmitted, only when the sense is to be different than that for the previous character.

Bit 5 - Not Implemented
This bit always reads zero.
M - SCI Character Length
$0=1$ start bit, 8 data bits, 1 stop bit
$1=1$ start bit, 9 data bits, 1 stop bit
WAKE - Wake Up Method Select
$0=$ Idle Line
1 = Address Mark
Bits 2-0 - Not Implemented
These bits always read zero.

### 5.8.3 Serial Communications Control Register 2 (SCCR2)

The serial communications control register 2 (SCCR2) provides the control bits which enable/disable individual SCI functions.


TIE - Transmit Interrupt Enable
$0=$ TDRE interrupts disabled
$1=\mathrm{SCI}$ interrupt if TDRE $=1$
TCIE - Transmit Complete Interrupt Enable
$0=$ TC interrupts disabled
$1=$ SCI Interrupt if TC = 1

RIE - Receive Interrupt Enable
$0=$ RDRF and OR interrupts disabled
$1=\mathrm{SCl}$ interrupt if RDRF or OR=1
ILIE — Idle Line Interrupt Enable
$0=$ IDLE interrupts disabled
$1=$ SCl interrupt if IDLE = 1

## TE - Transmit Enable

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

## RE - Receive Enable

When the receive enable bit is set, the receiver is enabled. When RE is clear, the receiver is disabled and all of the status bits associated with the receiver (RDRF, IDLE, OR, NF, and FE) are inhibited. While the receiver is enabled, the data direction register control for port $D$ bit 0 is overridden and the line is forced to be an input.
RWU - Receiver Wake Up
When the receiver wake-up bit is set by the user's software, it puts the receiver to sleep and enables the "wake up" function. If the WAKE bit is cleared, RWU is cleared by the SCI logic after receiving 10 $(M=0)$ or $11(M=1)$ consecutive ones. If the WAKE bit is set, RWU is cleared by the SCl logic after receiving a data word whose MSB is set.

## SBK - Send Break

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

### 5.8.4 Serial Communications Status Register (SCSR)

The serial communications status register (SCSR) provides inputs to the interrupt logic circuits for generation of the SCl system interrupt.


## TDRE - Transmit Data Register Empty

The transmit data register empty bit is set to indicate that the content of the serial communications data register have been transferred to the transmit serial shift register. This bit is cleared by reading the SCSR ( with TDRE $=1$ ) followed by a write to the SCDR.

TC - Transmit Complete
The transmit complete bit is set at the end of a data frame, preamble, or break condition if:

1) $T E=1, T D R E=1$, and no pending data, preamble, or break is to be transmitted; or
2) $\mathrm{TE}=0$, and the data, preamble, or break in the transmit shift register has been transmitted.

The TC bit is a status flag which indicates that one of the above conditions have occurred.
The TC bit is cleared by reading the SCSR (with TC set) followed by a write to the SCDR.
RDRF - Receive Data Register Full
The receive data register full bit is set when the receiver serial shift register is transferred to the SCDR. The RDRF bit is cleared when the SCSR is read (with RDRF set) followed by a read of the SCDR.

IDLE - Idle Line Detect
The idle line detect bit, when set, indicates the receiver has detected an idle line. The IDLE bit is cleared by reading the SCSR with IDLE set followed by reading SCDR. Once the IDLE status flag is cleared, it will not be set again until after the RxD line has been active and becomes idle again.

## OR - Overrun Error

The overrun error bit is set when the next byte is ready to be transferred from the receive shift register to the SCDR which is already full (RDRF bit is set). When an overrun error occurs, the data which caused the overrun is lost and the data which was already in SCDR is not disturbed. The OR is cleared when the SCSR is read (with OR set), followed by a read of the SCDR.

## NF - Noise Flag

The noise flag bit is set if there is noise on any of the received bits, including the start and stop bits. The NF bit is not set until the RDRF flag is set. The NF bit is cleared when the SCSR is read (with NF set), followed by a read of the SCDR.

FE - Framing Error
The framing error bit is set when no stop bit was detected in the received data character. The FE bit is set at the same time as the RDRF is set. If the byte received causes both framing and overrun errors, the processor will only recognize the overrun error. The framing error flag inhibits further transfer of data into the SCDR until it is cleared. The FE bit is cleared when the SCSR is read (with FE equal to one) followed by a read of the SCDR.

Bit 0 - Not Implemented
This bit always reads zero.

### 5.8.5 Baud Rate Register (BAUD)

The baud rate register selects the different baud rates which may be used as the rate control for the transmitter and receiver. The SCP0-SCP1 bits function as a prescaler for the SCR0-SCR2 bits. Together, these five bits provide multiple baud rate combinations for a given crystal frequency.

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \$102B | 7 | 6 | TCLR | 0 | SCP1 | SCP0 | RCKB | SCR2 |
| RESET | 0 | 0 | 0 | 0 | 0 | $U$ | $U$ | $U$ |
| BAUD |  |  |  |  |  |  |  |  |

TCLR - Clear Baud Rate Counters (Test) This bit is used to clear the baud rate counter chain during factory testing. TCLR is zero and cannot be set while in normal operating modes.
SCP1 and SCPO - SCI Baud Rate Prescaler Selects The E clock is divided by the factors shown in Table 5-1. This prescaled output provides an input to a divider which is controlled by the SCR2-SCR0 bits.

Table 5-1. First Prescaler Stage

| SCP1 | SCPO | Internal Processor <br> Clock Divide By |
| :---: | :---: | :---: |
| 0 | 0 | 1 |
| 0 | 1 | 3 |
| 1 | 0 | 4 |
| 1 | 1 | 13 |

SCR2, SCR1, and SCR0 - SCI Baud Rate Selects
These three bits select the baud rates for both the transmitter and the receiver. The prescaler output described above is further divided by the factors shown in Table 5-2.

Table 5-2. Second Prescaler Stage

| SCR2 | SCR1 | SCR0 | Prescaler Output <br> Divide By |
| :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 1 |
| 0 | 0 | 1 | 2 |
| 0 | 1 | 0 | 4 |
| 0 | 1 | 1 | 8 |
| 1 | 0 | 0 | 16 |
| 1 | 0 | 1 | 32 |
| 1 | 1 | 0 | 64 |
| 1 | 1 | 1 | 128 |

RCKB - SCI Baud Rate Clock Check (Test)
This bit is used during factory testing to enable the ex-clusive-OR of the receiver clock and transmitter clock to be driven out the TxD pin. RCKB is zero and cannot be set while in normal operating modes.

The diagram shown in Figure 5-7 and the data given in Tables 5-3 and 5-4 illustrate the divider chain used to obtain the baud rate clock. Note that there is a fixed rate divide-by-16 between the receive clock (RT) and the transmit clock ( Tx ). The actual divider chain is controlled by the combined SCP0-SCP1 and SCR0SCR2 bits in the baud rate register as illustrated.


Figure 5-7. Rate Generator Division

Table 5-3. Prescaler Highest Baud Rate Frequency Output

| SCP Bit |  | Clock* Divided By | Crystal Frequency (MHz) |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 1 | 0 |  | 12.0 | 8.3886 | 8.0 | 4.9152 | 4.0 | 3.6864 |
| 0 | 0 | 1 | 187.50 K Baud | 131.072 K Baud | 125.000 K Baud | 76.80 K Baud | 62.50 K Baud | 57.60 K Baud |
| 0 | 1 | 3 | 62.50 K Baud | 43.690 K Baud | 41.666 K Baud | 25.60 K Baud | 20.833 K Baud | 19.20 K Baud |
| 1 | 0 | 4 | 46.875 K Baud | 32.768 K Baud | 31.250 K Baud | 19.20 K Baud | 15.625 K Baud | 14.40 K Baud |
| 1 | 1 | 13 | 14.423 K Baud | 10.082 K Baud | 9600 Baud | 5.907 K Baud | 4800 Baud | 4430 Baud |

*The clock in the "Clock Divided By" column is the internal processor clock

## NOTE

The divided frequencies shown in Table 5-3 represent baud rates which are the highest transmit baud rate ( Tx ) that can be obtained by a specific crystal frequency and only using the prescaler division. Lower baud rates may be obtained by providing a further division using the SCI rate select bits as shown below for some representative prescaler outputs.

Table 5-4. Transmit Baud Rate Output for a Given Prescaler Output

| SCR Bit |  |  | Divided By | Representative Highest Prescaler Baud Rate Output |  |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 2 | 1 | 0 |  | 131.072 K Baud | 32.768 K Baud | 76.80 K Baud | 19.20 K Baud | 9600 Baud | 4800 Baud |
| 0 | 0 | 0 | 1 | 131.072 K Baud | 32.768 K Baud | 76.80 K Baud | 19.20 K Baud | 9600 Baud | 4800 Baud |
| 0 | 0 | 1 | 2 | 65.536 K Baud | 16.384 K Baud | 38.40 K Baud | 9600 Baud | 4800 Baud | 2400 Baud |
| 0 | 1 | 0 | 4 | 32.768 K Baud | 8.192 K Baud | 19.20 K Baud | 4800 Baud | 2400 Baud | 1200 Baud |
| 0 | 1 | 1 | 8 | 16.384 K Baud | 4.096 K Baud | 9600 Baud | 2400 Baud | 1200 Baud | 600 Baud |
| 1 | 0 | 0 | 16 | 8.192 K Baud | 2.048 K Baud | 4800 Baud | 1200 Baud | 600 Baud | 300 Baud |
| 1 | 0 | 1 | 32 | 4.096 K Baud | 1.024 K Baud | 2400 Baud | 600 Baud | 300 Baud | 150 Baud |
| 1 | 1 | 0 | 64 | 2.048 K Baud | 512 Baud | 1200 Baud | 300 Baud | 150 Baud | 75 Baud |
| 1 | 1 | 1 | 128 | 1.024 K Baud | 256 Baud | 600 Baud | 150 Baud | 75 Baud | - |

NOTE
Table 5-4 illustrates how the SCI select bits can be used to provide lower transmitter baud rates by further dividing the prescaler output frequency. The five examples are only representative samples. In all cases, the baud rates shown are transmit baud rates (transmit clock) and the receiver clock is 16 times higher in frequency than the actual baud rate.

## SECTION 6 <br> SERIAL PERIPHERAL INTERFACE (SPI)

This section contains a description on the serial peripheral interface (SPI).

### 6.1 OVERVIEW AND FEATURES

The serial peripheral interface (SPI) is a synchronous interface which allows several SPI microcontrollers or SPI-type peripherals to be interconnected. In a serial peripheral interface, separate wires (signals) are required for data and clock. In the SPI format, the clock is not included in the data stream and must be furnished as a separate signal. The MC68HC11A8 SPI system may be configured either as a master or as a slave.

Features include:

- Full Duplex, Three-Wire Synchronous Transfers
- Master or Slave Operation
- 1.5 MHz (Maximum) Master Bit Frequency
- 3 MHz (Maximum) Slave Bit Frequency
- Four Programmable Master Bit Rates
- Programmable Clock Polarity and Phase
- End-of-Transmission Interrupt Flag
- Write Collision Flag Protection
- Master-Master Mode Fault Protection
- Easily Interfaces to Simple Expansion Parts (PLLs, D/As, Latches, Display Drivers, etc.)


### 6.2 SPI SIGNAL DESCRIPTIONS

The four basic SPI signals (MISO, MOSI, SCK, and $\overline{\text { SS }}$ ) are discussed in the following paragraphs. Each signal is described for both the master and slave modes.

Any SPI output line has to have its corresponding data direction register bit set. If this bit is clear, the line is disconnected from the SPI logic and becomes a general-purpose input line. Any SPI input line is forced to act as an input regardless of what is in the corresponding data direction register bit.

### 6.2.1 Master In Slave Out (MISO)

The MISO line is configured as an input in a master device and as an output in a slave device. It is one of the two lines that transfer serial data in one direction, with the most significant bit sent first. The MISO line of a slave device is placed in the high-impedance state if the slave is not selected.

### 6.2.2 Master Out Slave In (MOSI)

The MOSI line is configured as an output in a master device and as an input in a slave device. It is one of the two lines that transfer serial data in one direction with the most significant bit sent first.

### 6.2.3 Serial Clock (SCK)

The serial clock is used to synchronize data movement both in and out of the device through its MOSI and MISO lines. The master and slave devices are capable of exchanging a byte of information during a sequence of eight clock cycles. Since SCK is generated by the master device, this line becomes an input on a slave device.

As shown in Figure 6-1, four possible timing relationships may be chosen by using control bits CPOL and CPHA in the serial peripheral control register (SPCR). Both master and slave devices must operate with the same timing. The master device always places data on the MOSI line a halfcycle before the clock edge (SCK), in order for the slave device to latch the data.
Two bits (SPRO and SPR1) in the SPCR of the master device select the clock rate. In a slave device, SPR0 and SPR1 have no effect on the operation of the SPI.

### 6.2.4 Slave Select ( $\overline{\mathrm{SS}}$ )

The slave select ( $\overline{\mathrm{SS}}$ ) input line is used to select a slave device. It has to be low prior to data transactions and must stay low for the duration of the transaction.

The $\overline{\mathrm{SS}}$ line on the master must be tied high. If it goes low, a mode fault error flag (MODF) is set in the serial peripheral status register (SPSR). The $\overline{\mathrm{SS}}$ pin can be selected to be a general-purpose


SPI TRANSFER FORMAT
Figure 6-1. Data Clock Timing Diagram
output by writing a one in bit 5 of the port D data direction register, thus disabling the mode fault circuit. The other three SPI lines are dedicated to the SPI whenever the SPI is on.

When CPHA $=0$, the shift clock is the OR of $\overline{\mathrm{SS}}$ with SCK. In this clock phase mode, $\overline{\mathrm{SS}}$ must go high between successive characters in an SPI message. When CPHA = 1, $\overline{\text { SS }}$ may be left low for several SPI characters. In cases where there is only one SPI slave MCU, its $\overline{\mathrm{SS}}$ line could be tied to $\mathrm{V}_{\mathrm{SS}}$ as long as CPHA $=1$ clock modes are used.

### 6.3 FUNCTIONAL DESCRIPTION

Figure 6-2 shows a block diagram of the serial peripheral interface circuitry. When a master device transmits data to a slave device via the MOSI line, the slave device responds by sending data to the master device via the master's MISO line. This implies full duplex transmission with both data out and data in synchronized with the same clock signal. Thus, the byte transmitted is replaced by the byte received and eliminates the need for separate transmit-empty and receiver-full status bits. A single status bit (SPIF) is used to signify that the I/O operation has been completed.

The SPI is double buffered on read, but not on write. If a write is performed during data transfer, the transfer occurs uninterrupted, and the write will be unsuccessful. This condition will cause the write collision (WCOL) status bit in the SPSR to be set. After a data byte is shifted, the SPIF flag of the SPSR is set.


Figure 6-2. Serial Peripheral Interface Block Diagram

In the master mode, the SCK pin is an output. It idles high or low, depending on the CPOL bit in the SPCR, until data is written to the shift register, at which point eight clocks are generated to shift the eight bits of data and then SCK goes idle again.

In a slave mode, the slave start logic receives a logic low at the $\overline{S S}$ pin and a clock input at the SCK pin. Thus, the slave is synchronized with the master. Data from the master is received serially at the slave MOSI line and loads the 8 -bit shift register. After the 8 -bit shift register is loaded, its data is parallel transferred to the read buffer. During a write cycle, data is written into the shift register, then the slave waits for a clock train from the master to shift the data out on the slave's MISO line.

Figure 6-3 illustrates the MOSI, MISO, SCK, and $\overline{\text { SS }}$ master-slave interconnections.
Due to data direction register control of SPI outputs and the port D wire-OR mode (DWOM) option, the SPI system can be configured in a variety of ways. Systems with a single bidirectional data path rather than separate MISO and MOSI paths can be accommodated. Since MC68HC11A8 SPI slaves can selectively disable their MISO output, a broadcast message protocol is also possible.


DUAL-MCU SPI CONN
Figure 6-3. Serial Peripheral Interface Master-Slave Interconnection

### 6.4 SPI REGISTERS

There are three registers in the serial peripheral interface which provide control, status, and data storage functions. These registers are called the serial peripheral control register (SPCR), serial peripheral status register (SPSR), and serial peripheral data I/O register (SPDR) and are described in the following paragraphs.

### 6.4.1 Serial Peripheral Control Register (SPCR)



SPIE - Serial Peripheral Interrupt Enable
$0=$ SPIF interrupts disabled
$1=$ SPI interrupt if SPIF =1
SPE - Serial Peripheral System Enable
$0=$ SPI system off
1 = SPI system on

DWOM - Port D Wire-OR Mode Option
DWOM affects all six port D pins together.
$0=$ Port D outputs are normal CMOS outputs
1 = Port D outputs act as open-drain outputs
MSTR — Master Mode Select
$0=$ Slave mode
1 = Master mode
CPOL - Clock Polarity
When the clock polarity bit is cleared and data is not being transferred, a steady state low value is produced at the SCK pin of the master device. Conversely, if this bit is set, the SCK pin will idle high. This bit is also used in conjunction with the clock phase control bit to produce the desired clock-data relationship between master and slave. See Figure 6-1.
CPHA - Clock Phase
The clock phase bit, in conjunction with the CPOL bit, controls the clock-data relationship between master and slave. The CPOL bit can be thought of as simply inserting an inverter in series with the SCK line. The CPHA bit selects one of two fundamentally different clocking protocols. When CPHA $=0$, the shift clock is the OR of SCK with $\overline{\mathrm{SS}}$. As soon as $\overline{\mathrm{SS}}$ goes low the transaction begins and the first edge on SCK invokes the first data sample. When CPHA $=1$, the $\overline{\text { SS }}$ pin may be thought of as a simple output enable control. Refer to Figure 6-1.

## SPR1 and SPRO-SPI Clock Rate Selects

These two serial peripheral rate bits select one of four baud rates (Table 6-1) to be used as SCK if the device is a master; however, they have no effect in the slave mode.

Table 6-1. Serial Peripheral Rate Selection

| SPR1 | SPR0 | Internal Processor, <br> Clock Divide By |
| :---: | :---: | :---: |
| 0 | 0 | 2 |
| 0 | 1 | 4 |
| 1 | 0 | 16 |
| 1 | 1 | 32 |

### 6.4.2 Serial Peripheral Status Register (SPSR)

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | SPSR |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \$1029 | SPIF | WCOL | 0 | MODF | 0 | 0 | 0 | 0 |  |
| RESET | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |

## SPIF - SPI Transfer Complete Flag

The serial peripheral data transfer flag bit is set upon completion of data transfer between the processor and external device. If SPIF goes high, and if SPIE is set, a serial peripheral interrupt is generated. Clearing the SPIF bit is accomplished by reading the SPSR (with SPIF set) followed by an access of the SPDR. Unless SPSR is read (with SPIF set) first, attempts to write to SPDR are inhibited.
WCOL — Write Collision
The write collision bit is set when an attempt is made to write to the serial peripheral data register while data transfer is taking place. If CPHA is zero a transfer is said to begin when $\overline{S S}$ goes low and the transfer ends when SS goes high after eight clock cycles on SCK. When CPHA is one a transfer is said to begin the first time SCK becomes active while $\overline{\text { SS }}$ is low and the transfer ends when the SPIF flag gets set. Clearing the WCOL bit is accomplished by reading the SPSR (with WCOL set) followed by an access to SPDR.

Bit 5 - Not Implemented
This bit always reads zero.
MODF - Mode Fault
The mode fault flag indicates that there may have been a multi-master conflict for system control and allows a proper exit from system operation to a reset or default system state. The MODF bit is normally clear, and is set only when the master device has its $\overline{S S}$ pin pulled low. Setting the MODF bit affects the internal serial peripheral interface system in the following ways.

1) An SPI interrupt is generated if SPIE $=1$.
2) The SPE bit is cleared. This disables the SPI.
3) The MSTR bit is cleared, thus forcing the device into the slave mode.
4) DDRD bits for the four SPI pins are forced to zeros.

Clearing the MODF bit is accomplished by reading the SPSR (with MODF set), followed by a write to the SPCR. Control bits SPE and MSTR may be restored by user software to their original state after the MODF bit has been cleared. It is also necessary to restore DDRD after a mode fault.
Bits 3-0 - Not Implemented
These bits always read zero.

### 6.4.3 Serial Peripheral Data I/O Register (SPDR)

The serial peripheral data I/O register is used to transmit and receive data on the serial bus. Only a write to this register will initiate transmission/reception of another byte, and this will only occur in the master device. At the completion of transmitting a byte of data, the SPIF status bit is set in both the master and slave devices.

When the user reads the serial peripheral data I/O register, a buffer is actually being read. The first SPIF must be cleared by the time a second transfer of data from the shift register to the read buffer is initiated or an overrun condition will exist. In cases of overrun the byte which causes the overrun is lost.

A write to the serial peripheral data I/O register is not buffered and places data directly into the shift register for transmission.

## SECTION 7 ANALOG-TO-DIGITAL CONVERTER

The MC68HC11A8 includes an 8-channel, multiplexed-input, successive approximation, analog-to-digital (A/D) converter with sample and hold to minimize conversion errors caused by rapidly changing input signals. Two dedicated lines ( $\mathrm{V}_{\mathrm{RL}}, \mathrm{V}_{\mathrm{RH}}$ ) are provided for the reference voltage inputs. These pins may be connected to a separate or isolated power supply to ensure full accuracy of the A/D conversion. The 8 -bit A/D converter has a total error of $\pm 1$ LSB which includes $\pm 1 / 2$ LSB of quantization error and accepts analog inputs which range from $\mathrm{V}_{\mathrm{RL}}$ to $\mathrm{V}_{\mathrm{RH}}$. Smaller analog input ranges can also be obtained by adjusting $\mathrm{V}_{\mathrm{RH}}$ and $\mathrm{V}_{\mathrm{RL}}$ to the desired upper and lower limits. Conversion is specified and tested for $\mathrm{V}_{\mathrm{RL}}=0 \mathrm{~V}$ and $\mathrm{V}_{\mathrm{RH}}=5 \mathrm{~V} \pm 10 \%$; however, laboratory characterization over the full temperature range indicates little or no degradation with $\mathrm{V}_{\mathrm{RH}}-\mathrm{V}_{\mathrm{RL}}$ as low as 2.5 to 3 V . The A/D system can be operated with $\mathrm{V}_{\mathrm{RH}}$ below $\mathrm{V}_{\mathrm{DD}}$ and/or $\mathrm{V}_{\mathrm{RL}}$ above $\mathrm{V}_{\mathrm{SS}}$ as long as $\mathrm{V}_{\mathrm{RH}}$ is above $\mathrm{V}_{\mathrm{RL}}$ by enough to support the conversions ( 2.5 to 5.0 V ). Each conversion is accomplished in 32 MCU E clock cycles, provided the E clock rate is greater than 750 kHz . For systems which operate at clock rates less than 750 kHz , an internal R-C oscillator must be used to clock the A/D system. The internal R-C oscillator is selected by setting the CSEL bit in the OPTION register.

## NOTE

Only four A/D input channels are available in the 48-pin version.

### 7.1 CONVERSION PROCESS

The A/D converter is ratiometric. An input voltage equal to $\mathrm{V}_{\mathrm{RL}}$ converts to $\$ 00$ and an input voltage equal to $\mathrm{V}_{\mathrm{RH}}$ converts to \$FF (full scale), with no overflow indication. For ratiometric conversions, the source of each analog input should use $\mathrm{V}_{\mathrm{RH}}$ as the supply voltage and be referenced to $\mathrm{V}_{\mathrm{RL}}$.
Figure 7-1 shows the detailed sequence for a set of four conversions. This sequence begins one E clock cycle after a write to the A/D control/status register (ADCTL). Figure 7-2 shows a model of the port $E$ A/D channel inputs. This model is useful for understanding the effects of external circuitry on the accuracy of $A / D$ conversions.

### 7.2 CHANNEL ASSIGNMENTS

A multiplexer allows the single A/D converter to select one of sixteen analog signals. Eight of these channels correspond to port E input lines to the MCU, four of the channels are for internal reference points or test functions, and four channels are reserved for future use. Table 7-1 shows the signals selected by the four channel select control bits.

### 7.3 SINGLE-CHANNEL OPERATION

There are two variations of single-channel operation. In the first variation (SCAN $=0$ ), the single selected channel is converted four consecutive times with the first result being stored in A/D result register 1 (ADR1) and the fourth result being stored in register ADR4. After the fourth conversion


Figure 7-1. A/D Conversion Sequence


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

Figure 7-2. A/D Pin Model
is complete, all conversion activity is halted until a new conversion command is written to the ADCTL register. In the second variation (SCAN = 1), conversions continue to be performed on the selected channel with the fifth conversion being stored in register ADR1 (overwriting the first conversion result), the sixth conversion overwrites ADR2, and so on.

### 7.4 MULTIPLE-CHANNEL OPERATION

There are two variations in multiple-channel operation. In the first variation (SCAN $=0$ ), the selected group of four channels are converted, one time each, with the first result being stored in register ADR1 and the fourth result being stored in register ADR4. After the fourth conversion is complete, all conversion activity is halted until a new conversion command is written to the ADCTL register. In the second variation (SCAN =1), conversions continue to be performed on the selected group of channels with the fifth conversion being stored in register ADR1 (replacing the earlier conversion result for the first channel in the group), the sixth conversion overwrites ADR2, and so on.

### 7.5 OPERATION IN STOP AND WAIT MODES

If a conversion sequence is still in process when either the STOP or WAIT mode is entered, the conversion of the current channel is suspended. When the MCU resumes normal operation, that channel will be re-sampled and the conversion sequence resumed. As the MCU exits the WAIT mode, the A/D circuits are stable and valid results can be obtained on the first conversion. However, in STOP mode, all analog bias currents are disabled and it becomes necessary to allow a stabilization period when leaving the STOP mode. If the STOP mode is exited with a delay, there will be enough time for these circuits to stabilize before the first conversion. If the STOP mode is exited with no delay (DLY bit in OPTION register equal to zero), sufficient time must be allowed for the A/D circuitry to stabilize to avoid invalid results (see 7.8 A/D POWER UP AND CLOCK SELECT).

### 7.6 A/D CONTROL/STATUS REGISTER (ADCTL)

All bits in this register may be read or written, except bit 7 which is a read-only status indicator and bit 6 which always reads as a zero.

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | ADCTL |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \$1030 | CCF | 0 | SCAN | MULT | CD | CC | CB | CA |  |
| RESET | 0 | 0 | U | U | U | U | U | U |  |

## CCF - Conversions Complete Flag

This read-only status indicator is set when all four A/D result registers contain valid conversion results. Each time the ADCTL register is written, this bit is automatically cleared to zero and a conversion sequence is started. In the continuous modes, conversions continue in a round-robin fashion and the result registers continue to be updated with current data even though the CCF bit remains set.

## NOTE

The user must write to register ADCTL to initiate conversion. To abort a conversion in progress, write to the ADCTL register and a new conversion sequence is initiated immediately.

Bit 6 - Not Implemented
This bit always reads zero.
SCAN - Continuous Scan Control
When this control bit is clear, the four requested conversions are performed once to fill the four result registers. When this control bit is set, conversions continue in a round-robin fashion with the result registers being updated as data becomes available.

MULT - Multiple-Channel/Single Channel Control
When this bit is clear, the A/D system is configured to perform four consecutive conversions on the single channel specified by the four channel select bits CD through CA (bits 3-0 of the ADCTL register). When this bit is set, the A/D system is configured to perform a conversion on each of four channels where each result register corresponds to one channel.

## CAUTION

When the multiple channel continuous scan mode is used, extra care is needed in the design of circuitry driving the A/D inputs. Refer to the A/D Pin Model and A/D Conversion Sequence figures in addition to the following discussion. The charge on the capacitive DAC array prior to the sample time is related to the voltage on the previously converted channel. A charge share situation exists between the internal DAC capacitance and the external circuit capacitance. Although the amount of charge involved is small the rate at which it is repeated is every 64 microseconds for an E clock of 2 MHz . The RC charging rate of the external circuit must be balanced against this charge sharing effect to avoid accuracy errors.
CD — Channel Select D
CC - Channel Select C
CB - Channel Select B
CA - Channel Select A
These four bits are used to select one of 16 A/D channels (see Table 7-1). When a multiple channel mode is selected (MULT = 1), the two least-significant channel select bits (CB and CA) have no meaning and the CD and CC bits specify which group of four channels are to be converted. The channels selected by the four channel select control bits are shown in Table 7-1.

Table 7-1. Analog-to-Digital Channel Assignments

| CD | CC | CB | CA | Channel Signal | Result in ADRx if MULT=1 |
| :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | 0 | 0 | ANO | 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 | 0 | 0 | Reserved | ADR1 |
| 1 | 0 | 0 | 1 | Reserved | ADR2 |
| 1 | 0 | 1 | 0 | Reserved | ADR3 |
| 1 | 0 | 1 | 1 | Reserved | ADR4 |
| 1 | 1 | 0 | 0 | $\mathrm{V}_{\mathrm{RH}} \mathrm{Pin}^{* *}$ | ADR1 |
| 1 | 1 | 0 | 1 | $\mathrm{V}_{\text {RL }} \mathrm{Pin}^{* *}$ | ADR2 |
| 1 | 1 | 1 | 0 | $\left(V_{\text {RH }}\right) / 2^{* *}$ | ADR3 |
| 1 | 1 | 1 | 1 | Reserved** | ADR4 |

*Not available in 48 -pin package versions.
**This group of channels used during factory test.

### 7.7 A/D RESULT REGISTERS 1, 2, 3, AND 4 (ADR1, ADR2, ADR3, AND ADR4)

The A/D result registers are read-only registers used to hold an 8 -bit conversion result. Writes to these registers have no effect. Data in the A/D result registers is valid when the CCF flag bit in the ADCTL register is set, indicating a conversion sequence is complete. If conversion results are needed sooner refer to Figure 7-1. For example the ADR1 result is valid 33 cycles after an ADCTL write. Refer to the A/D channel assignments in Table 7-1 for the relationship between the channels and the result registers.

### 7.8 A/D POWER UP AND CLOCK SELECT

A/D power up is controlled by bit 7 (ADPU) of the OPTION register. When ADPU is cleared, power to the A/D system is disabled. When ADPU is set, the A/D system is enabled. A delay of as much as 100 microseconds is required after turning on the $A / D$ converter to allow the analog bias voltages to stabilize.

Clock select is controlled by bit 6 (CSEL) of the OPTION register. When CSEL is cleared, the A/D system uses the system E clock. When CSEL is set, the A/D system uses an internal R-C clock source, which runs at about 1.5 MHz . The MCU E clock is not suitable to drive the A/D system if it is operating below 750 kHz , in which case the R-C internal clock should be selected. A delay of 10 ms is required after changing CSEL from zero to one to allow the R-C oscillator to start and internal bias voltages to settle. Refer to 9.1.5 Configuration Options Register (OPTION) for additional information. Note that the CSEL control bit also enables a separate R-C oscillator to drive the EEPROM charge pump.

When the A/D system is operating with the MCU E clock, all switching and comparator operations are synchronized to the MCU clocks. This allows the comparator results to be sampled at quiet clock times to minimize noise errors. The internal R-C oscillator is asynchronous to the MCU clock so noise will affect A/D results more while CSEL $=1$.

# SECTION 8 <br> PROGRAMMABLE TIMER, REAL TIME INTERRUPT, AND PULSE ACCUMULATOR 

This section describes the 16 -bit programmable timer, the real time interrupt, and the pulse accumulator system.

### 8.1 PROGRAMMABLE TIMER

The timer has a single 16 -bit free-running counter which is clocked by the output of a four-stage prescaler (divide by $1,4,8$, or 16 ), which is in turn driven by the MCU E clock. Input functions are called input captures. These input captures record the count from the free-running counter in response to a detected edge on an input line. Output functions, called output compares, cause an output action when there is a match between a 16-bit output-compare register and the free-running counter. This timer system has three input capture registers and five output compare registers.

### 8.1.1 Counter

The key element in the timer system is a 16-bit free-running counter, or timer counter register. After reset, the MCU is configured to use the E clock as the input to the free-running counter. Initialization software may optionally reconfigure the system to use one of the three prescaler values. The prescaler control bits can only be written once during the first 64 cycles after a reset. Software can read the counter at any time without affecting its value because it is clocked and read during opposite phases of the E clock.

A counter read should first address the most significant byte. An MPU read of this address causes the least significant byte to be transferred to a buffer. This buffer is not affected by reset and is accessed when reading the least significant byte of the counter. For double byte read instructions, the two accesses occur on consecutive bus cycles.

The counter is cleared to $\$ 0000$ during reset and is a read-only register with one exception. In test modes only, any MPU write to the most significant byte presets the counter to \$FFF8 regardless of the value involved in the write.

When the count changes from \$FFFF to \$0000, the timer overflow flag (TOF) bit is set in timer interrupt flag register 2 (TFLG2). An interrupt can be enabled by setting the interrupt enable bit (TOI) in timer interrupt mask register 2 (TMSK2).

### 8.1.2 Input Capture

The input capture registers are 16-bit read-only registers which are not affected by reset and are used to latch the value of the counter when a defined transition is sensed by the corresponding input capture edge detector. The level transition which triggers counter transfer is defined by the corresponding input edge bits (EDGxB, EDGxA) in TCTL2.

The result obtained by an input capture corresponds to the value of the counter one E clock cycle after the transition which triggered the edge-detection logic. The selected edge transition sets the ICxF bit in timer interrupt flag register 1 (TFLG1) and can cause an interrupt if the corresponding ICXI bit(s) is (are) set in the timer interrupt mask register 1 (TMSK1). A read of the input capture register's most significant byte inhibits captures for one E cycle to allow a double-byte read of the full 16-bit register.

### 8.1.3 Output Compare

All output compare registers are 16-bit read/write registers which are initialized to \$FFFF by reset. They can be used as output waveform controls or as elapsed time indicators. If an output compare register is not used, it may be used as a storage location.

All output compare registers have a separate dedicated comparator for comparing against the free-running counter. If a match is found, the corresponding output compare flag (OCxF) bit in TFLG1 is set and a specified action is automatically taken. For output compare functions two through five the automatic action is controlled by pairs of bits (OMx and OLx) in the timer control register 1 (TCTL1). Each pair of control bits are encoded to specify the output action to be taken as a result of a successful OCx compare. The output action is taken on each successful compare regardless of whether or not the OCxF flag was previously clear.

An interrupt can also accompany a successful output compare, provided that the corresponding interrupt enable bit (OCxI) is set in TMSK1.

After a write cycle to the most significant byte, output compares are inhibited for one E cycle in order to allow writing two consecutive bytes before making the next comparison. If both bytes of the register are to be changed, a double-byte write instruction should be used in order to take advantage of the compare inhibit feature.

Writes can be made to either byte of the output compare register without affecting the other byte.
A write-only register, timer compare force (CFORC), allows forced compares. Five of the bit positions in the CFORC register correspond to the five output compares. To force a compare, or compares, a write is done to CFORC register with the associated bits set for each output compare that is to be forced. The action taken as a result of a forced compare is the same as if there was a match between the OCx register and the free-running counter, except that the corresponding interrupt status flag bits are not set. Output actions are synchronized to the prescaled timer clock so there could be as much as 16 E clock cycles of delay between the write to CFORC and the output action.

### 8.1.4 Output Compare 1 I/O Pin Control

Unlike the other four output compares, output compare 1 can automatically affect any or all of the five output pins (bits 3-7) in port A as a result of a successful compare between the OC1 register and the 16 -bit free-running counter. The two 5 -bit registers used in conjunction with this function are the output compare 1 mask register (OC1M) and the output compare 1 data register (OC1D).

Register OC1M is used to specify the bits of port A (I/O and timer port) which are to be affected as a result of a successful OC1 compare. Register OC1D is used to specify the data which is to be stored to the affected bits of port $A$ as the result of a successful $O C 1$ compare. If an OC1
compare and another output compare occur during the same E cycle and both attempt to alter the same port A line, the OC1 compare prevails.

This function allows control of multiple I/O pins automatically with a single output compare.
Another intended use for the special I/O pin control on output compare 1 is to allow more than one output compare to control a single I/O pin. This allows pulses as short as one E clock cycle to be generated.

### 8.1.5 Timer Compare Force Register (CFORC)

The timer compare force register is used to force early output compare actions. The CFORC register is an 8 -bit write-only register. Reads of this location have no meaning and always return logic zeros. Note that the compare force function is not generally recommended for use with the output toggle function because a normal compare occurring immediately before or after the force may result in undesirable operation.


FOC1-FOC5 - Force Output Compare x Action
$0=$ Has no meaning
1 = Causes action programmed for output compare x , except the OCxF flag bit is not set.
Bits 2-0 - Not Implemented
These bits always read zero.

### 8.1.6 Output Compare 1 Mask Register (OC1M)

This register is used in conjunction with output compare 1 to specify the bits of port A which are affected as a result of a successful OC1 compare.

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | OC1M |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \$100C | OC1M7 | OC1M6 | OC1M5 | OC1M4 | OC1M3 | 0 | 0 | 0 |  |
| RESET | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |

The bits of the OC1M register correspond bit-for-bit with the lines of port A (lines 7 through 3 only). For each bit that is affected by the successful compare, the corresponding bit in OC1M should be set to one.

Note that the pulse accumulator function shares line 7 of port A. If the DDRA7 bit in the pulse accumulator control register (PACTL) is set, then port A line 7 is configured as an output and OC1 can obtain access by setting OC1M bit 7. In this condition if the PAEN bit in the PACTL register is set, enabling the pulse accumulator input, then OC1 compares cause a write of OC1D bit 7 to an internal latch, and the output of that latch drives the pin and the pulse accumulator input. This action can then cause the pulse accumulator to take the appropriate action (pulse count or gate modes).

### 8.1.7 Output Compare 1 Data Register (OC1D)

This register is used in conjunction with output compare 1 to specify the data which is to be stored to the affected bits of port A as the result of a successful OC1 compare.


OC1D

The bits of the OC1D register correspond bit-for-bit with the lines of port A (lines 7 thru 3 only). When a successful OC1 compare occurs, for each bit that is set in OC1M, the corresponding data bit in OC1D is stored in the corresponding bit of port A. If there is a conflicting situation where an OC1 compare and another output compare function occur during the same E cycle with both attempting to alter the same port A line, the OC1 action prevails.

### 8.1.8 Timer Control Register 1 (TCTL1)



OM2, OM3, OM4, and OM5 - Output Mode
OL2, OL3, OL4, and OL5 - Output Level
These two control bits ( OMx and OLx ) are encoded to specify the output action taken as a result of a successful OCx compare.

| OMx | OLx | Action Taken Upon Successful Compare |
| :---: | :---: | :--- |
| 0 | 0 | Timer disconnected from output pin logic |
| 0 | 1 | Toggle OCx output line |
| 1 | 0 | Clear OCx output line to zero |
| 1 | 1 | Set OCx output line to one |

### 8.1.9 Timer Control Register 2 (TCTL2)



Bits 7-6 - Not Implemented
These bits always read zero.
EDGxB and EDGxA - Input Capture x Edge Control.
These two bits (EDG×B and EDGxA) are cleared to zero by reset and are encoded to configure the input sensing logic for input capture $x$ as follows:

| EDGXB | EDBXA | Configuration |
| :---: | :---: | :--- |
| 0 | 0 | Capture disabled |
| 0 | 1 | Capture on rising edges only |
| 1 | 0 | Capture on falling edges only |
| 1 | 1 | Capture on any (rising or falling) edge |

### 8.1.10 Timer Interrupt Mask Register 1 (TMSK1)



OCxI — Output Compare x Interrupt
If the OCxI enable bit is set when the OCxF flag bit is set, a hardware interrupt sequence is requested.
ICxI - Input Capture x Interrupt
If the ICxI enable bit is set when the ICxF flag bit is set, a hardware interrupt sequence is requested.

### 8.1.11 Timer Interrupt Flag Register 1 (TFLG1)

Timer interrupt flag register 1 is used to indicate the occurrence of timer system events, and together with the TMSK1 register allows the timer subsystem to operate in a polled or interrupt driven system. For each bit in TFLG1, there is a corresponding bit in TMSK1 in the same bit position. If the mask bit is set, each time the conditions for the corresponding flag are met, a hardware interrupt sequence is requested as well as the flag bit being set.

These timer system status flags are cleared by writing a one to the bit positions corresponding to the flag(s) which are to be cleared. Bit manipulation instructions would be inappropriate for flag clearing because they are read-modify-write instructions. Even though the instruction mask implies that the programmer is only interested in some of the bits in the manipulated location, the entire location is actually read and rewritten which may clear other bits in the register.

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \$1023 | OC1F | OC2F | OC3F | OC4F | OC5F | IC1F | IC2F | IC3F | TFLG1 |
| RESET | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |

OCxF - Output Compare x Flag
This flag bit is set each time the timer counter matches the output compare register x value. A write of a zero does not affect this bit. A write of a one causes this bit to be cleared.

## ICxF - Input Capture x Flag

This flag is set each time a selected active edge is detected on the ICx input line. A write of a zero does not affect this bit. A write of a one causes this bit to be cleared.

### 8.1.12 Timer Interrupt Mask Register 2 (TMSK2)

Timer interrupt mask register 2 is used to control whether or not a hardware interrupt sequence is requested as a result of a status bit being set in timer interrupt flag register 2. In addition, two timer prescaler bits are included in this register. For each of the four most significant bits in timer flag register 2, (TFLG2), there is a corresponding bit in the timer mask register 2 (TMSK2) in the same bit position.


TMSK2

TOI - Timer Overflow Interrupt Enable
$0=$ TOF interrupts disabled
1 = Interrupt requested when TOF = 1
RTII - RTI Interrupt Enable
$0=$ RTIF interrupts disabled
$1=$ Interrupt requested when RTIF = 1
PAOVI — Pulse Accumulator Overflow Interrupt Enable
$0=$ PAOVF interrupts disabled
1 = Interrupt requested when PAOVF = 1
PAII - Pulse Accumulator Input Interrupt Enable
$0=$ PAIF interrupts disabled
$1=$ Interrupt requested when PAIF = 1
Bits 3 and 2 - Not Implemented
These bits always read zero.
PR1 and PR0 - Timer Prescaler Selects
These two bits may be read at any time but may only be written during initialization. Writes are disabled after the first write or after 64 E cycles out of reset. If the MCU is in special test or special bootstrap mode, then these two bits may be written any time.

These two bits specify the timer prescaler divide factor.

| PR1 | PR0 | Prescaler |
| :---: | :---: | :---: |
| 0 | 0 | $\div 1$ |
| 0 | 1 | $\div 4$ |
| 1 | 0 | $\div 8$ |
| 1 | 1 | $\div 16$ |

### 8.1.13 Timer Interrupt Flag Register 2 (TFLG2)

Timer interrupt flag register 2 is used to indicate the occurrence of timer system events and, together with the TMSK2 register, allows the timer subsystems to operate in a polled or interrupt driven system. For each bit in timer flag register 2 (TFLG2), there is a corresponding bit in timer mask register 2 (TMSK2) in the same bit position. If the enable bit is set each time the conditions for the corresponding flag are met, a hardware interrupt sequence is requested as well as the flag bit being set.

The timer system status flags are cleared by writing a one to the bit positions corresponding to the flag(s) which are to be cleared. Bit manipulation instructions would be inappropriate for flag clearing because they are read-modify-write instructions. Even though the instruction mask implies that the programmer is only interested in some of the bits in the manipulated location, the entire location is actually read and rewritten which may clear other bits in the register.

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \$1025 | TOF | RTIF | PAOVF | PAIF | 0 | 0 | 0 | 0 | TFLG2 |
| RESET | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 |  |

## TOF - Timer Overflow

This bit is cleared by reset. It is set to one each time the 16 -bit free-running counter advances from a value of $\$ F F F F$ to $\$ 0000$. This bit is cleared by a write to the TFLG2 register with bit 7 set.

RTIF - Real Time Interrupt Flag
This bit is set at each rising edge of the selected tap point. This bit is cleared by a write to the TFLG2 register with bit 6 set.
PAOVF - Pulse Accumulator Overflow Interrupt Flag
This bit is set when the count in the pulse accumulator rolls over from \$FF to $\$ 00$. This bit is cleared by a write to the TFLG2 register with bit 5 set.
PAIF - Pulse Accumulator Input Edge Interrupt Flag
This bit is set when an active edge is detected on the PAI input pin. This bit is cleared by a write to the TFLG2 register with bit 4 set.

Bits 3-0 - Not Implemented
These bits always read zero.

### 8.2 REAL TIME INTERRUPT

The real time interrupt feature on the MCU is configured and controlled by using two bits (RTR1 and RTRO) in the PACTL register to select one of four interrupt rates. The RTII bit in the TMSK2 register enables the interrupt capability. Every timeout causes the RTIF bit in TFLG2 to be set, and if RTII is set, an interrupt request is generated. After reset, one entire real time interrupt period elapses before the RTIF flag is set for the first time.

### 8.3 PULSE ACCUMULATOR

The pulse accumulator is an 8 -bit read/write counter which can operate in either of two modes (external event counting or gated time accumulation) depending on the state of the PAMOD control bit in the PACTL register. In the event counting mode, the 8 -bit counter is clocked to increasing values by an external pin. The maximum clocking rate for the external event counting mode is E clock divided by two. In the gated time accumulation mode, a free-running E clock/64 signal drives the 8 -bit counter, but only while the external PAI input pin is enabled.

The pulse accumulator uses port A bit 7 as its PAI input, but this pin also shares function as a general purpose I/O pin and as a timer output compare pin. Normally port A bit 7 would be configured as an input when being used for the pulse accumulator. Note that even when port A bit 7 is configured for output, this pin still drives the input to the pulse accumulator.

### 8.4 PULSE ACCUMULATOR CONTROL REGISTER (PACTL)

Four bits in this register are used to control an 8-bit pulse accumulator system and two other bits are used to select the rate for the real time interrupt system.

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :--- | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| \$1026 | 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
0 = Input only
1 = Output
PAEN - Pulse Accumulator System Enable
$0=$ Pulse accumulator off
1 = Pulse accumulator on
PAMOD - Pulse Accumulator Mode
$0=$ External event counting
1 = Gated time accumulation
PEDGE - Pulse Accumulator Edge Control
This bit has different meanings depending on the state of the PAMOD bit.

| 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 PAl Inhibits Counting |
| 1 | 1 | A one on PAI Inhibits Counting |

Bits 3-2 - Not Implemented
These bits always read zero.
RTR1 and RTR0 - RTI Interrupt Rate Selects
These two bits select one of four rates for the real time periodic interrupt circuit (see Table 8-1). Reset clears these two bits and after reset, a full RTI period elapses before the first RTI interrupt.

Table 8-1. Real Time Interrupt Rate versus RTR1 and RTRO

| RTR1 | RTRO | Rate | $\begin{gathered} \text { XTAL }= \\ 12.0 \mathrm{MHz} \end{gathered}$ | $\begin{gathered} \text { XTAL }= \\ 2^{23} \end{gathered}$ | $\begin{aligned} & \text { XTAL = } \\ & 8.0 \mathrm{MHz} \end{aligned}$ | $\begin{gathered} \text { XTAL }= \\ \text { 4.9152 MHz } \end{gathered}$ | $\begin{aligned} & \text { XTAL }= \\ & \text { 4.0 MHz } \end{aligned}$ | $\begin{gathered} \text { XTAL = } \\ \text { 3.6864 MHz } \end{gathered}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | $2^{13 \div E}$ | 8.192 ms | 3.91 ms | 4.10 ms | 6.67 ms | 8.19 ms | 8.89 ms |
| 0 | 1 | $2^{14 \div E}$ | 16.384 ms | 7.81 ms | 8.19 ms | 13.33 ms | 16.38 ms | 17.78 ms |
| 1 | 0 | $2^{15 \div E}$ | 32.768 ms | 15.62 ms | 16.38 ms | 26.67 ms | 32.77 ms | 35.56 ms |
| 1 | 1 | $2^{16 \div E}$ | 65.536 ms | 31.25 ms | 32.77 ms | 53.33 ms | 65.54 ms | 71.11 ms |
|  |  | $E=$ | 3.0 MHz | 2.1 MHz | 2.0 MHz | 1.2288 MHz | 1.0 MHz | 921.6 kHz |

## SECTION 9 <br> RESETS, INTERRUPTS, AND LOW POWER MODES

This section provides a description of the resets, interrupts, and low power modes. The computer operating properly (COP) watchdog system and clock monitor are described as part of the reset system. The interrupt description includes a flowchart to illustrate how interrupts are executed.

### 9.1 RESETS

The MCU has four possible types of reset: an active low external reset pin ( $\overline{\mathrm{RESET}}$ ), a power-on reset, a computer operating properly (COP) watchdog timer reset, and a clock monitor reset.

### 9.1.1 External $\overline{\text { RESET Pin }}$

The $\overline{\text { RESET }}$ pin is used to reset the MCU and allow an orderly software start-up procedure. When a reset condition is sensed, this pin is driven low by an internal device for four E clock cycles, then released, and two E clock cycles later it is sampled. If the pin is still low, it means that an external reset has occurred. If the pin is high, it implies that the reset was initiated internally by either the watchdog timer (COP) or the clock monitor (refer to Figure 9-1). This method of differentiation between internal and external reset conditions assumes that the reset pin will rise to a logic one in less than two E clock cycles once it is released and that an externally generated reset should stay active for at least eight $E$ clock cycles.

Since there is EEPROM on chip, it is very important to control reset during power transitions. If the reset line is not held low while $\mathrm{V}_{\mathrm{DD}}$ is below its minimum operating level, the EEPROM contents could be corrupted. Corruption occurs due to improper instruction execution when there is not sufficient voltage to execute instructions correctly. Both EEPROM memories and the EEPROM based CONFIG register are subject to this potential problem.

A low voltage inhibit (LVI) circuit which holds reset low whenever $\mathrm{V}_{\mathrm{DD}}$ is below its minimum operating level is required to protect against EEPROM corruption. Figure 9-3 shows an example of reset circuits with LVI capabilities. The best circuit for a particular application may be different from the suggested circuit.

### 9.1.2 Power-On Reset

The power-on reset occurs when a positive transition is detected on $V_{\text {DD }}$. The power-on reset is used strictly for power turn-on conditions and should not be used to detect any drops in power


CLOCK MONITOR RESET CASE

(1) reset pin sampled at this time. Low level indicates external reset. high level indicates clock monitor or cop system reset.

Figure 9-1. Reset Timing
supply voltage. The power-on circuitry provides a 4064 cycle time delay from the time of the first oscillator operation. In a system where $\mathrm{E}=2 \mathrm{MHz}$, power on reset lasts about 2 milliseconds. If the external RESET pin is low at the end of the power-on delay time, the MCU remains in the reset condition until the RESET pin goes high.
9.1.2.1 CPU. After reset the CPU fetches the restart vector from locations $\$$ FFFE and $\$ F F F F$ (\$BFFE and \$BFFF if in special bootstrap or special test operating mode) during the first three cycles, and begins executing instructions. The stack pointer and other CPU registers are indeterminate immediately after reset; however, the X and I interrupt mask bits in the condition code register are set to mask any interrupt requests. Also, the $S$ bit in the condition code register is set to disable the STOP mode.


Figure 9-2. Simple LVI Reset Circuit
9.1.2.2 MEMORY MAP. After reset, the INIT register is initialized to $\$ 01$, putting the 256 bytes of RAM at locations $\$ 0000$ through $\$ 00 F F$ and the control registers at locations $\$ 1000$ through $\$ 103 F$. The 8K-byte ROM and/or the 512-byte EEPROM may or may not be present in the memory map because the two bits that enable them in the CONFIG register are EEPROM cells and are not affected by reset or power down.
9.1.2.3 PARALLEL I/O. When a reset occurs in expanded multiplexed operating mode, the 18 pins used for parallel I/O are dedicated to the expansion bus. If a reset occurs in the single-chip operating mode, the STAF, STAI, and HNDS bits in the parallel input/output control register (PIOC) are cleared so that no interrupt is pending or enabled, and the simple strobed mode (rather than full handshake mode) of parallel I/O is selected. The CWOM bit in PIOC is cleared so port C is not in wired-OR mode. Port C is initialized as an input port (DDRC $=\$ 00$ ), port B is a general purpose output port with all bits cleared. STRA is the edge-sensitive strobe A input and the active edge is initially configured to detect rising edges (EGA bit in the PIOC set), and STRB is the strobe B output and is initially a logic zero (the INVB bit in the PIOC is set). Port C, port D bits 0 through 5, port A bits $0,1,2$, and 7 , and port E are configured as general purpose high-impedance inputs. Port B and bits 3 through 6 of port A have their directions fixed as outputs and their reset state is a logic zero.
9.1.2.4 TIMER. During reset, the timer system is initialized to a count of $\$ 0000$. The prescaler bits are cleared, and all output compare registers are initialized to \$FFFF. All input capture registers are indeterminate after reset. The output compare 1 mask (OC1M) register is cleared so that successful OC1 compares do not affect any I/O pins. The other four output compares are configured to not affect any I/O pins on successful compares. All three input capture edge-detector circuits are configured for "capture disabled" operation. The timer overflow interrupt flag and all eight timer function interrupt flags are cleared. All nine timer interrupts are disabled since their mask bits are cleared.
9.1.2.5 REAL TIME INTERRUPT. The real time interrupt flag is cleared and automatic hardware interrupts are masked. The rate control bits are cleared after reset and may be initialized by software before the real time interrupt system is used.
9.1.2.6 PULSE ACCUMULATOR. The pulse accumulator system is disabled at reset so that the PAI input pin defaults to being a general purpose input pin.
9.1.2.7 COP. The COP watchdog system is enabled if the NOCOP control bit in the system configuration control register (EEPROM cell) is clear, and disabled if NOCOP is set. The COP rate is set for the shortest duration timeout.
9.1.2.8 SCI SERIAL I/O. The reset condition of the SCI system is independent of the operating mode. At reset, the SCI baud rate is indeterminate and must be established by a software write to the BAUD register. All transmit and receive interrupts are masked and both the transmitter and receiver are disabled so the port pins default to being general purpose I/O lines. The SCl frame format is initialized to an 8 -bit character size. The send break and receiver wake up functions are disabled. The TDRE and TC status bits in the SCl status register are both set, indicating that there is no transmit data in either the transmit data register or the transmit serial shift register. The RDRF, IDLE, OR, NF, and FE receive-related status bits are all cleared.

Note that upon reset in special bootstrap mode execution begins in the 192 byte boot ROM. This firmware sets port D to wire-OR mode, establishes a baud rate, and enables the SCI receiver and transmitter.
9.1.2.9 SPI SERIAL I/O. The SPI system is disabled by reset. The port pins associated with this function default to being general purpose I/O lines.
9.1.2.10 A/D CONVERTER. The A/D converter system configuration is indeterminate after reset. The conversion complete flag is cleared by reset. The ADPU bit is cleared by reset thus disabling the A/D system.
9.1.2.11 SYSTEM. The EEPROM programming controls are all disabled so the memory system is configured for normal read operation. The highest priority I interrupt defaults to being the external $\overline{\mathrm{RQ}}$ pin by PSEL3-PSELO equal to 0:1:0:1. The $\overline{\mathrm{RQ}}$ interrupt pin is configured for level sensitive operation (for wireOR systems). The RBOOT, SMOD, and MDA bits in the HPRIO register reflect the status of the MODB and MODA inputs at the rising edge of reset. The DLY control bit is set to specify that an oscillator startup delay is imposed upon recovery from STOP mode. The clock monitor system is disabled by CME equal zero.

### 9.1.3 Computer Operating Properly (COP) Reset

The MCU includes a computer operating properly watchdog system to help protect against software failures. To use a COP watchdog timer, a watchdog timer reset sequence must be executed on a regular periodic basis so that the watchdog timer is never allowed to time out.

The internal COP function includes special control bits which permit specification of one four time out periods and even allows the function to be disabled completely. The COP system has a separate reset vector.

The NOCOP control bit, which determines whether or not a watchdog timeout causes a system reset, is implemented in an EEPROM cell in the CONFIG register. Once programmed, this bit remains set (or cleared) even when no power is applied, and the COP function is enabled or disabled independent of resident software. The NOCOP control bit may be preempted while in special modes to prevent the COP system from causing a hardware reset.

Two other control bits in the OPTION register select one of four timeout durations for the COP timer. The actual timeout period is dependent on the system E clock frequency, but for reference purposes, Table 9-1 shows the relationship between the CR1 and CRO control bits and the COP timeout period for various system clock frequencies.

Table 9-1. COP Timeout Period versus CR1 and CRO

| CR1 | CR0 | Rate | $\text { XTAL = } 12.0$ <br> MHz Timeout -0/+10.9 ms | $\begin{gathered} \text { XTAL }=2^{23} \\ \text { Timeout } \\ -0 /+15.6 \mathrm{~ms} \end{gathered}$ | $\begin{gathered} \text { XTAL }=8.0 \mathrm{MHz} \\ \text { Timeout } \\ -0 /+16.4 \mathrm{~ms} \end{gathered}$ | $\mathrm{XTAL}=4.9152$ MHz Timeout - 0/+26.7 ms | $\begin{aligned} & \text { XTAL }=4.0 \mathrm{MHz} \\ & \text { Timeout } \\ & -0 /+32.8 \mathrm{~ms} \end{aligned}$ | XTAL $=3.6864$ MHz Timeout $-0 /+35.6 \mathrm{~ms}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 0 | 0 | $2^{15} \div \mathrm{E}$ | 10.923 ms | 15.625 ms | 16.384 ms | 26.667 ms | 32.768 ms | 35.556 ms |
| 0 | 1 | $2^{17} \div \mathrm{E}$ | 43.691 ms | 62.5 ms | 65.536 ms | 106.67 ms | 131.07 ms | 142.22 ms |
| 1 | 0 | $2^{19} \div \mathrm{E}$ | 174.76 ms | 250 ms | 262.14 ms | 426.67 ms | 524.29 ms | 568.89 ms |
| 1 | 1 | $2^{21} \div E$ | 699.05 ms | 1 s | 1.049 s | 1.707 s | 2.1 s | 2.276 s |
|  |  | $\mathrm{E}=$ | 3.0 MHz | 2.1 MHz | 2.0 MHz | 1.2288 MHz | 1.0 MHz | 921.6 kHz |

The default reset condition of the CR1 and CR0 bits is cleared which corresponds to the shortest timeout period.
The sequence required to reset the watchdog timer is:

1) Write $\$ 55$ to the COP reset register (COPRST) at $\$ 103 A$, followed by
2) Write \$AA to the same address.

Both writes must occur in correct order prior to timeout but, any number of instructions may be executed between the writes. The elapsed time between adjacent software reset sequences must never be greater than the COP time out period. Reading the COPRST register does not return meaningful data and does not affect the watchdog timer.

### 9.1.4 Clock Monitor Reset

The clock monitor function is enabled by the CME control bit in the OPTION register. When CME is clear, the monitor function is disabled. When the CME bit is set, the clock monitor function detects the absence of an E clock for more than a certain period of time. The timeout period is dependent on processing parameters and will be between 5 and 100 microseconds. This means that an E-clock rate of 200 kHz or more will never cause a clock monitor failure and an E-clock rate of 10 kHz or less will definitely cause a clock monitor failure. This implies that systems operating near or below an E-clock rate of 200 kHz should not use the clock monitor function.
Upon detection of a slow or absent clock, the clock monitor circuit will cause a system reset. This reset is issued to the external system via the bidirectional RESET pin. The clock monitor system has a separate reset vector.

Special considerations are needed when using a STOP function and clock monitor in the same system. Since the STOP function causes the clocks to be halted, the clock monitor function will generate a reset sequence if it is enabled at the time the STOP mode is entered.

The clock monitor is useful as a backup for the COP watchdog timer. Since the watchdog timer requires a clock to function, it will not indicate any failure if the system clocks fail. The clock monitor would detect such a failure and force the MCU to its reset state. Note that clocks are not required for the MCU to reach its reset configuration, although clocks are required to sequence through reset back to the run condition.

### 9.1.5 Configuration Options Register (OPTION)

This is a special purpose 8-bit register that is used (optionally) during initialization to configure internal system configuration options. With the exception of bits 7, 6, and 3 (ADPU, CSEL, and CME) which may be read or written at any time, this register may be written to only once after a reset and thereafter is a read-only register. If no write is performed to this location within 64 E clock cycles after reset, then bits 5, 4, 1, and 0 (IRQE, DLY, CR1, and CRO) will become readonly to minimize the possibility of any accidental changes to the system configuration (writes will be ignored). While in special test modes, the protection mechanism on this register is preempted and all bits in the OPTION register may be written repeatedly.

|  | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $\$ 1039$ |  |  |  |  |  |  |  |  |
|  | ADPU | CSEL | IRQE | DLY | CME | 0 | CR1 | CRO |

ADPU - A/D Powerup
This bit controls operations of the on-chip analog-to-digital converter. When ADPU is clear, the A/D system is powered down and conversion requests will not return meaningful information. To use the A/D system, this bit should be set. A 100 microsecond delay is required after ADPU is turned on to allow the A/D system to stabilize.

## CSEL - A/D/EE Charge Pump Clock Source Select

This bit determines the clocking source for the on-chip A/D and EEPROM charge pump. When this bit is zero, the MCU E clock drives the A/D system and the EEPROM charge pump. When CSEL is one, on-chip separate R-C oscillators are enabled and clock the systems at about 2 MHz . When running with an E clock below 1 MHz , CSEL must be high to program or erase EEPROM. When operating below 750 kHz E clock rate, CSEL should be high for A/D conversions. A delay of 10 milliseconds is required after CSEL is turned on to allow the A/D system to stabilize.

IRQE - IRQ Edge/Level Sensitive
This bit may only be written under special circumstances as described above. When this bit is clear, the $\overline{\mathrm{RQ}}$ pin is configured for level sensitive wired-OR operation (low level) and when it is set, the $\overline{\mathrm{RRQ}}$ pin is configured for edge-only sensitivity (falling edges).

## DLY - STOP Exit Turn-On Delay

This bit may only be written under special circumstances as described above. This bit is set during reset and controls whether or not a relatively long turn-on delay will be imposed before processing can resume after a STOP period. If an external clock source is supplied this delay can be inhibited so that processing can resume within a few cycles of a wake up from STOP mode. When DLY is set, a 4064 E clock cycle delay is imposed to allow oscillator stabilization and when DLY is clear, this delay is bypassed.

## CME - Clock Monitor Enable

This control bit may be read or written at any time and controls whether or not the internal clock monitor circuit will trigger a reset sequence when a slow or absent system clock is detected. When it is clear, the clock monitor circuit is disabled and when it is set, the clock monitor circuit is enabled. Systems operating at or below 200 kHz should not use the clock monitor function. Reset clears the CME bit.

Bit 2 - Not Implemented This bit always reads zero.

CR1 and CRO - COP Timer Rate Selects
These bits may only be written under special circumstances as described above. Refer to Table 9-1 for the relationship between CR1:CR0 and the COP timeout period.

### 9.2 INTERRUPTS

When an external or internal (hardware) interrupt occurs, the interrupt is not serviced until the current instruction being executed is completed. Until the current instruction is complete, the interrupt is considered pending. After completion of current instruction execution, unmasked interrupts may be serviced in accordance with an established fixed hardware priority circuit; however, one I-bit related interrupt source may be dynamically elevated to the highest I bit priority position in the hierarchy (see 9.2.5 Highest Priority I Interrupt Register (HPRIO)).

Seventeen hardware interrupts and one software interrupt (excluding reset type interrupts) can be generated from all of the possible sources. The interrupts can be divided into two basic categories, maskable and non-maskable. In the MC68HC11A8 fifteen of the interrupts can be masked using the condition code register I bit. In addition to being maskable by the I bit in the condition code register, all of the on-chip interrupt sources are individually maskable by local control bits.

The software interrupt (SWI instruction) is a non-maskable instruction rather than a maskable interrupt source. The illegal opcode interrupt is a non-maskable interrupt. The last interrupt source, external input to the XIRQ pin, is considered a non-maskable interrupt because once enabled, it cannot be masked by software; however, it is masked during reset and upon receipt of an interrupt at the XIRQ pin. Tables 9-2, 9-3, and 9-4 provide a list of each interrupt, its vector location in memory, and the actual condition code and control bits that mask it. A discussion of the various interrupts is provided below. Figure 9-4 shows the interrupt stacking order.

Table 9-2. Interrupt Vector Assignments

| Vector <br> Address | Interrupt Source | CC <br> Register Mask | Local Mask |
| :--- | :--- | :---: | :---: |
| FFC0, C1 | Reserved | - | - |
| $\bullet$ | - |  |  |
| FFD4, D5 | Reserved | - |  |
| FFD6, D7 | SCI Serial System | I Bit | See Table 9-3 |
| FFD8, D9 | SPI Serial Transfer Complete | I Bit | SPIE |
| FFDA, DB | Pulse Accumulator Input Edge | I Bit | PAII |
| FFDC, DD | Pulse Accumulator Overflow | I Bit | PAOVI |
| FFDE, DF | Timer Overflow | I Bit | TOI |
| FFE0, E1 | Timer Output Compare 5 | I Bit | OC5I |
| FFE2, E3 | Timer Output Compare 4 | I Bit | OC4I |
| FFE4, E5 | Timer Output Compare 3 | I Bit | OC3I |
| FFE6, E7 | Timer Output Compare 2 | I Bit | OC2। |
| FFE8, E9 | Timer Output Compare 1 | I Bit | OC11 |
| FFEA, EB | Timer Input Capture 3 | I Bit | OC3I |
| FFEC, ED | Timer Input Capture 2 | I Bit | OC2। |
| FFEE, EF | Timer Input Capture 1 | I Bit | OC1। |
| FFF0, F1 | Real Time Interrupt | I Bit | RTII |
| FFF2, F3 | IRQ (External Pin or Parallel I/O) | I Bit | See Table 9-4 |
| FFF4, F5 | XIRQ Pin (Pseudo Non-Maskable Interrupt) | X Bit | None |
| FFF6, F7 | SWI | None | None |
| FFF8, F9 | Illegal Opcode Trap | None | None |
| FFFA, FB | COP Failure (Reset) | NOCOP |  |
| FFFC, FD | COP Clock Monitor Fail (Reset) | None | CME |
| FFFE, FF | RESET | None |  |

Table 9-3. SCI Serial System Interrupts

| Interrupt Cause | Local Mask |
| :--- | :---: |
| Receive Data Register Full | RIE |
| Receiver Overrun | RIE |
| Idle Line Detect | ILIE |
| Transmit Data Register Empty | TIE |
| Transmit Complete | TCIE |

### 9.2.1 Software Interrupt (SWI)

The software interrupt is executed in the same manner as any other instruction and will take precedence over interrupts only if the other interrupts are masked (I and $X$ bits in the condition code register set). The SWI instruction is executed in a manner similar to other maskable interrupts in that it sets the I bit, CPU registers are stacked, etc.

## NOTE

The SWI instruction will not be fetched if an interrupt is pending. However, once an SWI instruction has begun, no interrupt can be honored until the SWI vector has been fetched.

### 9.2.2 Illegal Opcode Trap

Since not all possible opcodes or opcode sequences are defined, an illegal opcode detection circuit has been included. When an illegal opcode is detected, an interrupt is requested to the illegal opcode vector. The illegal opcode vector should never be left uninitialized. It is a good idea to reinitialize the stack pointer as a result of an illegal opcode interrupt so repeated execution of illegal opcodes does not cause stack overruns.

### 9.2.3 Interrupt Mask Bits in Condition Code Register

Upon reset, both the X bit and the I bit are set to inhibit all maskable interrupts and XIRQ. After minimum system initialization, software may clear the $X$ bit by a TAP instruction, thus enabling $\overline{\text { XIRQ interrupts. Thereafter software cannot set the } X \text { bit so an XIRQ interrupt is effectively a non- }}$ maskable interrupt. Since the operation of the I bit related interrupt structure has no effect on the $X$ bit, the external $\overline{X I R Q}$ pin remains effectively non-masked. In the interrupt priority logic, the $\overline{\text { XIRQ }}$ interrupt is a higher priority than any source that is maskable by the I bit. All I bit related interrupts operate normally with their own priority relationship. When an I bit related interrupt occurs, the I bit is automatically set by hardware after stacking the condition code register byte, but the $X$ bit is not affected. When an X bit related interrupt occurs, both the X bit and the I bit are automatically set by hardware after stacking the condition code register. An RTI (return from interrupt) instruction restores the X and I bits to their pre-interrupt request state.

### 9.2.4 Priority Structure

Interrupts obey a fixed hardware priority circuit to resolve simultaneous requests; however, one I bit related interrupt source may be elevated to the highest I bit priority position in the resolution circuit. The first six interrupt sources are not masked by the I bit in the condition code register and have the fixed priority interrupt relationship of: reset, clock monitor fail, COP fail, illegal opcode, and XIRQ. (SWI is actually an instruction and has highest priority other than reset in the sense that once the SWI opcode is fetched, no other interrupt can be


Figure 9-4. Interrupt Stacking Order honored until the SWI vector has been fetched). Each of these sources is an input to the priority resolution circuit. The highest I bit masked priority input to the resolution circuit is assigned under software control (of the HPRIO register) to be connected to any one of the remaining I bit related interrupt sources. In order to avoid timing races, the HPRIO register may only be written while the I bit related interrupts are inhibited (I bit in condition code register is a logic one). An interrupt that is assigned to this high priority position is still subject to masking by any associated control bits or the I bit in the condition code register. The interrupt vector address is not affected by assigning a source to this higher priority position.

Figures 9-5, 9-6, and 9-7 illustrate the interrupt process as it relates to normal processing. Figure $9-5$ shows how the CPU begins from a reset and how interrupt detection relates to normal opcode fetches. Figure 9-6 is an expansion of a block in Figure 9-5 and shows how interrupt priority is resolved. Figure 9-7 is an expansion of the SCI interrupt block in Figure 9-6. Figure 9-7 shows the resolution of interrupt sources within the SCl subsystem.

### 9.2.5 Highest Priority I Interrupt Register (HPRIO)

This register is used to select one of the I bit related interrupt sources to be elevated to the highest I bit masked position in the priority resolution circuit. In addition, four miscellaneous system control bits are included in this register.


RBOOT - Read Bootstrap ROM
The read bootstrap ROM bit only has meaning when the SMOD bit is a one (special bootstrap mode or special test mode). At all other times, this bit is clear and may not be written.

When set, upon reset in bootstrap mode only, the small bootstrap loader program is enabled. When clear, by reset in the other three modes, this ROM is disabled and accesses to this area are treated as external accesses.

SMOD - Special Mode
The special mode bit reflects the inverse of the MODB input pin at the rising edge of reset. It is set if the MODB pin is low during reset. If MODB is high during reset, it is cleared. This bit may be cleared under software control from the special modes, thus, changing the operating mode of the MCU, but may never be set by software.
MDA - Mode Select A
The mode select A bit reflects the status of the MODA input pin at the rising edge of reset. While the SMOD bit is set (special bootstrap or special test mode in effect) the MDA bit may be written, thus, changing the operating mode, of the MCU. When the SMOD bit is clear, the MDA bit is a read-only bit and the operating mode cannot be changed without going through a reset sequence.
Table 9-5 summarizes the relationship between the SMOD and MDA bits and the MODB and MODA input pins at the rising edge of reset.

Table 9-5. Mode Bits Relationship

| Inputs |  | Mode Description | Latched at Reset |  |
| :---: | :---: | :--- | :---: | :---: |
|  | MODB |  |  | SMOD |
| MDA |  |  |  |
| 1 | 0 | Single Chip | 0 | 0 |
| 1 | 1 | Expanded Multiplexed | 0 | 1 |
| 0 | 0 | Special Bootstrap | 1 | 0 |
| 0 | 1 | Special Test | 1 | 1 |

IRV - Internal Read Visibility
The internal read visibility bit is used in the special modes ( $S M O D=1$ ) to affect visibility of internal reads on the expansion data bus. IRV is writeable only if SMOD $=1$ and returns to zero if SMOD $=0$. If IRV is clear, visibility of internal reads is blocked. If the bit is set, internal reads are visible on the external bus.
PSEL3, PSEL2, PSEL1, and PSELO - Priority Select
These four priority select bits are used to specify one I bit related interrupt source which becomes the highest priority I bit related source (Table 9-6). These bits may be written only while the I bit in $C C R=1$ (interrupts masked).


Figure 9-5. Processing Flow Out of Resets (Sheet 1 of 2)


Figure 9-5. Processing Flow Out of Resets (Sheet 2 of 2)


Figure 9-6. Interrupt Priority Resolution (Sheet 1 of 2)


Figure 9-6. Interrupt Priority Resolution (Sheet 2 of 2)


Figure 9-7. Interrupt Source Resolution Within SCI

Table 9-6. Highest Priority I Interrupt versus PSEL3-PSELO

| PSEL3 | PSEL2 | PSEL1 | PSELO | Interrupt Source Promoted |
| :---: | :---: | :---: | :---: | :--- |
| 0 | 0 | 0 | 0 | Timer Overflow |
| 0 | 0 | 0 | 1 | Pulse Accumulator Overfiow |
| 0 | 0 | 1 | 0 | Pulse Accumulator Input Edge |
| 0 | 0 | 1 | 1 | SPI Serial Transfer Complete |
| 0 | 1 | 0 | 0 | SCI Serial System |
| 0 | 1 | 0 | 1 | Reserved (Default to IRQ) |
| 0 | 1 | 1 | 0 | IRQ (External Pin or Parallel I/O) |
| 0 | 1 | 1 | 1 | Real Time Interrupt |
| 1 | 0 | 0 | 0 | Timer Input Capture 1 |
| 1 | 0 | 0 | 1 | Timer Input Capture 2 |
| 1 | 0 | 1 | 0 | Timer Input Capture 3 |
| 1 | 0 | 1 | 1 | Timer Output Compare 1 |
| 1 | 1 | 0 | 0 | Timer Output Compare 2 |
| 1 | 1 | 0 | 1 | Timer Output Compare 3 |
| 1 | 1 | 1 | 0 | Timer Output Compare 4 |
| 1 | 1 | 1 | 1 | Timer Output Compare 5 |

NOTE:
During reset, PSEL3, PSEL2, PSEL1, and PSEL0 are initialized to 0:1:0:1 which corresponds to "Reserved (default to $\overline{\mathrm{RQQ}}$ )" being the highest priority I bit related interrupt source.

### 9.3 LOW POWER MODES

The MCU contains two programmable low power consumption modes; WAIT and STOP. These two instructions are discussed below. Table 9-7 summarizes the activity on all pins of the MCU for all operating conditions.

### 9.3.1 WAIT Instruction

The WAI instruction puts the MCU in a low power consumption mode, keeping the oscillator running. Upon execution of a WAI instruction, the machine state is stacked and program execution stops. The wait state can be exited only by an unmasked interrupt or RESET. If the I bit is set (interrupts masked) and the COP is disabled, the timer system will be turned off to additionally reduce power consumption. The amount of power savings is application dependent and depends upon circuitry connected to the MCU pins as well as which subsystems (i.e., timer, SPI, SCI) are active when the WAIT mode is entered. Turning off the A/D subsystem by clearing ADPU further reduces WAIT mode current.

### 9.3.2 STOP Instruction

The STOP instruction places the MCU in its lowest power consumption mode provided the S bit in the condition code register is clear. If the $S$ bit is set, the STOP mode is disabled and STOP instructions are treated as NOPs (no operation). In the STOP mode, all clocks including the internal oscillator are stopped causing all internal processing to be halted. Recovery from the STOP mode may be accomplished by $\overline{\mathrm{RESET}}, \overline{\mathrm{XIRQ}}$, or an unmasked $\overline{\mathrm{IRQ}}$. When the XIRQ is used, the MCU exits from the STOP mode regardless of the state of the $X$ bit in the condition code register; however, the actual recovery sequence differs depending on the state of the X bit. If the X bit is clear, the MCU starts up with the stacking sequence leading to normal service of the XIRQ request. If the $X$ bit is set, then processing will continue with the instruction immediately following the STOP instruction and no XIRQinterrupt service routine is requested. A reset will always result in an exit from the STOP mode, and the start of MCU operation is determined by the reset vector.

Table 9-7. Pin State Summary for RESET, STOP, and WAIT

| Pins | Single Chip Modes |  |  | Expanded Modes |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  | RESET | WAIT | STOP | RESET | WAIT | STOP |
| Output Only |  |  |  |  |  |  |
| E | Active E | Active E | 0 | Active E | Active E | 0 |
| XTAL!!! | Active | Active | 1 | Active | Active | 1 |
| STRB/RW | 0 | SS | ss | 1 | 1 | 1 |
| РА3-PA6 | 0 | SS | SS | 0 | SS | SS |
| PB0-PB7 | 0 | SS | SS | HI ADD | HI ADD | HI ADD |
| Input/Output |  |  |  |  |  |  |
| RESET | 1 (0) | 1 | 1 | 1 (0) | 1 | 1 |
| MODA/LIR | $1(0)$ | OD (1) | OD (1) | $1(1)$ | OD (1) | OD (1) |
| MODB $N_{\text {STBY }}$ | 1 (MODB) | $1\left(V_{\text {STBY }}\right)$ | 1 ( $V_{\text {StBY }}$ ) | 1 (MODES) | 1 (V) ${ }_{\text {StBY }}$ ) | 1 ( $\mathrm{V}_{\text {StBY }}$ ) |
| STRA/AS | 1 (STRA) | 1 (STRA) | 1 (STRA) | Active AS | Active AS | 0 |
| PA7 | I | I/O | I/O | 1 | I/O | 1/0 |
| PC0-PC7 | 1 | 1/0 | 1/0 | ADD/DATA | SP-8/DATA | LO ADD |
| PD0-PD5 | 1 | 1/0 | 1/0 | 1 | $1 / \mathrm{O}$ | I/O |
| Input Only |  |  |  |  |  |  |
| EXTAL | Input Clock or Connect to Crystal with XTAL <br> Terminate Unused Inputs to $\mathrm{V}_{\mathrm{DD}}$ <br> Terminate Unused Inputs to $V_{D D}$ <br> Terminate Unused Inputs to $\mathrm{V}_{\mathrm{DD}}$ or $\mathrm{V}_{\mathrm{SS}}$ <br> If Not Used, External Drive Not Required <br> If Not Used, External Drive Not Required |  |  |  |  |  |
| $\overline{\mathrm{R} Q}$ |  |  |  |  |  |  |
| XIRQ |  |  |  |  |  |  |
| PAO-PA2 |  |  |  |  |  |  |
| PE0-PE7 |  |  |  |  |  |  |
| $\mathrm{V}_{\mathrm{RH}} \mathrm{V}_{\mathrm{RL}}$ |  |  |  |  |  |  |

SYMBOLS:

| DATA | $=$ Current data present. |
| :--- | :--- |
| I | $=$ Input pin, if () associated then this is required input state. |
| I/O | $=$ Input/output pin, state determined by data direction register. |
| HI ADD | $=$ High byte of the address. |
| LO ADD | $=$ Low byte of the address. |
| ADD/DATA | $=$ Low byte of the address multiplexed with data. |
| OD | $=$ Open drain output, () current output state. |
| SS | $=$ Steady state, output pin stays in current state. |
| SP-8 | $=$ Address output during WAI period following WAI instruction, stack pointer value, at time |
|  | of WAI, minus 8. |

Since the oscillator is stopped in the STOP mode, a restart delay of 4064 clock cycle times may be required to allow oscillator stabilization. If the internal oscillator is being used, this delay is required; however, if a stable external oscillator is being used, a control bit in the OPTION register may be used ( $D L Y=0$ ) to give a delay of four cycles.

## SECTION 10 CPU, ADDRESSING MODES, AND INSTRUCTION SET

This section provides a description of the CPU registers, addressing modes, and a summary of the M68HC11 instruction set. Special operations such as subroutine calls and interrupts are described and cycle-by-cycle operations for all instructions are presented.

### 10.1 CPU REGISTERS

In addition to being able to execute all M6800 and M6801 instructions, the MC68HC11A8 uses a 4 -page opcode map to allow execution of 91 new opcodes (see 10.2.7 Prebyte). Seven registers, discussed in the following paragraphs, are available to programmers as shown in Figure 10-1.

### 10.1.1 Accumulators $A$ and $B$

Accumulator $A$ and accumulator $B$ are general-purpose 8 -bit registers used to hold operands and results of arithmetic calculations or data manipulations. These two accumulators can be concatenated into a single 16-bit accumulator called the D accumulator.

### 10.1.2 Index Register $X$ (IX)

The 16 -bit IX register is used for indexed mode addressing. It provides a 16 -bit indexing value which is added to an 8 -bit offset provided in an instruction to create an effective address. The IX register can also be used as a counter or as a temporary storage register.


Figure 10-1. Programming Model

### 10.1.3 Index Register Y (IY)

The 16-bit IY register is also used for indexed mode addressing similar to the IX register; however, all instructions using the IY register require an extra byte of machine code and an extra cycle of execution time since they are two byte opcodes.

### 10.1.4 Stack Pointer (SP)

The stack pointer (SP) is a 16-bit register that contains the address of the next free location on the stack. The stack is configured as a sequence of last-in-first-out read/write registers which allow important data to be stored during interrupts and subroutine calls. Each time a new byte is added to the stack (a push instruction), the SP is decrement; whereas, each time a byte is removed from the stack (a pull instruction) the SP is incremented.

### 10.1.5 Program Counter (PC)

The program counter is a 16 -bit register that contains the address of the next instruction to be executed.

### 10.1.6 Condition Code Register (CCR)

The condition code register is an 8 -bit register in which each bit signifies the results of the instruction just executed. These bits can be individually tested by a program and a specific action can be taken as a result of the test. Each individual condition code register bit is explained below.
10.1.6.1 CARRY/BORROW (C). The C bit is set if there was a carry or borrow out of the arithmetic logic unit (ALU) during the last arithmetic operation. The C bit is also affected during shift and rotate instructions.
10.1.6.2 OVERFLOW (V). The overflow bit is set if there was an arithmetic overflow as a result of the operation; otherwise, the $V$ bit is cleared.
10.1.6.3 ZERO ( $\mathbf{Z}$ ). The zero bit is set if the result of the last arithmetic, logic, or data manipulation operation was zero; otherwise, the $Z$ bit is cleared.
10.1.6.4 NEGATIVE ( $\mathbf{N}$ ). The negative bit is set if the result of the last arithmetic, logic, or data manipulation operation was negative; otherwise, the N bit is cleared. A result is said to be negative if its most significant bit is a one.
10.1.6.5 INTERRUPT MASK (I). The I interrupt mask bit is set either by hardware or program instruction to disable (mask) all maskable interrupt sources (both external and internal).
10.1.6.6 HALF CARRY $(\mathbf{H})$. The half carry bit is set to a logic one when a carry occurs between bits 3 and 4 of the arithmetic logic unit during an ADD, ABA, or ADC instruction; otherwise, the H bit is cleared.
10.1.6.7 X INTERRUPT MASK ( X ). The X interrupt mask bit is set only by hardware ( $\overline{\mathrm{RESET}}$ or $\overline{\mathrm{XIRQ}}$ acknowledge); and it is cleared only by program instruction (TAP or RTI).
10.1.6.8 STOP DISABLE (S). The stop disable bit is set to disable the STOP instruction, and cleared to enable the STOP instruction. The $S$ bit is program controlled. The STOP instruction is treated as no operation (NOP) if the $S$ bit is set.

### 10.2 ADDRESSING MODES

Six addressing modes can be used to reference memory; they include: immediate, direct, extended, indexed (with either of two 16-bit index registers and an 8 -bit offset), inherent and relative. Some instructions require an additional byte before the opcode to accommodate a multi-page opcode map; this byte is called a prebyte.

The following paragraphs provide a description of each addressing mode plus a discussion of the prebyte. In these descriptions the term effective address is used to indicate the address in memory from which the argument is fetched or stored, or from which execution is to proceed.

### 10.2.1 Immediate Addressing

In the immediate addressing mode, the actual argument is contained in the byte(s) immediately following the instruction, where the number of bytes matches the size of the register. These are two, three, or four (if prebyte is required) byte instructions.

### 10.2.2 Direct Addressing

In the direct addressing mode (sometimes called zero page addressing), the least significant byte of the operand address is contained in a single byte following the opcode and the most significant byte is assumed to be $\$ 00$. Direct addressing allows the user to access $\$ 0000$ through $\$ 00 F F$ using two byte instructions and execution time is reduced by eliminating the additional memory access. In most applications, this 256-byte area is reserved for frequently referenced data. In the MC68HC11A8, software can configure the memory map so that internal RAM, and/or internal registers, or external memory space can occupy these addresses.

### 10.2.3 Extended Addressing

In the extended addressing mode, the second and third bytes (following the opcode) contain the absolute address of the operand. These are three or four (if prebyte is required) byte instructions: one or two for the opcode, and two for the effective address.

### 10.2.4 Indexed Addressing

In the indexed addressing mode, one of the index registers ( X or Y ) is used in calculating the effective address. In this case, the effective address is variable and depends on two factors: 1)
the current contents of the index register ( X or Y ) being used, and 2) the 8-bit unsigned offset contained in the instruction. This addressing mode allows referencing any memory location in the 64 Kbyte address space. These are usually two or three (if prebyte is required) byte instructions, the opcode plus the 8-bit offset.

### 10.2.5 Inherent Addressing

In the inherent addressing mode, all of the information is contained in the opcode. The operands (if any) are registers and no memory reference is required. These are usually one or two byte instructions.

### 10.2.6 Relative Addressing

The relative addressing mode is used for branch instructions. If the branch condition is true, the contents of the 8 -bit signed byte following the opcode (the offset) is added to the contents of the program counter to form the effective branch address; otherwise, control proceeds to the next instruction. These are usually two byte instructions.

### 10.2.7 Prebyte

In order to expand the number of instructions used in the MC68HC11A8, a prebyte instruction has been added to certain instructions. The instructions affected are usually associated with index register Y . The instruction opcodes which do not require a prebyte could be considered as page 1 of the overall opcode map. The remaining opcodes could be considered as pages 2, 3, and 4 of the opcode map and would require a prebyte; $\$ 18$ for page $2, \$ 1 A$ for page 3 , and $\$ C D$ for page 4.

### 10.3 INSTRUCTION SET

The central processing unit (CPU) in the MC68HC11A8 is basically a proper extension of the MC6801 CPU. In addition to its ability to execute all M6800 and M6801 instructions, the MC68HC11A8 CPU has a paged operation code (opcode) map with a total of 91 new opcodes. Major functional additions include a second 16-bit index register (Y register), two types of 16-by16 divide instructions, STOP and WAIT instructions, and bit manipulation instructions.

Table $10-1$ shows all MC68HC11A8 instructions in all possible addressing modes. For each instruction, the operand construction is shown as well as the total number of machine code bytes and execution time in CPU E-clock cycles. Notes are provided at the end of Table 10-1 which explain the letters in the Operand and Execution Time columns for some instructions. Definitions of "Special Ops" found in the Boolean Expression column are found in Figure 10-2.

Tables 10-2 through 10-8 provide a detailed description of the information present on the address bus, data bus, and the read/write ( $R / \bar{W}$ ) line during each cycle of each instruction. The information is useful in comparing actual with expected results during debug of both software and hardware as the program is executed. The information is categorized in groups according to addressing mode and number of cycles per instruction. In general, instructions with the same address mode and number of cycles execute in the same manner. Exceptions are indicated in the table.

Table 10-1. MC68HC11A8 Instructions, Addressing Modes, and Execution Times (Sheet 1 of 7)

| Source <br> Form(s) | Operation | Boolean Expression | Addressing Mode for Operand | Machine Coding (Hexadecimal) |  | $\left\lvert\, \begin{gathered} \boldsymbol{e} \\ \stackrel{y}{\mathbf{n}} \\ \underset{\mathbf{m}}{ } \end{gathered}\right.$ | $\frac{0}{0}$ | Cycle by Cycle* | Condition Codes <br> S X H I N V C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Opcode | Operand(s) |  |  |  |  |
| ABA | Add Accumulators | $A+B \rightarrow A$ | INH | 1B |  | 1 | 2 | 2-1 | $\cdots$-- $-\downarrow$ 1 |
| ABX | Add B to X | $\bar{I} X+00: B \rightarrow I X$ | INH | 3A |  | 1 | 3 | 2-2 | - - - - - - |
| ABY | Add B to Y | $\bar{Y}+00: B \rightarrow I Y$ | INH | 183 A |  | 2 | 4 | 2-4 | - - - - - - |
| ADCA(opr) | Add with Carry to A | $A+M+C \rightarrow A$ | A IMM <br> A DIR <br> A EXT <br> A IND, $X$ <br> A IND, Y | 89 99 B9 A9 18 A9 | $\begin{array}{ll} \hline \mathrm{ii} & \\ \text { dd } & \\ \text { hh } & I I \\ \mathrm{ff} & \\ \mathrm{ff} & \end{array}$ | $\begin{array}{\|l\|} \hline 2 \\ 2 \\ 3 \\ 2 \\ 3 \end{array}$ | $\begin{array}{\|l\|} \hline 2 \\ 3 \\ 4 \\ 4 \\ 5 \end{array}$ | $\begin{aligned} & 3-1 \\ & 4-1 \\ & 5-2 \\ & 6-2 \\ & 7-2 \end{aligned}$ | $\cdots$ |
| ADCB (opr) | Add with Carry to B | $B+M+C \rightarrow B$ | B IMM <br> B DIR <br> B EXT <br> B IND, X <br> B IND, Y | C9 D9 F9 E9 $18 \mathrm{E9}$ | $\begin{array}{ll} \hline \text { ii } & \\ \text { dd } & \\ \text { hh } & \text { II } \\ \text { ff } & \\ \mathrm{ff} & \end{array}$ | $\begin{array}{\|l\|} \hline 2 \\ 2 \\ 3 \\ 2 \\ 3 \end{array}$ | $\begin{aligned} & 2 \\ & 3 \\ & 4 \\ & 4 \\ & 5 \end{aligned}$ | $\begin{aligned} & 3-1 \\ & 4-1 \\ & 5-2 \\ & 6-2 \\ & 7-2 \end{aligned}$ | $\cdots$ |
| ADDA (opr) | Add Memory to A | $A+M \rightarrow A$ | A IMM <br> A DIR <br> A EXT <br> A IND, $X$ <br> A IND, Y | $8 B$ $9 B$ $B B$ $A B$ $18 A B$ | $\begin{array}{ll} \hline \mathrm{ii} & \\ \text { dd } & \\ \text { hh } & 11 \\ \mathrm{ff} & \\ \mathrm{ff} & \\ \hline \end{array}$ | 2  <br> 2  <br> 3  <br> 2  <br> 3  | $\begin{array}{\|l\|} \hline 2 \\ 3 \\ 4 \\ 4 \\ 5 \end{array}$ | $\begin{aligned} & \hline 3-1 \\ & 4-1 \\ & 5-2 \\ & 6-2 \\ & 7-2 \end{aligned}$ | $\cdots$ |
| ADDB(opr) | Add Memory to B | $B+M \rightarrow B$ | B IMM <br> B DIR <br> B EXT <br> B IND, X <br> B IND, Y | $\begin{array}{r} \mathrm{CB} \\ \mathrm{DB} \\ \mathrm{FB} \\ \mathrm{~EB} \\ 18 \mathrm{~EB} \end{array}$ | ii  <br> dd  <br> hh  <br>   <br> ff  <br> ff . | $\begin{array}{\|l\|} \hline 2 \\ 2 \\ 3 \\ 2 \\ 3 \end{array}$ | $\begin{array}{\|l\|} \hline 2 \\ 3 \\ 4 \\ 4 \\ 5 \end{array}$ | $\begin{aligned} & 3-1 \\ & 4-1 \\ & 5-2 \\ & 6-2 \\ & 7-2 \end{aligned}$ | $\cdots$ |
| ADDD (opr) | Add 16-Bit to D | $D+M: M+1 \rightarrow D$ | IMM DIR EXT IND, X IND,Y | C3 D3 F3 E3 18 E3 | dj kk <br> dd  <br> hh II <br> ff  <br> ff  | $\begin{array}{\|l\|} \hline 3 \\ 2 \\ 3 \\ 2 \\ 3 \\ \hline \end{array}$ | $\begin{array}{\|l\|} \hline 4 \\ 5 \\ 6 \\ 6 \\ 7 \\ \hline \end{array}$ | $\begin{gathered} \hline 3-3 \\ 4-7 \\ 5-10 \\ 6-10 \\ 7-8 \end{gathered}$ | $\cdots$ |
| ANDA (opr) | AND A with Memory | $\mathrm{A} \cdot \mathrm{M} \rightarrow \mathrm{A}$ | A IMM <br> A DIR <br> A EXT <br> A IND, $X$ <br> A IND, Y | 84 94 B4 A4 18 A4 | ii  <br> dd  <br> hh II <br> ff  <br> ff  | $\begin{array}{\|l\|} \hline 2 \\ 2 \\ 3 \\ 2 \\ 3 \\ \hline \end{array}$ | $\begin{aligned} & \hline 2 \\ & 3 \\ & 4 \\ & 4 \\ & 5 \end{aligned}$ | $\begin{aligned} & \hline 3-1 \\ & 4-1 \\ & 5-2 \\ & 6-2 \\ & 7-2 \end{aligned}$ | $\cdots$ |
| ANDB (opr) | AND B with Memory | $\mathrm{B} \cdot \mathrm{M} \rightarrow \mathrm{B}$ | B IMM <br> B DIR <br> B EXT <br> B IND, $X$ <br> B IND, Y | C4 D 4 F 4 E 4 18 E 4 | ii  <br> dd  <br> hh II <br> ff  <br> ff  | $\begin{array}{\|l\|} \hline 2 \\ 2 \\ 3 \\ 2 \\ 3 \\ \hline \end{array}$ | $\begin{aligned} & 2 \\ & 3 \\ & 4 \\ & 4 \\ & 5 \end{aligned}$ | $\begin{aligned} & 3-1 \\ & 4-1 \\ & 5-2 \\ & 6-2 \\ & 7-2 \end{aligned}$ | $\cdots$ |
| ASL (opr) <br>  <br> ASLA <br> ASLB <br> ASLD | Arithmetic Shift Left |  | EXT IND, X IND,Y A INH B INH | 78 68 1868 48 58 | hh II ff ff | $\begin{array}{\|l\|} \hline 3 \\ 2 \\ 3 \\ 1 \\ 1 \\ \hline \end{array}$ | $\begin{array}{\|l\|} \hline 6 \\ 6 \\ 7 \\ 2 \\ 2 \end{array}$ | $\begin{aligned} & 5-8 \\ & 6-3 \\ & 7-3 \\ & 2-1 \\ & 2-1 \end{aligned}$ | $\cdots$ |
| ASLD | Arithmetic Shift Left Double | $\square_{c}-\square_{b 15} \square_{b 0}-\square_{b}$ | INH | 05 |  | 1 | 3 | 2-2 | $\cdots$ |
| ASR (opr) <br>  <br> ASRA <br> ASRB <br> 戍 | Arithmetic Shift Right |  | EXT IND, X IND,Y A INH B INH | $\begin{array}{r} 77 \\ 67 \\ 1867 \\ 47 \\ 57 \end{array}$ | hh II  <br> ff  <br> ff  | $\begin{array}{\|l\|} \hline 3 \\ 2 \\ 3 \\ 1 \\ 1 \end{array}$ | $\begin{array}{\|l\|} \hline 6 \\ 6 \\ 7 \\ 2 \\ 2 \end{array}$ | $\begin{aligned} & 5-8 \\ & 6-3 \\ & 7-3 \\ & 2-1 \\ & 2-1 \end{aligned}$ | $\cdots$ |
| BCC (rel) | Branch if Carry Clear | ? $\mathrm{C}=0$ | REL | 24 | rr | 2 | 3 | 8-1 | - - - - - |
| $\begin{array}{r} \text { BCLR (opr) } \\ \text { (msk) } \end{array}$ | Clear Bit(s) | $\mathrm{M} \cdot(\overline{\mathrm{mm}}) \rightarrow \mathrm{M}$ | $\begin{aligned} & \hline \text { DIR } \\ & \text { IND, } X \\ & \text { IND,Y } \end{aligned}$ | 15 $1 D$ $181 D$ | dd mm <br> ff mm <br> ff mm | $\left.\begin{aligned} & 3 \\ & 3 \\ & 4 \end{aligned} \right\rvert\,$ | 6 7 7 8 | $\begin{aligned} & 4-10 \\ & 6-13 \\ & 7-10 \\ & \hline \end{aligned}$ | $\cdots$ |
| BCS (rel) | Branch if Carry Set | ? $\mathrm{C}=1$ | REL | 25 | rr | 2 | 3 | 8-1 | - - - - - - |
| BEQ (rel) | Branch if = Zero | ? $\mathrm{Z}=1$ | REL | 27 | rr | 2 | 3 | 8-1 | - - - - - |

*Cycle-by-cycle number provides a reference to Tables 10-2 through 10-8 which detail cycle-by-cycle operation.
Example: Table 10-1 Cycle-by-Cycle column reference number 2-4 equals Table 10-2 line item 2-4.

Table 10-1. MC68HC11A8 Instructions, Addressing Modes, and Execution Times (Sheet 2 of $\mathbf{7}$ )

| Source <br> Form(s) | Operation | Boolean Expression | Addressing Mode for Operand | Machine Coding (Hexadecimal) |  | $\stackrel{\substack{\infty \\ \underset{\infty}{\infty} \\ \hline \\ \hline}}{ }$ | $\frac{0}{0}$ | Cycle by Cycle* | Condition Codes <br> SXH I N V C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Opcode | Operand(s) |  |  |  |  |
| BGE (rel) | Branch if $\geq$ Zero | ? $\mathrm{N} \oplus \mathrm{V}=0$ | REL | 2C | rr | 2 | 3 | 8-1 | - - - - - - |
| BGT (rel) | Branch if > Zero | $? \mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=0$ | REL | 2 E | rr | 2 | 3 | 8-1 | - - - - - - |
| BHI (rel) | Branch if Higher | ? $\mathrm{C}+\mathrm{Z}=0$ | REL | 22 | rr | 2 | 3 | 8-1 | - |
| BHS (rel) | Branch if Higher or Same | ? $\mathrm{C}=0$ | REL | 24 | rr | 2 | 3 | 8-1 | - - - - - - |
| BITA (opr) | Bit(s) Test A with Memory | A•M | A IMM <br> A DIR <br> A EXT <br> A IND, $X$ <br> A IND, Y | 85 95 B5 A5 18 A5 | ii  <br> dd  <br> hh II <br> ff  <br> ff  | 2 2 3 3 2 3 | $\begin{aligned} & 2 \\ & 3 \\ & 4 \\ & 4 \\ & 5 \end{aligned}$ | $\begin{aligned} & \hline 3-1 \\ & 4-1 \\ & 5-2 \\ & 6-2 \\ & 7-2 \end{aligned}$ | $\cdots$ - -1. |
| BITB (opr) | Bit(s) Test B with Memory | $B \bullet M$ | $\begin{aligned} & \text { B IMM } \\ & \text { B DIR } \\ & \text { B EXT } \\ & \text { B IND, X } \\ & \text { B IND,Y } \end{aligned}$ | C5 D5 F5 E5 18 E5 | ii  <br> dd  <br> hh II <br> ff  <br> ff  | $\begin{aligned} & 2 \\ & 2 \\ & 3 \\ & 2 \\ & 3 \end{aligned}$ | $\begin{aligned} & 2 \\ & 3 \\ & 4 \\ & 4 \\ & 5 \end{aligned}$ | $\begin{aligned} & 3-1 \\ & 4-1 \\ & 5-2 \\ & 6-2 \\ & 7-2 \end{aligned}$ | $\cdots$ |
| BLE (rel) | Branch if $\leq$ Zero | $? \mathrm{Z}+(\mathrm{N} \oplus \mathrm{V})=1$ | REL | 2 F | rr | 2 | 3 | 8-1 | - |
| BLO (rel) | Branch if Lower | ? $\mathrm{C}=1$ | REL | 25 | rr | 2 | 3 | 8-1 | - - - - - - |
| BLS (rel) | Branch if Lower or Same | ? $\mathrm{C}+\mathrm{Z}=1$ | REL | 23 | rr | 2 | 3 | 8-1 | - - - - - - |
| BLT (rel) | Branch If < Zero | ? $\mathrm{N} \oplus \mathrm{V}=1$ | REL | 2D | rr | 2 | 3 | 8-1 | - - - - - - |
| BMI (rel) | Branch if Minus | ? $\mathrm{N}=1$ | REL | 2B | rr | 2 | 3 | 8-1 | - - - - - - - |
| BNE (rel) | Branch if Not = Zero | ? $\mathrm{Z}=0$ | REL | 26 | rr | 2 | 3 | 8-1 | - - - - - - |
| BPL (rel) | Branch if Plus | ? $\mathrm{N}=0$ | REL | 2A | rr | 2 | 3 | 8-1 | - - - - - - - |
| BRA (rel) | Branch Always | ? $1=1$ | REL | 20 | rr | 2 | 3 | 8-1 | - - - - - - |
| $\begin{gathered} \hline \text { BRCLR(opr) } \\ \text { (msk) } \\ \text { (rel) } \\ \hline \end{gathered}$ | Branch if Bit(s) Clear | ? $\mathrm{M} \cdot \mathrm{mm}=0$ | $\begin{aligned} & \text { DIR } \\ & \text { IND, } X \\ & \text { IND,Y } \end{aligned}$ | 13 $1 F$ $181 F$ | $\begin{aligned} & \text { dd mm rr } \\ & \text { ff mm rr } \\ & \text { ff mm rr } \end{aligned}$ | 年 | 6 7 8 8 | $\begin{aligned} & 4-11 \\ & 6-14 \\ & 7-11 \end{aligned}$ | - - - - - - |
| BRN (rel) | Branch Never | ? $1=0$ | REL | 21 | rr | 2 | 3 | 8-1 | - - - - - - |
| $\begin{array}{r} \text { BRSET(opr) } \\ \text { (msk) } \\ \text { (rel) } \\ \hline \end{array}$ | Branch if Bit(s) Set | ? $(\overline{\mathrm{M}}) \cdot \mathrm{mm}=0$ | $\begin{aligned} & \hline \text { DIR } \\ & \text { IND, } X \\ & \text { IND,Y } \end{aligned}$ | 12 $1 E$ $181 E$ | dd mm rr <br> ff mm rr <br> ff mm rr | 4 <br> 4 <br> 5 | 6 <br> 7 <br> 8 | $\begin{aligned} & 4-11 \\ & 6-14 \\ & 7-11 \end{aligned}$ | - |
| $\begin{array}{r} \text { BSET(opr) } \\ \text { (msk) } \end{array}$ | Set Bit(s) | $\mathrm{M}+\mathrm{mm} \rightarrow \mathrm{M}$ | $\begin{aligned} & \hline \text { DIR } \\ & \text { IND, } X \\ & \text { IND,Y } \end{aligned}$ | $\begin{array}{r} 14 \\ 1 \mathrm{C} \\ 181 \mathrm{C} \end{array}$ | dd mm <br> ff mm <br> ff mm | 3 3 4 4 | 8 <br> 7 <br> 7 <br> 8 | $\begin{aligned} & 4-10 \\ & 6-13 \\ & 7-10 \end{aligned}$ | $\cdots$ |
| BSR (rel) | Branch to Subroutine | See Special Ops | REL | 8D | rr | 2 | 6 | 8-2 | - |
| BVC (rel) | Branch if Overflow Clear | ? V = 0 | REL | 28 | rr | 2 | 3 | 8-1 | - |
| BVS (rel) | Branch if Overflow Set | ? $\mathrm{V}=1$ | REL | 29 | rr | 2 | 3 | 8-1 | - - - - - - |
| CBA | Compare A to B | A-B | INH | 11 |  | 1 | 2 | 2-1 | ---- $\downarrow \downarrow \downarrow$ |
| CLC | Clear Carry Bit | $0 \rightarrow$ C | INH | 0 C |  | 1 | 2 | 2-1 | $\cdots-\cdots-\cdots 0$ |
| CLI | Clear Interrupt Mask | $0 \rightarrow 1$ | INH | 0E |  | 1 | 2 | 2-1 | - - 0 - |
| CLR (opr) | Clear Memory Byte | $0 \rightarrow \mathrm{M}$ |  | $\begin{array}{r} 7 \mathrm{~F} \\ 6 \mathrm{~F} \\ 186 \mathrm{~F} \\ \hline \end{array}$ | hh II ff f | 3 2 3 | 6 6 7 | $\begin{aligned} & \hline 5-8 \\ & 6-3 \\ & 7-3 \\ & \hline \end{aligned}$ | $\cdots \cdots \cdots 0100$ |
| CLRA | Clear Accumulator A | $0 \rightarrow \mathrm{~A}$ | A INH | 4 F |  | 1 | 2 | 2-1 | $\cdots \cdots 00100$ |
| CLRB | Clear Accumulator B | $0 \rightarrow B$ | B INH | 5 F |  | 1 | 2 | 2-1 | $\cdots \cdots 0100$ |
| CLV | Clear Overflow Flag | $0 \rightarrow V$ | INH | OA |  | 1 | 2 | 2-1 | $\cdots$ |
| CMPA (opr) | Compare A to Memory | A-M | A IMM A DIR <br> A EXT <br> A IND, X <br> A IND, $Y$ | 81 91 B1 A1 18 A1 | $\begin{array}{ll} \hline \mathrm{ii} & \\ \text { dd } & \\ \text { hh } & \text { II } \\ \mathrm{ff} & \\ \mathrm{ff} & \\ \hline \end{array}$ | 2 <br> 2 <br> 3 <br> 3 <br> 2 <br> 3 | 2 3 4 4 5 | $\begin{aligned} & \hline 3-1 \\ & 4-1 \\ & 5-2 \\ & 6-2 \\ & 7-2 \end{aligned}$ | $\cdots \cdots$ |

[^0]Example: Table 10-1 Cycle-by-Cycle column reference number 2-4 equals Table 10-2 line item 2-4.

Table 10-1. MC68HC11A8 Instructions, Addressing Modes, and Execution Times (Sheet 3 of 7)

| Source <br> Form(s) | Operation | Boolean Expression | Addressing Mode for Operand | Machine Coding (Hexadecimal) |  | $\underset{\substack{\infty \\ \underset{\sim}{\infty} \\ \underset{\sim}{\infty} \\ \hline}}{ }$ | $\frac{0}{0}$ |  | Condition Codes <br> SXHIN Z V C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Opcode | Operand(s) |  |  |  |  |
| CMPB (opr) | Compare B to Memory | B-M | BIMM | C1 | ii | 2 | 2 | 3-1 | $\cdots$ |
|  |  |  | B DIR | D1 | dd | 2 | 3 | 4-1 |  |
|  |  |  | B EXT | F1 | hh II | 3 | 4 | 5-2 |  |
|  |  |  | B IND, X | E1 | $f$ | 2 | 4 | 6-2 |  |
|  |  |  | B IND, Y | 18 E 1 | ff | 3 | 5 | 7-2 |  |
| COM (opr) | 1's Complement Memory Byte | \$FF-M $\rightarrow$ M | EXT | 73 | hh II | 3 | 6 | 5-8 | $\cdots \cdots$ |
|  |  |  | IND, X | 63 | ff | 2 | 6 | 6-3 |  |
|  |  |  | IND, Y | 1863 | ff | 3 | 7 | 7-3 |  |
| COMA | 1's Complement A | \$FF-A $\rightarrow$ A | A INH | 43 |  | 1 | 2 | 2-1 | $\cdots$ |
| COMB | 1's Complement B | \$FF-B $\rightarrow$ B | B INH | 53 |  | 1 | 2 | 2-1 | $\cdots$ |
| CPD (opr) | $\begin{aligned} & \text { Compare D to Memory } \\ & 16-\mathrm{Bit} \end{aligned}$ | $D-M: M+1$ | IMM | 1A 83 | jj kk | 4 | 5 | 3-5 | $\cdots$ |
|  |  |  | DIR | 1A 93 |  | 3 | 6 | 4-9 |  |
|  |  |  | EXT | 1A B3 | hh II | 4 | 7 | 5-11 |  |
|  |  |  | IND, X | 1A A3 | $f f$ | 3 | 7 | 6-11 |  |
|  |  |  | IND, Y | CD A3 | ff | 3 | 7 | 7-8 |  |
| CPX (opr) | $\begin{aligned} & \text { Compare } \mathrm{X} \text { to Memory } \\ & \text { 16-Bit } \end{aligned}$ | IX - M:M + 1 | IMM | 8C | jj kk | 3 | 4 | 3-3 | $\cdots$ |
|  |  |  | DIR | 9 C | dd | 2 | 5 | 4-7 |  |
|  |  |  | EXT | BC | hh II | 3 | 6 | 5-10 |  |
|  |  |  | IND, X | AC | ff | 2 | 6 | 6-10 |  |
|  |  |  | IND, Y | CD AC | ff | 3 | 7 | 7-8 |  |
| CPY (opr) | Compare Y to Memory 16-Bit | IY - M:M + 1 | IMM | 188 C | jj kk | 4 | 5 |  | $\cdots$ |
|  |  |  | DIR | 189 C | dd | 3 | 6 | $4-9$ |  |
|  |  |  | EXT | 18 BC | hh II | 4 | 7 | 5-11 |  |
|  |  |  | IND, X | 1A AC | $f$ | 3 | 7 | 6-11 |  |
|  |  |  | IND, Y | 18 AC | ff | 3 | 7 | 7-8 |  |
| DAA | Decimal Adjust A | Adjust Sum to BCD | INH | 19 |  | 1 | 2 | 2-1 | $\cdots \cdots$ |
| DEC (opr) | Decrement Memory Byte | $\mathrm{M}-1 \rightarrow \mathrm{M}$ | EXT | 7A | hh II | 3 | 6 | 5-8 | $\cdots$ |
|  |  |  | IND, X | 6A | ff | 2 | 6 | 6-3 |  |
|  |  |  | IND, Y | 186 A | ff | 3 | 7 | 7-3 |  |
| DECA | Decrement Accumulator A | $\mathrm{A}-1 \rightarrow \mathrm{~A}$ | A INH | 4A |  | 1 | 2 | 2-1 | $\cdots$ |
| DECB | Decrement Accumulator B | $\mathrm{B}-1 \rightarrow \mathrm{~B}$ | B INH | 5A |  | 1 | 2 | 2-1 | $\cdots$ |
| DES | Decrement Stack Pointer | $\mathrm{SP}-1 \rightarrow$ SP | INH | 34 |  | 1 | 3 | 2-3 | - - - - |
| DEX | Decrement Index Register X | $\mathrm{IX}-1 \rightarrow \mathrm{IX}$ | INH | 09 |  | 1 | 3 | 2-2 | $\cdots \cdots$ |
| DEY | Decrement Index Register Y | IY-1 $\rightarrow$ IY | INH | 1809 |  | 2 | 4 | 2-4 | $\cdots$ |
| EORA (opr) | Exclusive OR A with Memory | $A \oplus M \rightarrow A$ | A IMM | 88 | ii | 2 | 2 | 3-1 | $\cdots$ |
|  |  |  | A DIR | 98 | dd | 2 | 3 | 4-1 |  |
|  |  |  | A EXT | 88 | hh II | 3 | 4 | 5-2 |  |
|  |  |  | A IND, X | A8 | ff | 2 | 4 | 6-2 |  |
|  |  |  | A IND, Y | 18 A8 | ff | 3 | 5 | 7-2 |  |
| EORB (opr) | Exclusive OR B with Memory | $B \oplus M \rightarrow B$ | B IMM | C8 | ii | 2 | 2 | 3-1 | $\cdots$ |
|  |  |  | B DIR | D8 | dd | 2 | 3 | 4-1 |  |
|  |  |  | B EXT | F8 | hh II | 3 | 4 | 5-2 |  |
|  |  |  | B IND, X | E8 | ff | 2 | 4 | 6-2 |  |
|  |  |  | B IND, Y | 18 E8 | ff | 3 | 5 | 7-2 |  |
| FDIV | Fractional Divide 16 by 16 | D/IX $\rightarrow$ IX; $\mathrm{r} \rightarrow \mathrm{D}$ | INH | 03 |  | 1 | 41 | 2-17 | $\cdots$ |
| IDIV | Integer Divide 16 by 16 | $\mathrm{D} / \mathrm{IX} \rightarrow \mathrm{IX} ; \mathrm{r} \rightarrow \mathrm{D}$ | INH | 02 |  | 1 | 41 | 2-17 | $\cdots \cdots$ |
| INC (opr) | Increment Memory Byte | $M+1 \rightarrow M$ | EXT | 7 C | hh II | 3 | 6 | 5-8 | $\cdots \cdots$ |
|  |  |  | IND, X | 6C | ff | 2 | 6 | 6-3 |  |
|  |  |  | IND, Y | 186 C | ff | 3 | 7 | 7-3 |  |
| INCA | Increment Accumulator A | $A+1 \rightarrow A$ | A INH | 4C |  | 1 | 2 | 2-1 | $\cdots$ |
| INCB | Increment Accumulator B | $\mathrm{B}+1 \rightarrow \mathrm{~B}$ | B INH | 5C |  | 1 | 2 | 2-1 | $\cdots$ |
| INS | Increment Stack Pointer | $\mathrm{SP}+1 \rightarrow \mathrm{SP}$ | INH | 31 |  | 1 | 3 | 2-3 | $\cdots$ |

*Cycle-by-cycle number provides a reference to Tables 10-2 through 10-8 which detail cycle-by-cycle operation.
Example: Table 10-1 Cycle-by-Cycle column reference number 2-4 equals Table 10-2 line item 2-4.

Table 10-1. MC68HC11A8 Instructions, Addressing Modes, and Execution Times (Sheet 4 of 7)

| Source Form(s) | Operation | Boolean Expression | Addressing Mode for Operand | Machine Coding (Hexadecimal) |  | $\begin{array}{\|c\|} \hline \boldsymbol{y} \\ \mathbf{y} \\ \mathbf{c} \\ \hline \mathbf{\infty} \\ \hline \end{array}$ | $\begin{array}{\|l\|} \hline \frac{0}{0} \\ \hline 0 \\ \hline \end{array}$ | Cycle by Cycle* | Condition Codes <br> $\mathrm{SXH} \mathbf{~ I N ~ Z ~ V ~ C ~}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Opcode | Operand(s) |  |  |  |  |
| INX | Increment Index Register X | $\mathrm{IX}+1 \rightarrow \mathrm{IX}$ | INH | 08 |  | 1 | 3 | 2-2 | $\cdots-\cdots-1-$ |
| INY | Increment Index Register Y | $\underline{I Y}+1 \rightarrow I Y$ | INH | 1808 |  | 2 | 4 | 2-4 |  |
| JMP (opr) | Jump | See Special Ops |  | $\begin{array}{r} 7 E \\ 6 E \\ 186 E \\ \hline \end{array}$ | hh II <br> ff ff | $\begin{array}{\|l} \hline 3 \\ 2 \\ 3 \\ \hline \end{array}$ | $\begin{array}{\|l} \hline 3 \\ 3 \\ 4 \\ \hline \end{array}$ | $\begin{aligned} & 5-1 \\ & 6-1 \\ & 7-1 \\ & \hline \end{aligned}$ | - - - - - - |
| JSR (opr) | Jump to Subroutine | See Special Ops | $\begin{aligned} & \hline \text { DIR } \\ & \text { EXT } \\ & \text { IND, } X \\ & \text { IND,Y } \\ & \hline \end{aligned}$ | $9 D$ $B D$ $A D$ 18 AD | $\begin{array}{ll} \hline \text { dd } & \\ \text { hh } & \text { II } \\ \text { ff } & \\ \mathrm{ff} & \\ \hline \end{array}$ | $\begin{array}{\|l\|} \hline 2 \\ 3 \\ 2 \\ 3 \\ \hline \end{array}$ | $\begin{array}{\|l\|} \hline 5 \\ 6 \\ 6 \\ 7 \\ \hline \end{array}$ | $\begin{gathered} \hline 4-8 \\ 5-12 \\ 6-12 \\ 7-9 \\ \hline \end{gathered}$ | $\cdots \cdots \cdots$ |
| LDAA (opr) | Load Accumulator A | $M \rightarrow A$ | A IMM A DIR <br> A EXT <br> A IND, X <br> A IND, Y | 86 96 $B 6$ A6 18 A 6 | $\begin{array}{ll} \hline \mathrm{ii} & \\ \text { dd } & \\ \text { hh } & \text { II } \\ \mathrm{ff} & \\ \mathrm{ff} & \\ \hline \end{array}$ | 2  <br> 2  <br> 3  <br> 2  <br> 2  <br> 3  | $\begin{aligned} & 2 \\ & 3 \\ & 4 \\ & 4 \\ & 5 \end{aligned}$ | $\begin{aligned} & \hline 3-1 \\ & 4-1 \\ & 5-2 \\ & 6-2 \\ & 7-2 \end{aligned}$ | $\cdots$ |
| LDAB (opr) | Load Accumulator B | $\mathrm{M} \rightarrow \mathrm{B}$ | B IMM <br> B DIR <br> B EXT <br> B IND, X <br> B IND, Y | C6 D6 F6 E6 18 E 6 | $\begin{array}{ll} \hline \text { ii } & \\ \text { dd } & \\ \text { hh } & \text { II } \\ \mathrm{ff} & \\ \mathrm{ff} & \\ \hline \end{array}$ | 2  <br> 2  <br> 3  <br> 2  <br> 3  | $\begin{aligned} & 2 \\ & 3 \\ & 4 \\ & 4 \\ & 5 \end{aligned}$ | $\begin{aligned} & 3-1 \\ & 4-1 \\ & 5-2 \\ & 6-2 \\ & 7-2 \end{aligned}$ | $\cdots$ |
| LDD (opr) | Load Double Accumulator D | $M \rightarrow A, M+1 \rightarrow B$ | $\begin{aligned} & \hline \text { IMM } \\ & \text { DIR } \\ & \text { EXT } \\ & \text { IND,X } \\ & \text { IND,Y } \end{aligned}$ | CC DC FC EC 18 EC | jj kk <br> dd  <br> hh II <br> ff  <br> ff  | 3  <br> 2  <br> 3  <br> 2  <br> 3  | $\begin{aligned} & \hline 3 \\ & 4 \\ & 5 \\ & 5 \\ & 6 \end{aligned}$ | $\begin{aligned} & 3-2 \\ & 4-3 \\ & 5-4 \\ & 6-6 \\ & 7-6 \end{aligned}$ | $\cdots$ |
| LDS (opr) | Load Stack Pointer | $\mathrm{M}: \mathrm{M}+1 \rightarrow \mathrm{SP}$ | IMM DIR EXT IND, X IND,Y | 8 E 9 E BE AE 18 AE | jj kk <br> dd  <br> hh II <br> ff  <br> ff  | $\begin{aligned} & 3 \\ & 2 \\ & 3 \\ & 2 \\ & 3 \end{aligned}$ | $\begin{aligned} & 3 \\ & 4 \\ & 5 \\ & 5 \\ & 6 \end{aligned}$ | $\begin{aligned} & 3-2 \\ & 4-3 \\ & 5-4 \\ & 6-6 \\ & 7-6 \end{aligned}$ | $\cdots$ |
| LDX (opr) | Load Index Register X | $\bar{M}: \mathrm{M}+1 \rightarrow \mathrm{X}$ | $\begin{aligned} & \text { IMM } \\ & \text { DIR } \\ & \text { EXT } \\ & \text { IND,X } \\ & \text { IND,Y } \end{aligned}$ | CE DE FE EE CDEE | jj kk <br> dd  <br> hh  <br> ff  <br> ff  <br> fin  | $\begin{aligned} & \hline 3 \\ & 2 \\ & 3 \\ & 2 \\ & 3 \end{aligned}$ | $\begin{aligned} & 3 \\ & 4 \\ & 5 \\ & 5 \\ & 6 \end{aligned}$ | $\begin{aligned} & \hline 3-2 \\ & 4-3 \\ & 5-4 \\ & 6-6 \\ & 7-6 \end{aligned}$ | $\cdots$ |
| LDY (opr) | Load Index Register Y | $\mathrm{M}: \mathrm{M}+1 \rightarrow \mathrm{IV}$ | IMM DIR EXT <br> IND, X <br> IND,Y | $\begin{aligned} & 18 \mathrm{CE} \\ & 18 \mathrm{DE} \\ & 18 \mathrm{FE} \\ & 1 \mathrm{~A} \mathrm{EE} \\ & 18 \mathrm{EE} \end{aligned}$ | jij kk <br> dd  <br> hh II <br> ff  <br> ff  | $\begin{aligned} & \hline 4 \\ & 3 \\ & 4 \\ & 3 \\ & 3 \end{aligned}$ | 4 5 6 6 6 | $\begin{aligned} & \hline 3-4 \\ & 4-5 \\ & 5-6 \\ & 6-7 \\ & 7-6 \end{aligned}$ | $\cdots$ |
| LSL (opr) <br>  <br> LSLA <br> LSLB | Logical Shift Left | $\square_{C} \leftarrow \prod_{b 7}^{\prod \prod_{b 0}}<0$ | EXT IND, X IND, Y A INH B INH | 78 68 1868 48 58 | hh II ff ff | $\begin{aligned} & 3 \\ & 2 \\ & 3 \\ & 1 \\ & 1 \\ & \hline \end{aligned}$ | $\begin{aligned} & 6 \\ & 6 \\ & 7 \\ & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & \hline 5-8 \\ & 6-3 \\ & 3-7 \\ & 2-1 \\ & 2-1 \\ & \hline \end{aligned}$ | $\cdots$ |
| LSLD | Logical Shift Left Double | $\square_{\mathrm{C}}^{\square}-\square_{\mathrm{b} 15} \longleftarrow-\square_{\mathrm{b} 0} \leftarrow 0$ | INH | 05 |  | 1 | 3 | 2-2 | $\cdots$ |
| LSR (opr) <br> LSRA <br> LSRB | Logical Shift Right |  | EXT IND, X IND,Y A INH B INH | 74 64 1864 44 54 | hh II <br> ff  <br> ff  <br>   | $\begin{array}{\|l\|} \hline 3 \\ 2 \\ 3 \\ 1 \\ 1 \\ \hline \end{array}$ | $\begin{aligned} & 6 \\ & 6 \\ & 7 \\ & 2 \\ & 2 \end{aligned}$ | $\begin{aligned} & \hline 5-8 \\ & 6-3 \\ & 7-3 \\ & 2-1 \\ & 2-1 \end{aligned}$ | $\cdots$ |
| LSRD | Logical Shift Right Double |  | INH | 04 |  | 1 | 3 | 2-2 | $\cdots$ |
| MUL | Multiply 8 by 8 | $\mathrm{AxB} \rightarrow \mathrm{D}$ | INH | 3D |  | 1 | 10 | 2-13 | $\cdots$ |

*Cycle-by-cycle number provides a reference to Tables 10-2 through 10-8 which detail cycle-by-cycle operation.
Example: Table 10-1 Cycle-by-Cycle column reference number 2-4 equals Table 10-2 line item 2-4.

Table 10-1. MC68HC11A8 Instructions, Addressing Modes, and Execution Times (Sheet 5 of 7)

| Source <br> Form(s) | Operation | Boolean Expression | Addressing Mode for Operand | Machine Coding (Hexadecimal) |  | $\stackrel{\otimes}{\underset{\sim}{\mathbf{c}}}$ | $\frac{0}{0}$ | Cycle by Cycle* | $\begin{array}{\|l\|} \hline \text { Condition Codes } \\ \hline \text { S X H I N Z V C } \\ \hline \end{array}$ |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Opcode | Operand(s) |  |  |  |  |
| NEG (opr) | 2's Complement Memory Byte | $0-M \rightarrow M$ | EXT | 70 | hh II | 3 | 6 | 5-8 | $\cdots$ |
|  |  |  | IND, X | 60 | $f$ | 2 | 6 | 6-3 |  |
|  |  |  | IND, Y | 1860 | $f$ | 3 | 7 | 7-3 |  |
| NEGA | 2's Complement A | $0-A \rightarrow A$ | A INH | 40 |  | 1 | 2 | 2-1 | $\cdots$ |
| NEGB | 2's Complement B | $0-B \rightarrow B$ | B INH | 50 |  | 1 | 2 | 2-1 | $\cdots$ |
| NOP | No Operation | No Operation | INH | 01 |  | 1 | 2 | 2-1 | - - - |
| ORAA (opr) | OR Accumulator A (Inclusive) | $A+M \rightarrow A$ | A IMM | 8A | ii | 2 | 2 | 3-1 | $\cdots$ |
|  |  |  | A DIR | 9A | dd | 2 | 3 | 4-1 |  |
|  |  |  | A EXT | BA | hh II | 3 | 4 | 5-2 |  |
|  |  |  | A IND, X | AA | $f$ | 2 | 4 | 6-2 |  |
|  |  |  | A IND, Y | 18 AA | ff | 3 | 5 | 7-2 |  |
| ORAB (opr) | OR Accumulator B (Inclusive) | $B+M \rightarrow B$ | B IMM | CA | ii | 2 | 2 | 3-1 | $\cdots$ |
|  |  |  | B DIR | DA | dd | 2 | 3 | 4-1 |  |
|  |  |  | B EXT | FA | hh II | 3 | 4 | 5-2 |  |
|  |  |  | $B$ IND, $X$ | EA | ff | 2 | 4 | 6-2 |  |
|  |  |  | B IND, Y | 18 EA | $f$ | 3 | 5 | 7-2 |  |
| PSHA | Push A onto Stack | A $\rightarrow$ Stk, SP $=$ SP-1 | A INH | 36 |  | 1 | 3 | 2-6 | - - - - - - |
| PSHB | Push B onto Stack | $\mathrm{B} \rightarrow$ Stk, SP $=$ SP-1 | B INH | 37 |  | 1 | 3 | 2-6 | - - - - - |
| PSHX | Push X onto Stack (Lo First) | $\mathrm{IX} \rightarrow$ Stk, SP = SP-2 | INH | 3C |  | 1 | 4 | 2-7 | - - |
| PSHY | Push Y onto Stack (Lo First) | $\mathrm{I} \mathrm{Y} \rightarrow$ Stk, SP = SP-2 | INH | 183 C |  | 2 | 5 | 2-8 | - - |
| PULA | Pull A from Stack | SP $=$ SP + 1, A $\leftarrow$ Stk | A INH | 32 |  | 1 | 4 | 2-9 | - - - - - |
| PULB | Pull B from Stack | $S P=S P+1, B \leftarrow S t k$ | B INH | 33 |  | 1 | 4 | 2-9 | $\cdots$ |
| PULX | Pull X from Stack (Hi First) | $S P=S P+2, I X \leftarrow S t k$ | INH | 38 |  | 1 | 5 | 2-10 | - - - - - - |
| PULY | Pull Y from Stack (Hi First) | $S P=S P+2, I Y \leftarrow S t k$ | INH | 1838 |  | 2 | 6 | 2-11 | - - - - - - - |
| ROL (opr) | Rotate Left | $\square_{\mathrm{C}} \leftarrow \prod_{\mathrm{b}}$ | EXT | 79 | hh II | 3 | 6 | 5-8 | $\cdots$ |
|  |  |  | IND, X | 69 | ff | 2 | 6 | 6-3 |  |
|  |  |  | IND, Y | 1869 | $f$ | 3 | 7 | 7-3 |  |
| ROLA |  |  | A INH | 49 |  | 1 | 2 | 2-1 |  |
| ROLB |  |  | B INH | 59 |  | 1 | 2 | 2-1 |  |
| ROR (opr) | Rotate Right |  | EXT | 76 | hh II | 3 | 6 | 5-8 | $\cdots$ |
|  |  |  | IND, X | 66 | ff | 2 | 6 | 6-3 |  |
|  |  |  | IND, Y | 1866 | $f$ | 3 | 7 | 7-3 |  |
| RORA |  |  | A INH | 46 |  | 1 | 2 | 2-1 |  |
| RORB |  |  | B INH | 56 |  | 1 | 2 | 2-1 |  |
| RTI | Return from Interrupt | See Special Ops | INH | 3B |  | 1 | 12 | 2-14 | $\downarrow \downarrow \downarrow \downarrow \downarrow \downarrow \downarrow \downarrow$ |
| RTS | Return from Subroutine | See Special Ops | INH | 39 |  | 1 | 5 | 2-12 | $\cdots$ |
| SBA | Subtract B from A | $A-B \rightarrow A$ | INH | 10 |  | 1 | 2 | 2-1 | $\cdots$ |
| SBCA (opr) | Subtract with Carry from A | $A-M-C \rightarrow A$ | A IMM | 82 | ii | 2 | 2 | 3-1 | $\cdots$ |
|  |  |  | A DIR | 92 | dd | 2 | 3 | 4-1 |  |
|  |  |  | A EXT | B2 | hh II | 3 | 4 | 5-2 |  |
|  |  |  | A IND, X | A2 | ff | 2 | 4 | 6-2 |  |
|  |  |  | A IND, Y | 18 A2 | ff | 3 | 5 | 7-2 |  |
| SBCB (opr) | Subtract with Carry from B | $B-M-C \rightarrow B$ | B IMM | C2 | ii | 2 | 2 | 3-1 | $\cdots$ |
|  |  |  | B DIR | D2 | dd | 2 | 3 | 4-1 |  |
|  |  |  | B EXT | F2 | hh II | 3 | 4 | 5-2 |  |
|  |  |  | B IND, $X$ | E2 | $f$ | 2 | 4 | 6-2 |  |
|  |  |  | B IND, Y | 18 E 2 | $f$ | 3 | 5 | 7-2 |  |
| SEC | Set Carry | $1 \rightarrow \mathrm{C}$ | INH | OD |  | 1 | 2 | 2-1 | ---.--1 |
| SEI | Set Interrupt Mask | $1 \rightarrow 1$ | INH | OF |  | 1 | 2 | 2-1 | $\cdots$ |
| SEV | Set Overflow Flag | $1 \rightarrow \mathrm{~V}$ | INH | OB |  | 1 | 2 | 2-1 | $\cdots-\cdots-1$ |

*Cycle-by-cycle number provides a reference to Tables 10-2 through 10-8 which detail cycle-by-cycle operation. Example: Table 10-1 Cycle-by-Cycle column reference number 2-4 equals Table 10-2 line item 2-4.

Table 10-1. MC68HC11A8 Instructions, Addressing Modes, and Execution Times (Sheet 6 of 7)

| Source <br> Form(s) | Operation | Boolean Expression | Addressing Mode for Operand | Machine Coding (Hexadecimal) |  |  | 응 |  | Condition Codes <br> S X H IN Z V C |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Opcode | Operand(s) |  | U |  |  |
| STAA (opr) | Store Accumulator A | $A \rightarrow M$ | A DIR | 97 | dd | 2 | 3 | 4-2 | $\cdots \cdots$ |
|  |  |  | A EXT | B7 | hh II | 3 | 4 | 5-3 |  |
|  |  |  | A IND, X | A7 | $f$ | 2 | 4 | 6-5 |  |
|  |  |  | A IND, Y | 18 A7 | $f$ | 3 | 5 | 7-5 |  |
| STAB (opr) | Store Accumulator B | $B \rightarrow M$ | B DIR | D7 | dd | 2 | 3 | 4-2 | $\cdots$ |
|  |  |  | B EXT | F7 | hh II | 3 | 4 | 5-3 |  |
|  |  |  | B IND, X | E7 | $f$ | 2 | 4 | 6-5 |  |
|  |  |  | B IND, Y | 18 E7 | ff | 3 | 5 | 7-5 |  |
| STD (opr) | Store Accumulator D | $\mathrm{A} \rightarrow \mathrm{M}, \mathrm{B} \rightarrow \mathrm{M}+1$ | DIR | DD | dd | 2 | 4 | 4-4 | $\cdots$ |
|  |  |  | EXT | FD | hh II | 3 | 5 | 5-5 |  |
|  |  |  | IND, X | ED | ff | 2 | 5 | 6-8 |  |
|  |  |  | IND, Y | 18 ED | ff | 3 | 6 | 7-7 |  |
| STOP | Stop Internal Clocks |  | INH | CF |  | 1 | 2 | 2-1 | - - |
| STS (opr) | Store Stack Pointer | $S P \rightarrow M: M+1$ | DIR | 9 F | dd | 2 | 4 | 4-4 | $\cdots$ |
|  |  |  | EXT | BF | hh II | 3 | 5 | 5-5 |  |
|  |  |  | IND, X | AF | $f f$ | 2 | 5 | 6-8 |  |
|  |  |  | IND, Y | 18 AF | $f f$ | 3 | 6 | 7-7 |  |
| STX (opr) | Store Index Register X | $I X \rightarrow M: M+1$ | DIR | DF | dd | 2 | 4 | 4-4 | $\cdots$ |
|  |  |  | EXT | FF | hh II | 3 | 5 | 5-5 |  |
|  |  |  | IND, X | EF | $f$ | 2 | 5 | 6-8 |  |
|  |  |  | IND, Y | CD EF | $f$ | 3 | 6 | 7-7 |  |
| STY (opr) | Store Index Register Y | $\mathrm{IY} \rightarrow \mathrm{M}: \mathrm{M}+1$ | DIR | 18 DF | dd | 3 | 5 | 4-6 | $\cdots$ |
|  |  |  | EXT | 18 FF | hh II | 4 | 6 | 5-7 |  |
|  |  |  | IND, X | 1 AEF | ff | 3 | 6 | 6-9 |  |
|  |  |  | IND, Y | 18 EF | ff | 3 | 6 | 7-7 |  |
| SUBA (opr) | Subtract Memory from A | $A-M \rightarrow A$ | A IMM | 80 | ii | 2 | 2 | 3-1 | $\cdots$ |
|  |  |  | A DIR | 90 | dd | 2 | 3 | 4-1 |  |
|  |  |  | A EXT | B0 | hh II | 3 | 4 | 5-2 |  |
|  |  |  | A IND, X | A0 | $f$ | 2 | 4 | 6-2 |  |
|  |  |  | A IND, Y | 18 AO | $f$ | 3 | 5 | 7-2 |  |
| SUBB (opr) | Subtract Memory from B | $B-M \rightarrow B$ | B IMM | C0 | ii | 2 | 2 | 3-1 | $\cdots$ |
|  |  |  | B DIR | D0 | dd | 2 | 3 | 4-1 |  |
|  |  |  | B EXT | F0 | hh II | 3 | 4 | 5-2 |  |
|  |  |  | B IND, $X$ | E0 | ff | 2 | 4 | 6-2 |  |
|  |  |  | B IND, Y | 18 E0 | ff | 3 | 5 | 7-2 |  |
| SUBD (opr) | Subtract Memory from D | $D-M: M+1 \rightarrow D$ |  | 83 | jj kk | 3 | 4 | 3-3 | $\cdots \cdots$ |
|  |  |  | DIR | 93 | dd | 2 | 5 | 4-7 |  |
|  |  |  | EXT | B3 | hh II | 3 | 6 | 5-10 |  |
|  |  |  | IND, X | A3 | $f$ | 2 | 6 | 6-10 |  |
|  |  |  | IND, Y | 18 A3 | ff | 3 | 7 | 7-8 |  |
| SWI | Software Interrupt | See Special Ops | INH | 3 F |  | 1 | 14 | 2-15 | - - 1-- - |
| TAB | Transfer A to B | A $\rightarrow$ B | INH | 16 |  | 1 | 2 | 2-1 | $\cdots$ |
| TAP | Transfer A to CC Register | $A \rightarrow$ CCR | INH | 06 |  | 1 | 2 | 2-1 | $\downarrow \downarrow \downarrow \downarrow \uparrow \downarrow \downarrow \downarrow$ |
| TBA | Transfer B to A | $\mathrm{B} \rightarrow \mathrm{A}$ | INH | 17 |  | 1 | 2 | 2-1 | $\cdots$ |
| TEST | TEST (Only in Test Modes) | Address Bus Counts | INH | 00 |  | 1 | ** | 2-20 | - - - - - - |
| TPA | Transfer CC Register to A | $\mathrm{CCR} \rightarrow \mathrm{A}$ | INH | 07 |  | 1 | 2 | 2-1 | - - - |
| TST (opr) | Test for Zero or Minus | M - 0 | EXT | 7D | hh II | 3 | 6 | 5-9 | $\cdots \cdots$ |
|  |  |  | IND, X | 6D | $f$ | 2 | 6 | 6-4 |  |
|  |  |  | IND, Y | 18 6D | ff | 3 | 7 | 7-4 |  |
| TSTA |  | A-0 | A INH | 4D |  | 1 | 2 | 2-1 | $\cdots$ |
| TSTB |  | B-0 | B INH | 5D |  | 1 | 2 | 2-1 | $\cdots$ |
| TSX | Transfer Stack Pointer to X | $\mathrm{SP}+1 \rightarrow \mathrm{IX}$ | INH | 30 |  | 1 | 3 | 2-3 | - - - - - - |
| TSY | Transfer Stack Pointer to $Y$ | $\mathrm{SP}+1 \rightarrow \mathrm{IY}$ | INH | 1830 |  | 2 | 4 | 2-5 | - - - - - - |

[^1]Example: Table 10-1 Cycle-by-Cycle column reference number 2-4 equals Table 10-2 line item 2-4.

Table 10-1. MC68HC11A8 Instructions, Addressing Modes, and Execution Times (Sheet 7 of 7)

| Source | Operation | Boolean Expression | Addressing Mode for Operand | Machine Coding (Hexadecimal) |  | $\underbrace{\infty}_{\infty}$ | $\stackrel{9}{0}$ | Cycle by Cycle* | Condition Codes |  |  |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| Form(s) |  |  |  | Opcode | Operand(s) |  | 0 |  |  | S H | HIN | N Z | V C |
| TXS | Transfer X to Stack Pointer | $\mathrm{IX}-1 \rightarrow \mathrm{SP}$ | INH | 35 |  | 1 | 3 | 2-2 | - | - - | - | - - | - - |
| TYS | Transfer Y to Stack Pointer | $\mathrm{IY}-1 \rightarrow \mathrm{SP}$ | INH | 1835 |  | 2 | 4 | 2-4 | - | - - | - | - - | - - |
| WAI | Wait for Interrupt | Stack Regs \& WAIT | INH | 3E |  | 1 | *** | 2-16 | - | - - | - | - - | - - |
| XGDX | Exchange D with X | IX $\rightarrow$ D, D $\rightarrow$ IX | INH | 8F |  | 1 | 3 | 2-2 |  | - - | - | - - | - - |
| XGDY | Exchange D with Y | IY $\rightarrow$ D, D $\rightarrow$ IY | INH | 188 F |  | 2 | 4 | 2-4 |  | - - | - | - - | - - |

*Cycle-by-cycle number provides a reference to Tables 10-2 through 10-8 which detail cycle-by-cycle operation.
Example: Table 10-1 Cycle-by-Cycle column reference number 2-4 equals Table 10-2 line item 2-4.
**Infinity or Until Reset Occurs
***12 Cycles are used beginning with the opcode fetch. A wait state is entered which remains in effect for an integer number of MPU E-clock cycles ( $n$ ) until an interrupt is recognized. Finally, two additional cycles are used to fetch the appropriate interrupt vector ( $14+n$ total).
dd $=8$-Bit Direct Address ( $\$ 0000-\$ 00 F F)$ (High Byte Assumed to be $\$ 00$ )
$\mathrm{ff}=8$-Bit Positive Offset $\$ 00(0)$ to $\$ F F$ (255) (Is Added to Index)
hh $=$ High Order Byte of 16-Bit Extended Address
ii = One Byte of Immediate Data
jj $=$ High Order Byte of 16-Bit Immediate Data
kk = Low Order Byte of 16-Bit Immediate Data
II = Low Order Byte of 16-Bit Extended Address
$\mathrm{mm}=8$-Bit Bit Mask (Set Bits to be Affected)
rr $=$ Signed Relative Offset $\$ 80(-128)$ to $\$ 7 F(+127)$
(Offset Relative to the Address Following the Machine Code Offset Byte)


INDEXED, $X\left\{\right.$|  | MAIN PROGRAM |
| :---: | :---: |
| PC | $\$ A D=$ JSR |
|  |  |
| RTN | NEXT MAIN INSTR. |
|  |  |




JMP, JUMP


WAI, WAIT FOR INTERRUPT


SWI, SOFTWARE INTERRUPT


BSR, BRANCH TO SUBROUTINE


RTS, RETURN FROM
SUBROUTINE


## LEGEND:

RTN = ADDRESS OF NEXT INSTRUCTION IN MAIN PROGRAM TO BE EXECUTED UPON RETURN FROM SUBROUTINE
RTN $_{H}=$ MOST SIGNIFICANT BYTE OF RETURN ADDRESS
RTN $=$ LEAST SIGNIFICANT BYTE OF RETURN ADDRESS
$\zeta=$ STACK POINTER POSITION AFTER OPERATION IS COMPLETE $\mathrm{dd}=8$-BIT DIRECT ADDRESS ( $\$ 0000-\$ 00 \mathrm{FF}$ ) (HIGH BYTE ASSUMED TO BE \$00)
$\mathrm{ff}=8$-BIT POSITIVE OFFSET $\$ 00$ (0) TO \$FF (256) IS ADDED TO INDEX hh = HIGH-ORDER BYTE OF 16-BIT EXTENDED ADDRESS
$\|=$ LOW-ORDER BYTE OF 16-BIT EXTENDED ADDRESS
$\mathrm{rr}=$ SIGNED RELATIVE OFFSET $\$ 80(-128)$ TO $\$ 7 \mathrm{~F}$ ( +127 ) (OFFSET RELATIVE TO THE ADDRESS FOLLOWING THE MACHINE CODE OFFSET BYTE)

Figure 10-2. Special Operations

Table 10-2. Cycle-by-Cycle Operation - Inherent Mode (Sheet 1 of 3)

| Reference Number* | Address Mode and Instructions | Cycles | Cycle \# | Address Bus | $\begin{aligned} & \mathbf{R} / \bar{W} \\ & \text { Line } \end{aligned}$ | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 2-1 | ABA, ASLA, ASLB, ASRA, ASRB, CBA, CLC, CLI, CLRA, CLRB, CLV, COMA, COMB, DAA, DECA, DECB, INCA, INCB, LSLA, LSLB, LSRA, LSRB, NEGA, NEGB, NOP, ROLA, ROLB, RORA, RORB, SBA, SEC, SEI, SEV, STOP, TAB, TAP, TBA, TPA, TSTA, TSTB | 2 | $\begin{aligned} & 1 \\ & 2 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | Opcode Irrelevant Data |
| 2-2 | $\begin{aligned} & \text { ABX, ASLD, DEX, } \\ & \text { INX, LSLD, LSRD, } \\ & \text { TXS, XGDX } \end{aligned}$ | 3 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & \hline \end{aligned}$ | Opcode Address <br> Opcode Address + 1 \$FFFF | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & \hline \end{aligned}$ | Opcode Irrelevant Data Irrelevant Data |
| 2-3 | DES, INS, TSX | 3 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \end{aligned}$ | Opcode Address Opcode Address + 1 Previous SP Value | $\begin{aligned} & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode Irrelevant Data Irrelevant Data |
| 2-4 | ABY, DEY, INY, <br> TYS, XGDY | 4 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 <br> \$FFFF | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & \text { Opcode (Page Select Byte) (\$18) } \\ & \text { Opcode (Second Byte) } \\ & \text { Irrelevant Data } \\ & \text { Irrelevant Data } \\ & \hline \end{aligned}$ |
| 2-5 | TSY | 4 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 <br> Stack Pointer | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | ```Opcode (Page Select Byte)($18) Opcode (Second Byte) ($30) Irrelevant Data Irrelevant Data``` |
| 2-6 | PSHA, PSHB | 3 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & \hline \end{aligned}$ | Opcode Address Opcode Address + 1 Stack Pointer | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & \hline \end{aligned}$ | Opcode Irrelevant Data Accumulator Data |
| 2-7 | PSHX | 4 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Stack Pointer <br> Stack Pointer - 1 | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 0 \end{aligned}$ | Opcode (\$3C) Irrelevant Data IXL (Low Byte) to Stack IXH (High Byte) to Stack |
| 2-8 | PSHY | 5 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 <br> Stack Pointer <br> Stack Pointer - 1 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 0 \\ & 0 \end{aligned}$ | Opcode (Page Select Byte) (\$18) <br> Opcode (Second Byte) (\$3C) <br> Irrelevant Data <br> IXL (Low Byte) to Stack <br> IXH (High Byte) to Stack |
| 2-9 | PULA, PULB | 4 | $\begin{aligned} & \hline 1 \\ & 2 \\ & 3 \\ & 4 \\ & \hline \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Stack Pointer <br> Stack Pointer + 1 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode Irrelevant Data Irrelevant Data Operand Data from Stack |
| 2-10 | PULX | 5 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Stack Pointer <br> Stack Pointer + 1 <br> Stack Pointer + 2 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode (\$38) <br> Irrelevant Data <br> Irrelevant Data <br> IXH (High Byte) from Stack <br> IXL (Low Byte) from Stack |
| 2-11 | PULY | 6 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 <br> Stack Pointer <br> Stack Pointer +1 <br> Stack Pointer + 2 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | $\begin{aligned} & \text { Opcode (Page Select Byte) (\$18) } \\ & \text { Opcode (Second Byte) (\$38) } \\ & \text { Irrelevant Data } \\ & \text { Irrelevant Data } \\ & \text { IYH (High Byte) from Stack } \\ & \text { IYH (Low Byte) from Stack } \\ & \hline \end{aligned}$ |

*The reference number is given to provide a cross-reference to Table 10-1

Table 10-2. Cycle-by-Cycle Operation — Inherent Mode (Sheet 2 of 3)

| Reference Number* | Address Mode and Instructions | Cycles | Cycle \# | Address Bus | $\begin{aligned} & \mathrm{R} / \overline{\mathrm{W}} \\ & \text { Line } \end{aligned}$ | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 2-12 | RTS | 5 | 1 | Opcode Address | 1 | Opcode (\$39) |
|  |  |  | 2 | Opcode Address + 1 | 1 | Irrelevant Data |
|  |  |  | 3 | Stack Pointer | 1 | Irrelevant Data |
|  |  |  | 4 | Stack Pointer +1 | 1 | Address of Next Instruction (High Byte) |
|  |  |  | 5 | Stack Pointer + 2 | 1 | Address of Next Instruction (Low Byte) |
| 2-13 | MUL | 10 | 1 | Opcode Address | 1 | Opcode (\$3D) |
|  |  |  | 2 | Opcode Address + 1 | 1 | Irrelevant Data |
|  |  |  | 3 | \$FFFF | 1 | Irrelevant Data |
|  |  |  | 4 | \$FFFF | 1 | Irrelevant Data |
|  |  |  | 5 | \$FFFF | 1 | Irrelevant Data |
|  |  |  | 6 | \$FFFF | 1 | Irrelevant Data |
|  |  |  | 7 | \$FFFF | 1 | Irrelevant Data |
|  |  |  | 8 | \$FFFF | 1 | Irrelevant Data |
|  |  |  | 9 | \$FFFF | 1 | Irrelevant Data |
|  |  |  | 10 | \$FFFF | 1 | Irrelevant Data |
| 2-14 | RTI | 12 | 1 | Opcode Address | 1 | Opcode (\$3B) |
|  |  |  | 2 | Opcode Address + 1 | 1 | Irrelevant Data |
|  |  |  | 3 | Stack Pointer | 1 | Irrelevant Data |
|  |  |  | 4 | Stack Pointer + 1 | 1 | Condition Code Register from Stack |
|  |  |  | 5 | Stack Pointer + 2 | 1 | B Accumulator from Stack |
|  |  |  | 6 | Stack Pointer + 3 | 1 | A Accumulator from Stack |
|  |  |  | 7 | Stack Pointer +4 | 1 | IXH (High Byte) from Stack |
|  |  |  | 8 | Stack Pointer +5 | 1 | IXL (Low Byte) from Stack |
|  |  |  | 9 | Stack Pointer +6 | 1 | IYH (High Byte) from Stack |
|  |  |  | 10 | Stack Pointer +7 | 1 | IYL (Low Byte) from Stack |
|  |  |  | 11 | Stack Pointer + 8 | 1 | Address of Next Instruction (High Byte) |
|  |  |  | 12 | Stack Pointer + 9 | 1 | Address of Next Instruction (Low Byte) |
| 2-15 | SWI | 14 | 1 | Opcode Address | 1 | Opcode (\$3F) |
|  |  |  | 2 | Opcode Address + 1 | 1 | Irrelevant Data |
|  |  |  | 3 | Stack Pointer | 0 | Return Address (Low Byte) |
|  |  |  | 4 | Stack Pointer - 1 | 0 | Return Address (High Byte) |
|  |  |  | 5 | Stack Pointer - 2 | 0 | IYL (Low Byte) to Stack |
|  |  |  | 6 | Stack Pointer - 3 | 0 | IYH (High Byte) to Stack |
|  |  |  | 7 | Stack Pointer - 4 | 0 | IXL (Low Byte) to Stack |
|  |  |  | 8 | Stack Pointer - 5 | 0 | IXH (High Byte) to Stack |
|  |  |  | 9 | Stack Pointer - 6 | 0 | A Accumulator to Stack |
|  |  |  | 10 | Stack Pointer - 7 | 0 | B Accumulator to Stack |
|  |  |  | 11 | Stack Pointer - 8 | 0 | Condition Code Register to Stack |
|  |  |  | 12 | Stack Pointer - 8 | 1 | Irrelevant Data |
|  |  |  | 13 | Address of SWI Vector (First Location) | 1 | SWI Service Routine Address (High Byte) |
|  |  |  | 14 | Address of Vector + 1 <br> (Second Location) | 1 | SWI Service Routine Address (Low Byte) |
| 2-16 | WAI | $14+n$ | 1 | Opcode Address | 1 | Opcode (\$3E) |
|  |  |  | 2 | Opcode Address + 1 | 1 | Irrelevant Data |
|  |  |  | 3 | Stack Pointer | 0 | Return Address (Low Byte) |
|  |  |  | 4 | Stack Pointer - 1 | 0 | Return Address (High Byte) |
|  |  |  | 5 | Stack Pointer - 2 | 0 | IYL (Low Byte) to Stack |
|  |  |  | 6 | Stack Pointer - 3 | 0 | IYH (High Byte) to Stack |
|  |  |  | 7 | Stack Pointer - 4 | 0 | IXL (Low Byte) to Stack |
|  |  |  | 8 | Stack Pointer - 5 | 0 | IXH (High Byte) to Stack |
|  |  |  | 9 | Stack Pointer - 6 | 0 | A Accumulator to Stack |

[^2]Table 10-2. Cycle-by-Cycle Operation - Inherent Mode (Sheet 3 of 3)

| Reference Number* | Address Mode and Instructions | Cycles | Cycle \# | Address Bus | $\begin{aligned} & \mathrm{R} / \overline{\mathrm{W}} \\ & \text { Line } \end{aligned}$ | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| $2-16$ (Continued) | WAI | $14+n$ | $\begin{gathered} 10 \\ 11 \\ 12 \text { to } \\ n+12 \\ n+13 \\ n+14 \end{gathered}$ | Stack Pointer - 7 <br> Stack Pointer - 8 <br> Stack Pointer - 8 <br> Address of Vector <br> (First Location) <br> Address of Vector + 1 <br> (Second Location) | $\begin{aligned} & \hline 0 \\ & 0 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | B Accumulator to Stack Condition Code Register to Stack <br> Irrelevant Data <br> Service Routine Address (High Byte) <br> Service Routine Address (Low Byte) |
| 2-17 | FDIV, IDIV | 41 | $\begin{gathered} 1 \\ 2 \\ 3-41 \\ \hline \end{gathered}$ | Opcode Address <br> Opcode Address + 1 <br> \$FFFF | $\begin{aligned} & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode Irrelevant Data Irrelevant Data |
| 2-18 | Page 1 Illegal Opcodes | 15 | $\begin{gathered} \hline 1 \\ 2 \\ 3 \\ 4 \\ 5 \\ 5 \\ 6 \\ 7 \\ 8 \\ 9 \\ 10 \\ 11 \\ 12 \\ 13 \\ 14 \\ \\ 15 \end{gathered}$ | Opcode Address <br> Opcode Address + 1 <br> \$FFFF <br> Stack Pointer <br> Stack Pointer - 1 <br> Stack Pointer - 2 <br> Stack Pointer - 3 <br> Stack Pointer-4 <br> Stack Pointer - 5 <br> Stack Pointer - 6 <br> Stack Pointer - 7 <br> Stack Pointer - 8 <br> Stack Pointer - 8 <br> Address of Vector <br> (First Location) <br> Address of Vector + 1 <br> (Second Location) | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 1 \\ & 1 \end{aligned}$ | Opcode (Illegal) <br> Irrelevant Data <br> Irrelevant Data <br> Return Address (Low Byte) <br> Return Address (High Byte) <br> IYL (Low Byte) to Stack <br> IYH (High Byte) to Stack <br> IXL (Low Byte) to Stack <br> IXH (High Byte) to Stack <br> A Accumulator <br> B Accumulator <br> Condition Code Register to Stack <br> Irrelevant Data <br> Service Routine Address (High Byte) <br> Service Routine Address (Low Byte) |
| 2-19 | $\begin{aligned} & \text { Pages 2, 3, or } 4 \\ & \text { Illegal Opcodes } \end{aligned}$ | 16 | $\begin{gathered} \hline 1 \\ 2 \\ 3 \\ 4 \\ 4 \\ 5 \\ 6 \\ 7 \\ 7 \\ 8 \\ 9 \\ 10 \\ 11 \\ 12 \\ 13 \\ 14 \\ 15 \\ \\ 16 \end{gathered}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 <br> \$FFFF <br> Stack Pointer <br> Stack Pointer - 1 <br> Stack Pointer - 2 <br> Stack Pointer-3 <br> Stack Pointer - 4 <br> Stack Pointer - 5 <br> Stack Pointer - 6 <br> Stack Pointer - 7 <br> Stack Pointer - 8 <br> Stack Pointer - 8 <br> Address of Vector <br> (First Location) <br> Address of Vector + 1 <br> (Second Location) | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 0 \\ & 1 \\ & 1 \end{aligned}$ | Opcode (Legal Page Select) <br> Opcode (Illegal Second Byte) <br> Irrelevant Data <br> Irrelevant Data <br> Return Address (Low Byte) <br> Return Address (High Byte) <br> IYL (Low Byte) to Stack <br> IYH (High Byte) to Stack <br> IXL (Low Byte) to Stack <br> IXH (High Byte) to Stack <br> A Accumulator <br> B Accumulator <br> Condition Code Register to Stack <br> Irrelevant Data <br> Service Routine Address (High Byte) <br> Service Routine Address (Low Byte) |
| 2-20 | TEST | Infinite | $\begin{gathered} 1 \\ 2 \\ 3 \\ 4 \\ 5-n \end{gathered}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address +1 <br> Opcode Address + 2 <br> Previous Address + 1 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode (\$00) Irrelevant Data Irrelevant Data Irrelevant Data Irrelevant Data |

[^3]Table 10-3. Cycle-by-Cycle Operation - Immediate Mode

| Reference Number* | Address Mode and Instructions | Cycles | Cycle \# | Address Bus | $\begin{aligned} & \mathrm{R} / \overline{\mathrm{W}} \\ & \text { Line } \end{aligned}$ | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 3-1 | ADCA, ADCB, ADDA, ADDB, ANDA, ANDB, BITA, BITB, CMPA, CMPB, EORA, EORB, LDAA, LDAB, ORAA, ORAB, SBCA, SBCB, SUBA, SUBB, | 2 | $\begin{aligned} & 1 \\ & 2 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | Opcode <br> Operand Data |
| 3-2 | LDD, LDS, LDX | 3 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode <br> Operand Data (High Byte) <br> Operand Data (Low Byte) |
| 3-3 | ADDD, CPX, SUBD | 4 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 <br> \$FFFF | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode <br> Operand Data (High Byte) <br> Operand Data (Low Byte) <br> Irrelevant Data |
| 3-4 | LDY | 4 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 <br> Opcode Address + 3 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & \hline \end{aligned}$ | Opcode (Page Select Byte) (\$18) <br> Opcode (Second Byte) (\$EC) <br> Operand Data (High Byte) <br> Operand Data (Low Byte) |
| 3-5 | CPD, CPY | 5 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 <br> Opcode Address + 3 <br> \$FFFF | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode (Page Select Byte) <br> Opcode (Second Byte) <br> Operand Data (High Byte) <br> Operand Data (Low Byte) <br> Irrelevant Data |

*The reference number is given to provide a cross-reference to Table 10-1
Table 10-4. Cycle-by-Cycle Operation - Direct Mode (Sheet 1 of 2)

| Reference Number* | Address Mode and Instructions | Cycles | $\begin{gathered} \text { Cycle } \\ \# \# \end{gathered}$ | Address Bus | $\begin{aligned} & \mathrm{R} / \overline{\mathrm{W}} \\ & \text { Line } \end{aligned}$ | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 4-1 | ADCA, ADCB, ADDA, ADDB, ANDA, ANDB, BITA, BITB, CMPA, CMPB, EORA, EORB, LDAA, LDAB, ORAA, ORAB, SBCA, SBCB, SUBA, SUBB | 3 | $2$ | Opcode Address Opcode Address + 1 <br> Operand Address | $\begin{aligned} & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode Operand Address (Low Byte) <br> (High Byte Assumed to be \$00) Operand Data |
| 4-2 | STAA, STAB | 3 | $2$ <br> 3 | Opcode Address Opcode Address + 1 <br> Operand Address | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | Opcode Operand Address (Low Byte) <br> (High Byte Assumed to be \$00) Data from Accumulator |
| 4-3 | LDD, LDS, LDX | 4 | $2$ | Opcode Address Opcode Address + 1 <br> Operand Address <br> Operand Address + 1 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode <br> Operand Address (Low Byte) <br> (High Byte Assumed to be \$00) <br> Operand Data (High Byte) <br> Operand Data (Low Byte) |
| 4-4 | STD, STS, STX | 4 | 2 <br> 3 | Opcode Address Opcode Address +1 Operand Address Operand Address + 1 | 1 1 0 0 | Opcode <br> Operand Address (Low Byte) <br> (High Byte Assumed to be \$00) <br> Register Data (High Byte) <br> Register Data (Low Byte) |
| 4-5 | LDY | 5 | $\begin{aligned} & 1 \\ & 2 \end{aligned}$ | Opcode Address Opcode Address + 1 Opcode Address + 2 Operand Address Operand Address + 1 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode (Page Select Byte) (\$18) Opcode (Second Byte) (\$DE) Operand Address (Low Byte) <br> (High Byte Assumed to be \$00) Operand Data (High Byte) Operand Data (Low Byte) |

[^4]Table 10-4. Cycle-by-Cycle Operation — Direct Mode (Sheet 2 of 2)

| Reference Number* | Address Mode and Instructions | Cycles | Cycle \# | Address Bus | $\begin{aligned} & \mathrm{R} / \overline{\mathrm{W}} \\ & \text { Line } \end{aligned}$ | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 4-6 | STY | 5 | 1 | Opcode Address | 1 | Opcode (Page Select Byte) (\$18) |
|  |  |  | 2 | Opcode Address + 1 | 1 | Opcode (Second Byte) (\$DF) |
|  |  |  | 3 | Opcode Address + 2 | 1 | Operand Address (Low Byte) (High Byte Assumed to be \$00) |
|  |  |  | 4 | Operand Address | 0 | Register Data (High Byte) |
|  |  |  | 5 | Operand Address + 1 | 0 | Register Data (Low Byte) |
| 4-7 | ADDD, CPX, SUBD | 5 | 1 | Opcode Address | 1 | Opcode |
|  |  |  | 2 | Opcode Address + 1 | 1 | Operand Address (Low Byte) (High Byte Assumed to be \$00) |
|  |  |  | 3 | Operand Address | 1 | Operand Data (High Byte) |
|  |  |  | 4 | Operand Address + 1 | 1 | Operand Data (Low Byte) |
|  |  |  | 5 | \$FFFF | 1 | Irrelevant Data |
| 4-8 | JSR | 5 | 1 | Opcode Address | 1 | Opcode (\$9D) |
|  |  |  | 2 | Opcode Address + 1 | 1 | Subroutine Address (Low Byte) <br> (High Byte Assumed to be \$00) |
|  |  |  | 3 | Subroutine Address | 1 | First Subroutine Opcode |
|  |  |  | 4 | Stack Pointer | 0 | Return Address (Low Byte) |
|  |  |  | 5 | Stack Pointer - 1 | 0 | Return Address (High Byte) |
| 4-9 | CPD, CPY | 6 | 1 | Opcode Address | 1 | Opcode (Page Select Byte) |
|  |  |  | 2 | Opcode Address + 1 | 1 | Opcode (Second Byte) |
|  |  |  | 3 | Opcode Address + 2 | 1 | Operand Address (Low Byte) <br> (High Byte Assumed to be \$00) |
|  |  |  | 4 | Operand Address | 1 | Operand Data (High Byte) |
|  |  |  | 5 | Operand Address + 1 | 1 | Operand Data (Low Byte) |
|  |  |  | 6 | \$FFFF | 1 | Irrelevant Data |
| 4-10 | BCLR, BSET | 6 | 1 | Opcode Address | 1 | Opcode |
|  |  |  | 2 | Opcode Address + 1 | 1 | Operand Address (Low Byte) <br> (High Byte Assumed to be \$00) |
|  |  |  | 3 | Operand Address | 1 | Original Operand Data |
|  |  |  | 4 | Opcode Address + 2 | 1 | Mask Byte |
|  |  |  | 5 | \$FFFF | 1 | Irrelevant Data |
|  |  |  | 6 | Operand Address | 0 | Result Operand Data |
| 4-11 | BRCLR, BRSET | 6 | 1 | Opcode Address | 1 | Opcode |
|  |  |  | 2 | Opcode Address + 1 | 1 | Operand Address (Low Byte) (High Byte Assumed to be \$00) |
|  |  |  | 3 | Operand Address | 1 | Original Operand Data |
|  |  |  | 4 | Opcode Address + 2 | 1 | Mask Byte |
|  |  |  | 5 | Opcode Address + 3 | 1 | Branch Offset |
|  |  |  | 6 | \$FFFF | 1 | Irrelevant Data |

*The reference number is given to provide a cross-reference to Table 10-1
Table 10-5. Cycle-by-Cycle Operation - Extended Mode (Sheet 1 of 2)

| Reference Number* | Address Mode and Instructions | Cycles | Cycle \# | Address Bus | $\begin{aligned} & \mathrm{R} / \overline{\mathrm{W}} \\ & \text { Line } \end{aligned}$ | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 5-1 | JMP | 3 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \end{aligned}$ | Opcode Address Opcode Address + 1 Opcode Address + 2 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & \hline \end{aligned}$ | $\begin{aligned} & \hline \text { Opcode (\$7E) } \\ & \text { Jump Address (High Byte) } \\ & \text { Jump Address (Low Byte) } \\ & \hline \end{aligned}$ |
| 5-2 | ADCA, ADCB, ADDA, ADDB, ANDA, ANDB, BITA, BITB, CMPA, CMPB, EORA, EORB, LDAA, LDAB, ORAA ORAB, SBCA, SBCB, SUBA, SUBB | 4 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 <br> Operand Address | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode <br> Operand Address (High Byte) <br> Operand Address (Low Byte) <br> Operand Data |

*The reference number is given to provide a cross-reference to Table 10-1

Table 10-5. Cycle-by-Cycle Operation - Extended Mode (Sheet 2 of 2)

| Reference Number* | Address Mode and Instructions | Cycles | $\begin{gathered} \hline \text { Cycle } \\ \# \\ \hline \end{gathered}$ | Address Bus | $\begin{aligned} & \mathrm{R} / \overline{\mathrm{W}} \\ & \text { Line } \end{aligned}$ | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 5-3 | STAA, STAB | 4 | $\begin{aligned} & 2 \\ & 3 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 <br> Operand Address | $1$ | Opcode <br> Operand Address (High Byte) <br> Operand Address (Low Byte) <br> Accumulator Data |
| 5-4 | LDD, LDS, LDX | 5 | $\begin{aligned} & 2 \\ & 3 \\ & 4 \\ & 5 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 <br> Operand Address <br> Operand Address + 1 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode <br> Operand Address (High Byte) Operand Address (Low Byte) Operand Data (High Byte) Operand Data (Low Byte) |
| 5-5 | STD, STS, STX | 5 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 <br> Operand Address <br> Operand Address + 1 | $0$ | Opcode <br> Operand Address (High Byte) <br> Operand Address (Low Byte) <br> Register Data (High Byte) <br> Register Data (Low Byte) |
| 5-6 | LDY | 6 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 <br> Opcode Address + 3 <br> Operand Address <br> Operand Address + 1 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & \hline \end{aligned}$ | Opcode (Page Select Byte) (\$18) Opcode (Second Byte) (\$FE) Operand Address (High Byte) Operand Address (Low Byte) Operand Data (High Byte) Operand Data (Low Byte) |
| 5-7 | STY | 6 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 <br> Opcode Address + 3 <br> Operand Address <br> Operand Address + 1 | $\begin{aligned} & 0 \\ & 0 \\ & \hline \end{aligned}$ | Opcode (Page Select Byte) (\$18) Opcode (Second Byte) (\$FF) Operand Address (High Byte) Operand Address (Low Byte) Register Data (High Byte) Register Data (Low Byte) |
| 5-8 | ASL, ASR, CLR, COM, DEC, INC, LSL, LSR, NEG, ROL, ROR | 6 | $\begin{aligned} & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 <br> Operand Address <br> \$FFFF <br> Operand Address | $\begin{aligned} & 1 \\ & 1 \\ & 0 \end{aligned}$ | Opcode <br> Operand Address (High Byte) <br> Operand Address (Low Byte) <br> Original Operand Data <br> Irrelevant Data <br> Result Operand Data |
| 5-9 | TST | 6 | $\begin{aligned} & 1 \\ & 2 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 <br> Operand Address <br> \$FFFF <br> SFFFF | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode (\$7D) <br> Operand Address (High Byte) <br> Operand Address (Low Byte) <br> Original Operand Data <br> Irrelevant Data <br> Irrelevant Data |
| 5-10 | ADDD, CPX, SUBD | 6 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \\ & \hline \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 <br> Operand Address <br> Operand Address + 1 \$FFFF | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode <br> Operand Address (High Byte) Operand Address (Low Byte) Operand Data (High Byte) Operand Data (Low Byte) Irrelevant Data |
| 5-11 | CPD, CPY | 7 | $\begin{aligned} & \hline 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \\ & 7 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 <br> Opcode Address + 3 <br> Operand Address <br> Operand Address + 1 <br> \$FFFF | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode (Page Select Byte) Opcode (Second Byte) Operand Address (High Byte) Operand Address (Low Byte) Operand Data (High Byte) Operand Data (Low Byte) Irrelevant Data |
| 5-12 | JSR | 6 | $\begin{aligned} & 2 \\ & 3 \\ & 4 \\ & 5 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 <br> Subroutine Address <br> Stack Pointer <br> Stack Pointer - 1 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 0 \end{aligned}$ | Opcode (\$BD) <br> Subroutine Address (High Byte) <br> Subroutine Address (Low Byte) <br> First Opcode in Subroutine <br> Return Address (Low Byte) <br> Return Address (High Byte) |

[^5]Table 10-6. Cycle-by-Cycle Operation - Indexed X Mode (Sheet 1 of 2)

| Reference Number* | Address Mode and Instructions | Cycles | $\begin{gathered} \hline \text { Cycle } \\ \# \end{gathered}$ | Address Bus | $\begin{aligned} & \mathrm{R} / \overline{\mathrm{W}} \\ & \text { Line } \end{aligned}$ | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 6-1 | JMP | 3 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \end{aligned}$ | Opcode Address Opcode Address + 1 SFFFF | $1$ | Opcode (\$6E) Index Offset Irrelevant Data |
| 6-2 | ADCA, ADCB, ADDA, ADDB, ANDA, ANDB, BITA, BITB, CMPA, CMPB, EORA, EORB, LDAA, LDAB, ORAA, ORAB, SBCA, SBCB, SUBA, SUBB | 4 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | Opcode Address Opcode Address + 1 \$FFFF (IX) + Offset | $\begin{aligned} & 1 \\ & 1 \end{aligned}$ | Opcode Index Offset Irrelevant Data Operand Data |
| 6-3 | ASL, ASR, CLR, COM, DEC, INC, LSL, LSR, NEG, ROL, ROR | 6 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> \$FFFF <br> (IX) + Offset <br> \$FFFF <br> (IX) + Offset | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | Opcode <br> Index Offset <br> Irrelevant Data <br> Original Operand Data <br> Irrelevant Data <br> Result Operand Data |
| 6-4 | TST | 6 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> \$FFFF <br> (IX) + Offset <br> \$FFFF <br> \$FFFF | $\begin{aligned} & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode (\$6D) Index Offset Irrelevant Data Original Operand Data Irrelevant Data Irrelevant Data |
| 6-5 | STAA, STAB | 4 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> \$FFFF <br> (IX) + Offset | $\begin{aligned} & 1 \\ & 0 \end{aligned}$ | Opcode Index Offset Irrelevant Data Accumulator Data |
| 6-6 | LDD, LDS, LDX | 5 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> \$FFFF <br> (IX) + Offset <br> (IX) + Offset + 1 | $1$ | Opcode <br> Index Offset <br> Irrelevant Data <br> Operand Data (High Byte) <br> Operand Data (Low Byte) |
| 6-7 | LDY | 6 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 <br> \$FFFF <br> (IX) + Offset <br> (IX) + Offset +1 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode (Page Select Byte) (\$1A) <br> Opcode (Second Byte) (\$EE) <br> Index Offset <br> Irrelevant Data <br> Operand Data (High Byte) <br> Operand Data (Low Byte) |
| 6-8 | STD, STS, STX | 5 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> \$FFFF <br> (IX) + Offset <br> (IX) + Offset + 1 | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 0 \\ & \hline \end{aligned}$ | Opcode <br> Index Offset <br> Irrelevant Data <br> Register Data (High Byte) <br> Register Data (Low Byte) |
| 6-9 | STY | 6 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 <br> \$FFFF <br> (IX) + Offset <br> (IX) + Offset + 1 | $\begin{aligned} & 1 \\ & 1 \\ & 0 \\ & 0 \end{aligned}$ | Opcode (Page Select Byte) (\$1A) <br> Opcode (Second Byte) (\$EF) <br> Index Offset <br> Irrelevant Data <br> Register Data (High Byte) <br> Register Data (Low Byte) |
| 6-10 | ADDD, CPX, SUBD | 6 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \end{aligned}$ | Opcode Address Opcode Address + 1 \$FFFF $\begin{aligned} & \text { (IX) + Offset } \\ & (\mathrm{IX})+\text { Offset }+1 \end{aligned}$ $\$ \text { FFFF }$ | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode <br> Index Offset <br> Irrelevant Data <br> Operand Data (High Byte) <br> Operand Data (Low Byte) <br> Irrelevant Data |

*The reference number is given to provide a cross-reference to Table 10-1

Table 10-6. Cycle-by-Cycle Operation — Indexed X Mode (Sheet 2 of 2)

| Reference Number* | Address Mode and Instructions | Cycles | Cycle \# | Address Bus | $\begin{aligned} & \mathrm{R} / \overline{\mathrm{W}} \\ & \text { Line } \end{aligned}$ | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 6-11 | CPD, CPY | 7 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \\ & 7 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 <br> \$FFFF <br> (IX) + Offset <br> (IX) + Offset +1 <br> \$FFFF | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode (Page Select Byte) <br> Opcode (Second Byte) <br> Index Offset <br> Irrelevant Data <br> Operand Data (High Byte) <br> Operand Data (Low Byte) <br> Irrelevant Data |
| 6-12 | JSR | 6 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> \$FFFF <br> (IX) + Offset <br> Stack Pointer <br> Stack Pointer - 1 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 0 \\ & 0 \end{aligned}$ | Opcode (\$AD) <br> Index Offset <br> Irrelevant Data <br> First Opcode in Subroutine <br> Return Address (Low Byte) <br> Return Address (High Byte) |
| 6-13 | BCLR, BSET | 7 | $\begin{aligned} & \hline 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \\ & 7 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> \$FFFF <br> (IX) + Offset <br> Opcode Address + 2 <br> \$FFFF <br> (IX) + Offset | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 0 \end{aligned}$ | Opcode <br> Index Offset <br> Irrelevant Data <br> Original Operand Data <br> Mask Byte <br> Irrelevant Data <br> Result Operand Data |
| 6-14 | BRCLR, BRSET | 7 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \\ & 7 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> \$FFFF <br> (IX) + Offset <br> Opcode Address + 2 <br> Opcode Address + 3 <br> \$FFFF | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode Index Offset Irrelevant Data Original Operand Data Mask Byte Branch Offset Irrelevant Data |

*The reference number is given to provide a cross-reference to Table 10-1
Table 10-7. Cycle-by-Cycle Operation — Indexed Y Mode (Sheet 1 of 2)

| Reference Number* | Address Mode and Instructions | Cycles | Cycle \# | Address Bus | $\begin{aligned} & \mathrm{R} / \overline{\mathrm{W}} \\ & \text { Line } \end{aligned}$ | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 7-1 | JMP | 4 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 <br> \$FFFF | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode (Page Select Byte) (\$18) Opcode (Second Byte) (\$6E) Index Offset Irrelevant Data |
| 7-2 | ADCA, ADCB, ADDA, ADDB, ANDA ANDB, BITA, BITB, CMPA, CMPB, EORA, EORB, LDAA, LDAB, ORAA, ORAB, SBCA, SBCB, SUBA, SUBB, | 5 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 <br> \$FFFF <br> (IY) + Offset | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode (Page Select Byte) (\$18) <br> Opcode (Second Byte) <br> Index Offset <br> Irrelevant Data <br> Operand Data |
| 7-3 | ASL, ASR, CLR, COM, DEC, INC, LSL, LSR, NEG, ROL, ROR | 7 | $\begin{aligned} & \hline 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \\ & 7 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 <br> \$FFFF <br> (IY) + Offset <br> \$FFFF <br> (IY) + Offset | $\begin{aligned} & \hline 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 0 \end{aligned}$ | Opcode (Page Select Byte) <br> Opcode (Second Byte) <br> Index Offset <br> Irrelevant Data <br> Original Operand Data <br> Irrelevant Data <br> Result Operand Data |

[^6]Table 10-7. Cycle-by-Cycle Operation — Indexed Y Mode (Sheet 2 of 2)

| Reference Number* | Address Mode and Instructions | Cycles | $\begin{gathered} \text { Cycle } \\ \# \end{gathered}$ | Address Bus | $\begin{aligned} & \hline \mathbf{R} \overline{\bar{W}} \\ & \text { Line } \end{aligned}$ | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 7-4 | TST | 7 | $\begin{aligned} & \hline 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \\ & 6 \\ & \hline \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 <br> \$FFFF <br> (IY) + Offset <br> \$FFFF <br> \$FFFF | $\begin{aligned} & 1 . \\ & 1 \\ & 1 \end{aligned}$ | Opcode (Page Select Byte) (\$18) Opcode (Second Byte) (\$6D) Index Offset Irrelevant Data Original Operand Data Irrelevant Data Irrelevant Data |
| 7-5 | STAA, STAB | 5 | $\begin{aligned} & 2 \\ & 3 \\ & 4 \\ & 5 \\ & \hline \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 <br> \$FFFF <br> (IY) + Offset | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 0 \end{aligned}$ | ```Opcode (Page Select Byte) (\$18) Opcode (Second Byte) Index Offset Irrelevant Data Accumulator Data``` |
| 7-6 | $\begin{aligned} & \text { LDD, LDS, LDX, } \\ & \text { LDY } \end{aligned}$ | 6 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \\ & \hline \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 <br> \$FFFF <br> (IY) + Offset <br> (IY) + Offset +1 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & \hline \end{aligned}$ | Opcode (Page Select Byte) Opcode (Second Byte) Index Offset Irrelevant Data Operand Data (High Byte) Operand Data (Low Byte) |
| 7-7 | $\begin{aligned} & \text { STD, STS, STX, } \\ & \text { STY } \end{aligned}$ | 6 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 <br> \$FFFF <br> (IY) + Offset <br> (IY) + Offset + 1 | $1$ | Opcode (Page Select Byte) <br> Opcode (Second Byte) <br> Index Offset <br> Irrelevant Data <br> Register Data (High Byte) <br> Register Data (Low Byte) |
| 7-8 | ADDD, CPD, CPX, CPY, SUBD | 7 | $\begin{aligned} & \hline 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \\ & 6 \\ & \hline \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 <br> \$FFFF <br> (IY) + Offset <br> (IY) + Offset + 1 <br> \$FFFF | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode (Page Select Byte) Opcode (Second Byte) Index Offset Irrelevant Data Operand Data (High Byte) Operand Data (Low Byte) Irrelevant Data |
| 7-9 | JSR | 7 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 4 \\ & 5 \\ & 6 \\ & 7 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 <br> \$FFFF <br> (IY) + Offset <br> Stack Pointer <br> Stack Pointer - 1 | $\begin{aligned} & \hline 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 0 \\ & 0 \\ & \hline \end{aligned}$ | Opcode (Page Select Byte) (\$18) <br> Opcode (Second Byte) (\$AD) <br> Index Offset <br> Irrelevant Data <br> First Opcode in Subroutine <br> Return Address (Low Byte) <br> Return Address (High Byte) |
| 7-10 | BCLR, BSET | 8 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 4 \\ & 5 \\ & 6 \\ & 7 \\ & 8 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 <br> \$FFFF <br> (IY) + Offset <br> Opcode Address + 3 <br> \$FFFF <br> (IY) + Offset | $\begin{aligned} & \hline 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | ```Opcode (Page Select Byte) (\$18) Opcode (Second Byte) Index Offset Irrelevant Data Original Operand Data Mask Byte Irrelevant Data Result Operand Data``` |
| 7-11 | BRCLR, BRSET | 8 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \\ & 7 \\ & 8 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> Opcode Address + 2 <br> \$FFFF <br> (IY) + Offset <br> Opcode Address + 3 <br> Opcode Address + 4 <br> SFFFF | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 1 \end{aligned}$ | ```Opcode (Page Select Byte) (\$18) Opcode (Second Byte) Index Offset Irrelevant Data Original Operand Data Mask Byte Branch Offset Irrelevant Data``` |

[^7]Table 10-8. Cycle-by-Cycle Operation - Relative Mode

| Reference Number* | Address Mode and Instructions | Cycles | Cycle \# | Address Bus | $\begin{aligned} & \mathrm{R} / \overline{\mathrm{W}} \\ & \text { Line } \end{aligned}$ | Data Bus |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| 8-1 | BCC, BCS, BEQ, BGE, BGT, BHI, BHS, BLE, BLO, BLS, BLT, BMI, BNE, BPL, BRA, BRN, BVC, BVS, | 3 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> \$FFFF | $\begin{aligned} & 1 \\ & 1 \\ & 1 \end{aligned}$ | Opcode Branch Offset Irrelevant Data |
| 8-2 | BSR | 6 | $\begin{aligned} & 1 \\ & 2 \\ & 3 \\ & 4 \\ & 5 \\ & 6 \end{aligned}$ | Opcode Address <br> Opcode Address + 1 <br> \$FFFF <br> Subroutine Address <br> Stack Pointer <br> Stack Pointer - 1 | $\begin{aligned} & 1 \\ & 1 \\ & 1 \\ & 1 \\ & 0 \\ & 0 \end{aligned}$ | Opcode (\$8D) <br> Branch Offset <br> Irrelevant Data <br> Opcode of Next Instruction <br> Return Address (Low Byte) <br> Return Address (High Byte) |

*The reference number is given to provide a cross-reference to Table 10-1

## APPENDIX A ELECTRICAL CHARACTERISTICS

Table A-1. Maximum Rating

| Rating | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| Supply Voltage | $\mathrm{V}_{\mathrm{DD}}$ | -0.3 to +7.0 | V |
| Input Voltage | $\mathrm{V}_{\text {in }}$ | -0.3 to +7.0 | V |
| Operating Temperature Range | $\mathrm{T}_{\mathrm{A}}$ | $\mathrm{T}_{\mathrm{L}}$ to $\mathrm{T}_{\mathrm{H}}$ | ${ }^{\circ} \mathrm{C}$ |
| MC68HCC1A8 | to 70 |  |  |
| MC68HC11A8C |  | -40 to 85 |  |
| MC68HC11A8V |  | -40 to 105 |  |
| MC68HC11A8M |  | -40 to 125 |  |
| MC68L11A8 |  | -20 to 70 |  |
| Storage Temperature Range |  | -55 to 150 |  |
| Current Drain per Pin | ${ }^{\circ} \mathrm{C}$ |  |  |
| Excluding $\mathrm{V}_{\mathrm{DD}}, \mathrm{V}_{\mathrm{SS}}, \mathrm{V}_{\text {RH }}$, and $\mathrm{V}_{\mathrm{RL}}$ | $\mathrm{T}_{\text {stg }}$ | mA |  |

*One pin at a time, observing maximum power dissipation limits.
Internal circuitry protects the inputs against damage caused by high static voltages or electric fields; however, normal precautions are necessary to avoid application of any voltage higher than maximum-rated voltages to this high-impedance circuit. Extended operation at the maximum ratings can adversely affect device reliability. Tying unused inputs to an appropriate logic voltage level (either GND or $V_{D D}$ ) enhances reliability of operation.

Table A-2. Thermal Characteristics

| Characteristic | Symbol | Value | Unit |
| :--- | :---: | :---: | :---: |
| Average Junction Temperature | $\mathrm{T}_{\mathrm{J}}$ | $\mathrm{T}_{\mathrm{A}}+\left(\mathrm{P}_{\mathrm{D}} \times \Theta_{\mathrm{JA}}\right)$ | ${ }^{\circ} \mathrm{C}$ |
| Ambient Temperature | $\mathrm{T}_{\mathrm{A}}$ | User-determined | ${ }^{\circ} \mathrm{C}$ |
| Package Thermal Resistance (Junction-to-Ambient) <br> 52--Pin Plastic Quad Pack (PLCC) <br> 48-Pin Plastic Dual In-Line Package (DIP) | $\Theta_{\mathrm{JA}}$ | 50 | ${ }^{\circ} \mathrm{C} / \mathrm{W}$ |
| Total Power Dissipation |  | $\mathrm{P}_{\mathrm{D}}$ | 40 |

## NOTES:

1. This is an approximate value, neglecting $P_{/ / 0}$.
2. For most applications $\mathrm{P}_{\mathrm{V}}$ " $\mathrm{P}_{\mathrm{INT}}$ and can be neglected.
3. $K$ is a constant pertaining to the device. Solve for $K$ with a known $T_{A}$ and a measured $P_{D}$ (at equilibrium). Use this value of $K$ to solve for $P_{D}$ and $T_{J}$ iteratively for any value of $T_{A}$.

Table A-3. DC Electrical Characteristics
$V_{D D}=5.0 \mathrm{Vdc} \pm 10 \%, V_{S S}=0 \mathrm{Vdc}, T_{A}=T_{L}$ to $T_{H}$, unless otherwise noted

\begin{tabular}{|c|c|c|c|c|}
\hline Characteristics \& Symbol \& Min \& Max \& Unit \\
\hline \begin{tabular}{rr} 
Output Voltage (Note 1) \& All Outputs except XTAL \\
\& All Outputs Except XTAL, RESET, \\
L Load \(= \pm 10.0 \mu \mathrm{~A}\) \& and MODA
\end{tabular} \& \[
\begin{aligned}
\& \mathrm{V}_{\mathrm{OL}} \\
\& \mathrm{v}_{\mathrm{OH}}
\end{aligned}
\] \& \[
V_{D D}-01
\] \& \[
0.1
\] \& V \\
\hline \begin{tabular}{lr} 
Output High Voltage (Note 1) \& All Outputs Except XTAL, \\
\(\mathrm{L}_{\text {Load }}=-0.8 \mathrm{~mA}, \mathrm{~V}_{\mathrm{DD}}=4.5 \mathrm{~V}\) \& \(\overline{\text { RESET, and MODA }}\)
\end{tabular} \& \(\mathrm{V}_{\mathrm{OH}}\) \& \(\mathrm{V}_{\mathrm{DD}}-0.8\) \& - \& V \\
\hline \[
\begin{array}{|l|l}
\hline \begin{array}{l}
\text { Output Low Voltage } \\
I_{\text {Load }}=1.6 \mathrm{~mA}
\end{array} \& \text { All Outputs Except XTAL } \\
\hline
\end{array}
\] \& \(\mathrm{V}_{\mathrm{OL}}\) \& - \& 0.4 \& V \\
\hline Input High Voltage \(\quad\) All Inputs Except \(\overline{\text { RESET }}\) \& \(\mathrm{V}_{\mathrm{IH}}\) \& \[
\begin{aligned}
\& 0.7 \times V_{D D} \\
\& 0.8 \times V_{D D} \\
\& \hline
\end{aligned}
\] \& \[
\begin{aligned}
\& \mathrm{V}_{\mathrm{DD}}+0.3 \\
\& \mathrm{~V}_{\mathrm{DD}}+0.3
\end{aligned}
\] \& V \\
\hline Input Low Voltage All Inputs \& \(\mathrm{V}_{\text {IL }}\) \& \(\mathrm{V}_{S S}-0.3\) \& \(0.2 \times \mathrm{V}_{\text {DD }}\) \& V \\
\hline \begin{tabular}{lr} 
I/O Ports, Three-State Leakage \& PA7, PC0-PC7, PD0-PD5, \\
\(V_{\text {in }}=V_{\text {IH }}\) or \(V_{\mathrm{IL}}\) \& AS/STRA, MODA/LIR, RESET \\
\hline
\end{tabular} \& \(\mathrm{I}_{\mathrm{OZ}}\) \& - \& \(\pm 10\) \& \(\mu \mathrm{A}\) \\
\hline \begin{tabular}{l}
Input Leakage Current (Note 2)
\[
\begin{aligned}
\& V_{\text {in }}=V_{D D} \text { or } V_{S S} \\
\& V_{\text {in }}=V_{D D} \text { or } V_{S S}
\end{aligned}
\] \\
PAO-PA2, IRQ, \(\overline{\mathrm{IIRQ}}\) MODB/ \(\mathrm{N}_{\text {STBY }}\)
\end{tabular} \& \(\mathrm{l}_{\text {in }}\) \& - \& \[
\begin{gathered}
\pm 1 \\
\pm 10
\end{gathered}
\] \& \(\mu \mathrm{A}\) \\
\hline RAM Standby Voltage Power down \& \(\mathrm{V}_{S B}\) \& 4.0 \& \(\mathrm{V}_{\mathrm{DD}}\) \& V \\
\hline RAM Standby Current Power down \& \(\mathrm{I}_{\text {SB }}\) \& - \& 10 \& \(\mu \mathrm{A}\) \\
\hline \begin{tabular}{l}
Total Supply Current (Note 3) RUN: \\
Single-Chip Mode \\
Expanded Multiplexed Mode
\end{tabular} \& \[
\begin{gathered}
\mathrm{IDD} \\
\mathrm{dc}-2 \mathrm{MHz} \\
3 \mathrm{MHz} \\
\mathrm{dc}-2 \mathrm{MHz} \\
3 \mathrm{MHz}
\end{gathered}
\] \& - \& \[
\begin{aligned}
\& 15 \\
\& 27 \\
\& 27 \\
\& 35
\end{aligned}
\] \& mA \\
\hline \begin{tabular}{l}
WAIT: \\
All Peripheral Functions Shut Down Single-Chip Mode \\
Expanded Multiplexed Mode \\
STOP: \\
No Clocks, Single-Chip Mode
\end{tabular} \& \[
\begin{gathered}
\text { W IDD } \\
\text { dc }-2 \mathrm{MHz} \\
3 \mathrm{MHz} \\
\mathrm{dc}-2 \mathrm{MHz} \\
3 \mathrm{MHz} \\
\mathrm{~S}_{\mathrm{IDD}} \\
\mathrm{dc}-2 \mathrm{MHz} \\
3 \mathrm{MHz}
\end{gathered}
\] \& \[
\begin{aligned}
\& - \\
\& - \\
\& - \\
\& -
\end{aligned}
\] \& \[
\begin{gathered}
6 \\
15 \\
10 \\
20 \\
\\
50 \\
150
\end{gathered}
\] \& \(m A\)

$\mu A$ <br>
\hline Input Capacitance PA0-PA2, PE0-PE7, $\overline{\mathrm{IRQ}, \overline{X I R Q}, ~ E X T A L ~}$

PA7, PC0-PC7, PD0-PD5, AS/STRA, MODA $\sqrt{L I R}, \overline{\text { RESET }}$ \& $\mathrm{C}_{\text {in }}$ \& - \& $$
\begin{gathered}
\hline 8 \\
12
\end{gathered}
$$ \& pF <br>

\hline | Power Dissipation |
| :--- |
| Single-Chip Mode Expanded Multiplexed Mode Single-Chip Mode Expanded Multiplexed Mode | \& \[

$$
\begin{gathered}
\mathrm{P}_{\mathrm{D}} \\
2 \mathrm{MHz} \\
3 \mathrm{MHz}
\end{gathered}
$$

\] \& \[

$$
\begin{aligned}
& - \\
& - \\
& -
\end{aligned}
$$

\] \& \[

$$
\begin{gathered}
85 \\
150 \\
150 \\
195
\end{gathered}
$$
\] \& mW <br>

\hline
\end{tabular}

## NOTES:

1. $\mathrm{V}_{\mathrm{OH}}$ specification for RESET and MODA is not applicable because they are open-drain pins. $\mathrm{V}_{\mathrm{OH}}$ specification not applicable to ports $C$ and $D$ in wired-OR mode.
2. Refer to A/D specification for leakage current for port E.
3. EXTAL is driven with a square wave, and
$\mathrm{t}_{\mathrm{cyc}}=500 \mathrm{~ns}$ for 2 MHz rating;
$\mathrm{t}_{\mathrm{cyc}}=333 \mathrm{~ns}$ for 3 MHz rating.
$\mathrm{V}_{\mathrm{IL}} \leq 0.2 \mathrm{~V}$
$\mathrm{V}_{\mathrm{IH}} \geq \mathrm{V}_{\mathrm{DD}}-0.2 \mathrm{~V}$
No dc loads.

Table A-3a. DC Electrical Characteristics (MC68L11A8)
$\mathrm{V}_{\mathrm{DD}}=3.0 \mathrm{Vdc}$ to $5.5 \mathrm{Vdc}, \mathrm{V}_{\mathrm{SS}}=0 \mathrm{Vdc}, \mathrm{T}_{\mathrm{A}}=\mathrm{T}_{\mathrm{L}}$ to $\mathrm{T}_{\mathrm{H}}$, unless otherwise noted

\begin{tabular}{|c|c|c|c|c|}
\hline Characteristics \& Symbol \& Min \& Max \& Unit \\
\hline \begin{tabular}{rr} 
Output Voltage (Note 1) \& All Outputs except XTAL \\
\& All Outputs Except XTAL, RESET, \\
\(L_{\text {Load }}= \pm 10.0 \mu \mathrm{~A}\) \& and MODA
\end{tabular} \& \[
\begin{aligned}
\& \mathrm{V}_{\mathrm{OL}} \\
\& \mathrm{~V}_{\mathrm{OH}}
\end{aligned}
\] \& \[
V_{D D}-01
\] \& \[
0.1
\] \& V \\
\hline \begin{tabular}{lr} 
Output High Voltage (Note 1) \& All Outputs Except XTAL, \\
\(\mathrm{I}_{\text {Load }}=-0.8 \mathrm{~mA}, \mathrm{~V}_{\mathrm{DD}}=4.5 \mathrm{~V}\) \& RESET, and MODA \\
\hline
\end{tabular} \& \(\mathrm{V}_{\mathrm{OH}}\) \& \(\mathrm{V}_{\mathrm{DD}}-0.8\) \& 3 \& V \\
\hline \[
\begin{array}{|l|l}
\hline \begin{array}{l}
\text { Output Low Voltage } \\
I_{\text {Load }}=1.6 \mathrm{~mA}
\end{array} \& \text { All Outputs Except XTAL } \\
\hline
\end{array}
\] \& \(\mathrm{V}_{\text {OL }}\) \& - \& 0.4 \& V \\
\hline \begin{tabular}{l} 
Input High Voltage \(\quad\) All Inputs Except \(\overline{\text { RESET }}\) \\
\(\overline{\text { RESET }}\) \\
\hline
\end{tabular} \& \(\mathrm{V}_{\mathrm{IH}}\) \& \[
\begin{aligned}
\& 0.7 \times V_{\mathrm{DD}} \\
\& 0.8 \times \mathrm{V}_{\mathrm{DD}}
\end{aligned}
\] \& \[
\begin{array}{r}
\mathrm{V}_{\mathrm{DD}}+0.3 \\
\mathrm{~V}_{\mathrm{DD}}+0.3 \\
\hline
\end{array}
\] \& V \\
\hline Input Low Voltage All Inputs \& \(\mathrm{V}_{\text {IL }}\) \& \(\mathrm{V}_{\text {SS }}-0.3\) \& \(0.2 \times V_{D D}\) \& V \\
\hline \begin{tabular}{lr} 
l/O Ports, Three-State Leakage \& PA7, PC0-PC7, PD0-PD5, \\
\(V_{\text {in }}=V_{I H}\) or \(V_{\mathrm{IL}}\) \& AS/STRA, MODA/LIR, RESET
\end{tabular} \& \(\mathrm{I}_{\mathrm{Oz}}\) \& - \& \(\pm 10\) \& \(\mu \mathrm{A}\) \\
\hline \begin{tabular}{|lr|}
\hline Input Leakage Current (Note 2) \& \\
\(V_{\text {in }}=V_{D D}\) or \(V_{S S}\) \& PAO-PA2, IRQ, XIRQ \\
\(V_{\text {in }}=V_{D D}\) or \(V_{S S}\) \& MODB \(/ V_{S T B Y}\) \\
\hline
\end{tabular} \& \(\mathrm{I}_{\text {in }}\) \& - \& \[
\begin{gathered}
\pm 1 \\
\pm 10
\end{gathered}
\] \& \(\mu \mathrm{A}\) \\
\hline RAM Standby Voltage Power down \& \(\mathrm{V}_{\mathrm{SB}}\) \& 2.0 \& \(\mathrm{V}_{\mathrm{DD}}\) \& V \\
\hline RAM Standby Current Power down \& \(\mathrm{I}_{\text {SB }}\) \& - \& 10 \& \(\mu \mathrm{A}\) \\
\hline \begin{tabular}{l}
Total Supply Current (Note 3) RUN: \\
Single-Chip Mode \\
Expanded Multiplexed Mode
\end{tabular} \& \[
\begin{gathered}
\mathrm{I}_{\mathrm{DD}} \\
\mathrm{dc}-1 \mathrm{MHz} \\
2 \mathrm{MHz} \\
\mathrm{dc}-1 \mathrm{MHz} \\
2 \mathrm{MHz}
\end{gathered}
\] \& - \& \[
\begin{gathered}
4 \\
8 \\
7 \\
14
\end{gathered}
\] \& mA \\
\hline \begin{tabular}{l}
WAIT: \\
All Peripheral Functions Shut Down Single-Chip Mode \\
Expanded Multiplexed Mode \\
STOP: \\
No Clocks, Single-Chip Mode
\end{tabular} \& \[
\begin{gathered}
\text { W IDD } \\
\text { dc }-1 \mathrm{MHz} \\
2 \mathrm{MHz} \\
\mathrm{dc}-1 \mathrm{MHz} \\
2 \mathrm{MHz} \\
\mathrm{~S}_{\mathrm{IDD}} \\
\mathrm{dc}-1 \mathrm{MHz} \\
2 \mathrm{MHz}
\end{gathered}
\] \& \[
\begin{aligned}
\& - \\
\& - \\
\& - \\
\& -
\end{aligned}
\] \& \[
\begin{gathered}
3 \\
6 \\
2.5 \\
5 \\
\\
25 \\
25
\end{gathered}
\] \& \(m A\)

$\mu \mathrm{~A}$ <br>
\hline Input Capacitance PA0-PA2, PE0-PE7, $\overline{\mathrm{IRQ}}, \overline{\overline{X I R Q}}$, EXTAL

PA7, PC0-PC7, PD0-PD5, AS/STRA, MODA $/ \overline{L I R}, \overline{\text { RESET }}$ \& $\mathrm{Cin}_{\text {in }}$ \& - \& $$
\begin{gathered}
\hline 8 \\
12
\end{gathered}
$$ \& pF <br>

\hline | Power Dissipation | Single-Chip Mode |
| :--- | ---: |
| Expanded Multiplexed Mode |  |
| Single-Chip Mode |  |
| Expanded Multiplexed Mode |  | \& \[

$$
\begin{gathered}
\mathrm{P}_{\mathrm{D}} \\
1 \mathrm{MHz} \\
2 \mathrm{MHz}
\end{gathered}
$$

\] \& \[

$$
\begin{aligned}
& - \\
& -
\end{aligned}
$$

\] \& \[

$$
\begin{aligned}
& 12 \\
& 21 \\
& 24 \\
& 42 \\
& \hline
\end{aligned}
$$
\] \& mW <br>

\hline
\end{tabular}

NOTES:

1. $\mathrm{V}_{\mathrm{OH}}$ specification for $\overline{\text { RESET }}$ and MODA is not applicable because they are open-drain pins. $\mathrm{V}_{\mathrm{OH}}$ specification not applicable to ports $C$ and $D$ in wired-OR mode.
2. Refer to A/D specification for leakage current for port E .
3. EXTAL is driven with a square wave, and
$\mathrm{t}_{\text {cyc }}=1000 \mathrm{~ns}$ for 1 MHz rating;
$t_{\text {cyc }}=500 \mathrm{~ns}$ for 2 MHz rating.
$\mathrm{V}_{\text {IL }} \leq 0.2 \mathrm{~V}$
$\mathrm{V}_{\mathrm{IH}} \geq \mathrm{V}_{\mathrm{DD}}-0.2 \mathrm{~V}$
No dc loads.


NOTES:

1. Full test loads are applied during all $D C$ electrical tests and $A C$ timing measurements.
2. During AC timing measurements, inputs are driven to 0.4 volts and VDD -0.8 volts while timing measurements are taken at the $20 \%$ and $70 \%$ of $V_{D D}$ points.

Figure A-1. Test Methods

Table A-4. Control Timing
$V_{D D}=5.0 \mathrm{Vdc} \pm 10 \%, V_{S S}=0 \mathrm{Vdc}, T_{A}=T_{L}$ to $T_{H}$

| Characteristic | Symbol | 1.0 MHz |  | 2.0 MHz |  | 3.0 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max |  |
| Frequency of Operation | $f_{0}$ | dc | 1.0 | dc | 2.0 | dc | 3.0 | MHz |
| E-Clock Period | $\mathrm{t}_{\mathrm{cyc}}$ | 1000 | - | 500 | - | 333 | - | ns |
| Crystal Frequency | $\mathrm{f}_{\text {XTAL }}$ | - | 4.0 | - | 8.0 | - | 12.0 | MHz |
| External Oscillator Frequency | $4 \mathrm{f}_{0}$ | dc | 4.0 | dc | 8.0 | dc | 12.0 | MHz |
| Processor Control Setup $\quad t_{\text {PCSU }}=1 / 4 \mathrm{t}_{\text {cyc }}+50 \mathrm{~ns}$ $\quad$ Time | tpcsu | 300 | - | 175 | - | 133 | - | ns |
| Reset Input Pulse Width (To Guarantee External <br> (Note 1) Reset Vector) <br>  (Minimum Input Time; <br>  Can Be Preempted by <br> Internal Reset)  | PW ${ }_{\text {RSTL }}$ | $\begin{aligned} & 8 \\ & 1 \end{aligned}$ | - | $\begin{aligned} & 8 \\ & 1 \end{aligned}$ | - | $\begin{aligned} & 8 \\ & 1 \end{aligned}$ | - | $\mathrm{t}_{\text {cyc }}$ |
| Mode Programming Setup Time | $\mathrm{t}_{\text {MPS }}$ | 2 | - | 2 | - | 2 | - | $\mathrm{t}_{\text {cyc }}$ |
| Mode Programming Hold Time | $\mathrm{t}_{\text {MPH }}$ | 10 | - | 10 | - | 10 | - | ns |
| Interrupt Pulse Width, <br> IRQ Edge-Sensitive Mode$\quad \mathrm{PW}_{\mathrm{IRQ}}=\mathrm{t}_{\mathrm{cyc}}+20 \mathrm{~ns}$ | PW ${ }_{\text {IRQ }}$ | 1020 | - | 520 | - | 353 | - | ns |
| Wait Recovery Start-up Time | ${ }^{\text {twRS }}$ | - | 4 | - | 4 | - | 4 | $\mathrm{t}_{\text {cyc }}$ |
| Timer Pulse Width <br> Input Capture, <br> Pulse Accumulator Input $\mathrm{PW}_{\text {TIM }}=\mathrm{t}_{\text {cyc }}+20 \mathrm{~ns}$ | $\mathrm{PW}_{\text {TIM }}$ | 1020 | - | 520 | - | 353 | - | ns |

## NOTES:

1. $\overline{R E S E T}$ is recognized during the first clock cycle it is held low. Internal circuitry then drives the pin low for four clock cycles, releases the pin, and samples the pin level two cycles later to determine the source of the interrupt. Refer to SECTION 5 RESETS AND INTERRUPTS for further detail.
2. All timing is shown with respect to $20 \% V_{D D}$ and $70 \% V_{D D}$, unless otherwise noted.

Table A-4a. Control Timing (MC68L11A8)
$\mathrm{V}_{\mathrm{DD}}=3.0 \mathrm{Vdc}$ to $5.5 \mathrm{Vdc}, \mathrm{V}_{\mathrm{SS}}=0 \mathrm{Vdc}, \mathrm{T}_{\mathrm{A}}=\mathrm{T}_{\mathrm{L}}$ to $\mathrm{T}_{\mathrm{H}}$

| Characteristic | Symbol | 1.0 MHz |  | 2.0 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| Frequency of Operation | $f_{0}$ | dc | 1.0 | dc | 2.0 | MHz |
| E-Clock Period | $\mathrm{t}_{\text {cyc }}$ | 1000 | - | 500 | - | ns |
| Crystal Frequency | ${ }_{\text {fxtaL }}$ | - | 4.0 | - | 8.0 | MHz |
| External Oscillator Frequency | $4 \mathrm{f}_{0}$ | dc | 4.0 | dc | 8.0 | MHz |
| Processor Control Setup $\quad t_{\text {PCSU }}=1 / 4 \mathrm{t}_{\text {cyc }}+50 \mathrm{~ns}$ $\quad$ Time | ${ }_{\text {tpCSU }}$ | 325 | - | 200 | - | ns |
| Reset Input Pulse Width (To Guarantee External <br> (Note 1) Reset Vector) <br>  (Minimum Input Time; <br>  Can Be Preempted by <br>  Internal Reset) | PW ${ }_{\text {RSTL }}$ | $\begin{aligned} & 8 \\ & 1 \end{aligned}$ | - | $\begin{aligned} & 8 \\ & 1 \end{aligned}$ | — | $\mathrm{t}_{\mathrm{cyc}}$ |
| Mode Programming Setup Time | $\mathrm{t}_{\text {MPS }}$ | 2 | - | 2 | - | $\mathrm{t}_{\text {cyc }}$ |
| Mode Programming Hold Time | $\mathrm{t}_{\text {MPH }}$ | 10 | - | 10 | - | ns |
| Interrupt Pulse Width, PW <br> $\overline{\mathrm{IRQ}} \mathrm{EQ}$ Edge-Sensitive Mode $=\mathrm{t}_{\mathrm{cyc}}+20 \mathrm{~ns}$ | PW ${ }_{\text {IRQ }}$ | 1020 | - | 520 | - | ns |
| Wait Recovery Start-up Time | $t_{\text {WRS }}$ | - | 4 | - | 4 | $\mathrm{t}_{\mathrm{cyc}}$ |
| Timer Pulse Width $\mathrm{PW}_{\text {TIM }}=\mathrm{t}_{\mathrm{cyc}}+20 \mathrm{~ns}$ <br> Input Capture, <br> Pulse Accumulator Input | $\mathrm{PW}_{\text {TIM }}$ | 1020 | - | 520 | - | ns |

NOTES:

1. $\overline{R E S E T}$ is recognized during the first clock cycle it is held low. Internal circuitry then drives the pin low for four clock cycles, releases the pin, and samples the pin level two cycles later to determine the source of the interrupt. Refer to SECTION 5 RESETS AND INTERRUPTS for further detail.
2. All timing is shown with respect to $20 \% \mathrm{~V}_{\mathrm{DD}}$ and $70 \% \mathrm{~V}_{\mathrm{DD}}$, unless otherwise noted.


NOTES:

1. Rising edge sensitive input
2. Falling edge sensitive input
3. Maximum pulse accumulator clocking rate is E-clock frequency divided by 2.

Figure A-2. Timer Inputs


Figure A－3．POR and External Reset Timing Diagram


NOTES:

1. Edge Sensitive $\overline{R Q}$ pin (IRQE bit $=1$ )
2. Level sensitive $\overline{R Q Q}$ pin (IRQE bit $=0$ )
3. $\mathrm{I}_{\text {STOPDELAY }}=4064 \mathrm{t}_{\text {CYC }}$ if DLY bit $=1$ or $4 \mathrm{t}_{\text {CYC }}$ if $\mathrm{DL} \dot{Y}=0$.
4. XIRQ with X bit in $C C R=1$.
5. $\overline{\mathrm{RQQ}}$ or ( $\overline{\mathrm{XIRQ}}$ with X bit in $\mathrm{CCR}=0$ ).


Figure A-5. WAIT Recovery Timing Diagram


NOTES: 2. Level sensitive $\overline{\mathrm{RQ}}$ pin (IRQE bit $=0$ )

Figure A-6. Interrupt Timing Diagram

Table A-5. Peripheral Port Timing
$V_{D D}=5.0 \mathrm{Vdc} \pm 10 \%, V_{S S}=0 \mathrm{Vdc}, T_{A}=T_{L}$ to $T_{H}$

| Characteristic | Symbol | 1.0 MHz |  | 2.0 MHz |  | 3.0 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max | Min | Max |  |
| Frequency of Operation (E-Clock Frequency) | $\mathrm{f}_{0}$ | dc | 1.0 | dc | 2.0 | dc | 3.0 | MHz |
| E-Clock Period | $\mathrm{t}_{\mathrm{cyc}}$ | 1000 | - | 500 | - | 333 | - | ns |
| Peripheral Data Setup Time (MCU Read of Ports A, C, D, and E) | $\mathrm{t}_{\text {pDSu }}$ | 100 | - | 100 | - | 100 | - | ns |
| Peripheral Data Hold Time <br> (MCU Read of Ports A, C, D, and E) | $t_{\text {PDH }}$ | 50 | - | 50 | - | 50 | - | ns |
| Delay Time, Peripheral Data Write MCU Write to Port A MCU Writes to Ports B, C, and D $t_{\text {PWD }}=1 / 4 \mathrm{t}_{\text {cyc }}+100 \mathrm{~ns}$ | ${ }_{\text {tPWD }}$ | - | $\begin{aligned} & 200 \\ & 350 \end{aligned}$ | - | $\begin{aligned} & 200 \\ & 225 \end{aligned}$ |  | $\begin{aligned} & 200 \\ & 183 \end{aligned}$ | ns |
| Input Data Setup Time (Port C) | $\mathrm{t}_{15}$ | 60 | - | 60 | - | 60 | - | ns |
| Input Data Hold Time (Port C) | $\mathrm{t}_{\mathrm{H}}$ | 100 | - | 100 | - | 100 | - | ns |
| Delay Time, E Fall to STRB $\quad \mathrm{t}_{\text {DEB }}=1 / 4 \mathrm{t}_{\text {cyc }}+100 \mathrm{~ns}$ | $t_{\text {deb }}$ | - | 350 | - | 225 | - | 183 | ns |
| Setup Time, STRA Asserted to E Fall (Note 1) | $t_{\text {AES }}$ | 0 | - | 0 | - | 0 | - | ns |
| Delay Time, STRA Asserted to Port C Data Output Valid | $t_{\text {PCD }}$ | - | 100 | - | 100 | - | 100 | ns |
| Hold Time, STRA Negated to Port C Data | $\mathrm{t}_{\mathrm{PCH}}$ | 10 | - | 10 | - | 10 | - | ns |
| Three-State Hold Time | $t_{\text {PCZ }}$ | - | 150 | - | 150 | - | 150 | ns |

NOTES:

1. If this setup time is met, STRB acknowledges in the next cycle. If it is not met, the response may be delayed one more cycle.
2. Port $C$ and $D$ timing is valid for active drive (CWOM and DWOM bits not set in PIOC and SPCR registers respectively).
3. All timing is shown with respect to $20 \% \mathrm{~V}_{\mathrm{DD}}$ and $70 \% \mathrm{~V}_{\mathrm{DD}}$, unless otherwise noted.

Table A-5a. Peripheral Port Timing (MC68L11A8)
$\mathrm{V}_{\mathrm{DD}}=3.0 \mathrm{Vdc}$ to $5.5 \mathrm{Vdc}, \mathrm{V}_{\mathrm{SS}}=0 \mathrm{Vdc}, \mathrm{T}_{\mathrm{A}}=\mathrm{T}_{\mathrm{L}}$ to $\mathrm{T}_{\mathrm{H}}$

| Characteristic | Symbol | 1.0 MHz |  | 2.0 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  | Min | Max | Min | Max |  |
| Frequency of Operation (E-Clock Frequency) | $f_{0}$ | dc | 1.0 | dc | 2.0 | MHz |
| E-Clock Period | $\mathrm{t}_{\text {cyc }}$ | 1000 | - | 500 | - | ns |
| Peripheral Data Setup Time <br> (MCU Read of Ports A, C, D, and E) | $\mathrm{t}_{\text {PDSU }}$ | 100 | - | 100 | - | ns |
| Peripheral Data Hold Time (MCU Read of Ports A, C, D, and E) | $t_{\text {PDH }}$ | 50 | - | 50 | - | ns |
| Delay Time, Peripheral Data Write MCU Write to Port A MCU Writes to Ports B, C, and D $t_{\text {PWD }}=1 / 4 \mathrm{t}_{\text {cyc }}+150 \mathrm{~ns}$ | $t_{\text {PWD }}$ | - | $\begin{aligned} & 250 \\ & 400 \end{aligned}$ | - | $\begin{aligned} & 250 \\ & 275 \end{aligned}$ | ns |
| Input Data Setup Time (Port C) | $\mathrm{t}_{\text {IS }}$ | 60 | - | 60 | - | ns |
| Input Data Hold Time (Port C) | $\mathrm{t}_{\mathrm{IH}}$ | 100 | - | 100 | - | ns |
| Delay Time, E Fall to STRB $\quad \mathrm{t}_{\text {DEB }}=1 / 4 \mathrm{t}_{\text {cyc }}+150 \mathrm{~ns}$ | ${ }^{\text {t }}$ DEB | - | 400 | - | 275 | ns |
| Setup Time, STRA Asserted to E Fall (Note 1) | $t_{\text {AES }}$ | 0 | - | 0 | - | ns |
| Delay Time, STRA Asserted to Port C Data Output Valid | ${ }^{\text {t }}$ PCD | - | 100 | - | 100 | ns |
| Hold Time, STRA Negated to Port C Data | $t_{\text {PCH }}$ | 10 | - | 10 | - | ns |
| Three-State Hold Time | $t_{\text {PCZ }}$ | - | 150 | - | 150 | ns |

## NOTES:

1. If this setup time is met, STRB acknowledges in the next cycle. If it is not met, the response may be delayed one more cycle.
2. Port $C$ and $D$ timing is valid for active drive (CWOM and DWOM bits not set in PIOC and SPCR registers respectively).
3. All timing is shown with respect to $20 \% \mathrm{~V}_{\mathrm{DD}}$ and $70 \% \mathrm{~V}_{\mathrm{DD}}$, unless otherwise noted.


Figure A-7. Port Write Timing Diagram


Figure A-8. Port Read Timing Diagram


Figure A-9. Simple Output Strobe Timing Diagram


Figure A-10. Simple Input Strobe Timing Diagram


Figure A-11. Port C Input Handshake Timing Diagram


Figure A-12. Port C Output Handshake Timing Diagram


Figure A-13. Three-State Variation of Output Handshake Timing Diagram (STRA Enables Output Buffer)

Table A-6. Analog-To-Digital Converter Characteristics
$\mathrm{V}_{\mathrm{DD}}=5.0 \mathrm{Vdc} \pm 10 \%, \mathrm{~V}_{\mathrm{SS}}=0 \mathrm{Vdc}, \mathrm{T}_{\mathrm{A}}=\mathrm{T}_{\mathrm{L}}$ to $\mathrm{T}_{\mathrm{H}}, 750 \mathrm{kHz} \leq \mathrm{E} \leq 3.0 \mathrm{MHz}$, unless otherwise noted

| Characteristic | Parameter | Min | Absolute | 2.0 MHz | 3.0 MHz | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  |  | Max | Max |  |
| Resolution | Number of Bits Resolved by A/D Converter | - | 8 | - | - | Bits |
| Non-Linearity | Maximum Deviation from the Ideal A/D Transfer Characteristics | - | - | $\pm 1 / 2$ | $\pm 1$ | LSB |
| Zero Error | Difference Between the Output of an Ideal and an Actual for Zero Input Voltage | - | - | $\pm 1 / 2$ | $\pm 1$ | LSB |
| Full Scale Error | Difference Between the Output of an Ideal and an Actual A/D for Full-Scale Input Voltage | - | - | $\pm 1 / 2$ | $\pm 1$ | LSB |
| Total Unadjusted Error | Maximum Sum of Non-Linearity, Zero Error, and Full-Scale Error | - | - | $\pm 1 / 2$ | $\pm 11 / 2$ | LSB |
| Quantization Error | Uncertainty Because of Converter Resolution | - | - | $\pm 1 / 2$ | $\pm 1 / 2$ | LSB |
| Absolute Accuracy | Difference Between the Actual Input Voltage and the Full-Scale Weighted Equivalent of the Binary Output Code, All Error Sources Included | - | - | $\pm 1$ | $\pm 2$ | LSB |
| Conversion Range | Analog Input Voltage Range | $\mathrm{V}_{\text {RL }}$ | - | $\mathrm{V}_{\mathrm{RH}}$ | $\mathrm{V}_{\mathrm{RH}}$ | V |
| $\mathrm{V}_{\text {RH }}$ | Maximum Analog Reference Voltage (Note 2) | $\mathrm{V}_{\mathrm{RL}}$ | - | $\mathrm{V}_{\mathrm{DD}}+0.1$ | $\mathrm{V}_{\mathrm{DD}}+0.1$ | V |
| $\mathrm{V}_{\mathrm{RL}}$ | Minimum Analog Reference Voltage (Note 2) | $\mathrm{V}_{\text {SS }}-0.1$ | - | $\mathrm{V}_{\mathrm{RH}}$ | $\mathrm{V}_{\mathrm{RH}}$ | V |
| $\Delta \mathrm{V}_{\mathrm{R}}$ | Minimum Difference between $\mathrm{V}_{\mathrm{RH}}$ and $\mathrm{V}_{\mathrm{RL}}$ (Note 2) | 3 | - | - | - | V |
| Conversion Time | Total Time to Perform a Single Analog-to-Digital Conversion: <br> a. E Clock <br> b. Internal RC Oscillator | - | $32$ | $\begin{gathered} - \\ \mathrm{t}_{\mathrm{cyc}}+32 \\ \hline \end{gathered}$ | $\begin{gathered} - \\ t_{\mathrm{cyc}}+32 \\ \hline \end{gathered}$ | $\begin{aligned} & \mathrm{t}_{\text {cyc }} \\ & \mu \mathrm{s} \end{aligned}$ |
| Monotonicity | Conversion Result Never Decreases with an Increase in Input Voltage and has no Missing Codes | - | Guaranteed | - | - | - |
| Zero Input Reading | Conversion Result when $\mathrm{V}_{\text {in }}=\mathrm{V}_{\mathrm{RL}}$ | 00 | - | - | - | Hex |
| Full Scale Reading | Conversion Result when $\mathrm{V}_{\text {in }}=\mathrm{V}_{\text {RH }}$ | - | - | FF | FF | Hex |
| Sample Acquisition Time | Analog Input Acquisition Sampling Time: <br> a. E Clock <br> b. Internal RC Oscillator | — | $12$ | $\overline{12}$ | $\overline{12}$ | $\mathrm{t}_{\mathrm{cyc}}$ $\mu \mathrm{s}$ |
| Sample/Hold Capacitance | Input Capacitance during Sample PE0-PE7 | - | 20 (Typ) | - | - | pF |
| Input Leakage | Input Leakage on A/D Pins PE0-PE7 <br>  $\mathrm{V}_{\mathrm{RL}}, \mathrm{V}_{\mathrm{RH}}$ | - | - | $\begin{gathered} 400 \\ 1.0 \end{gathered}$ | $\begin{gathered} 400 \\ 1.0 \end{gathered}$ | nA $\mu \mathrm{A}$ |

## NOTES:

1. Source impedances greater than $10 \mathrm{k} \Omega$ affect accuracy adversely because of input leakage.
2. Performance verified down to $2.5 \mathrm{~V} \Delta \mathrm{~V}_{\mathrm{R}}$, but accuracy is tested and guaranteed at $\Delta \mathrm{V}_{\mathrm{R}}=5 \mathrm{~V} \pm 10 \%$.

Table A-6a. Analog-To-Digital Converter Characteristics (MC68L11A8)
$\mathrm{V}_{\mathrm{DD}}=3.0 \mathrm{Vdc}$ to $5.5 \mathrm{Vdc}, \mathrm{V}_{\mathrm{SS}}=0 \mathrm{Vdc}, \mathrm{T}_{\mathrm{A}}=\mathrm{T}_{\mathrm{L}}$ to $\mathrm{T}_{\mathrm{H}}, 750 \mathrm{kHz} \leq \mathrm{E} \leq 2.0 \mathrm{MHz}$, unless otherwise noted

| Characteristic | Parameter | Min | Absolute | Max | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: |
| Resolution | Number of Bits Resolved by A/D Converter | - | 8 | - | Bits |
| Non-Linearity | Maximum Deviation from the Ideal A/D Transfer Characteristics | - | - | $\pm 1$ | LSB |
| Zero Error | Difference Between the Output of an Ideal and an Actual for Zero Input Voltage | - | - | $\pm 1$ | LSB |
| Full Scale Error | Difference Between the Output of an Ideal and an Actual A/D for Full-Scale Input Voltage | - | - | $\pm 1$ | LSB |
| Total Unadjusted Error | Maximum Sum of Non-Linearity, Zero Error, and Full-Scale Error | - | - | $\pm 11 / 2$ | LSB |
| Quantization Error | Uncertainty Because of Converter Resolution | - | - | $\pm 1 / 2$ | LSB |
| Absolute Accuracy | Difference Between the Actual Input Voltage and the Full-Scale Weighted Equivalent of the Binary Output Code, All Error Sources Included | - | - | $\pm 2$ | LSB |
| Conversion Range | Analog Input Voltage Range | $\mathrm{V}_{\mathrm{RL}}$ | - | $\mathrm{V}_{\text {RH }}$ | V |
| $\mathrm{V}_{\mathrm{RH}}$ | Maximum Analog Reference Voltage (Note 2) | $\mathrm{V}_{\mathrm{RL}}$ | - | $\mathrm{V}_{\mathrm{DD}}+0.1$ | V |
| $\mathrm{V}_{\mathrm{RL}}$ | Minimum Analog Reference Voltage (Note 2) | $\mathrm{V}_{\text {SS }}-0.1$ | - | $\mathrm{V}_{\mathrm{RH}}$ | V |
| $\Delta \mathrm{V}_{\mathrm{R}}$ | Minimum Difference between $\mathrm{V}_{\mathrm{RH}}$ and $\mathrm{V}_{\mathrm{RL}}$ <br> (Note 2) | 3 | - | - | V |
| Conversion Time | Total Time to Perform a Single Analog-to-Digital Conversion: <br> a. E Clock <br> b. Internal RC Oscillator |  | $32$ | $t_{\mathrm{cyc}}+32$ | $\begin{aligned} & \mathrm{t}_{\mathrm{cyc}} \\ & \mu \mathrm{~s} \end{aligned}$ |
| Monotonicity | Conversion Result Never Decreases with an Increase in Input Voltage and has no Missing Codes | - | Guaranteed | - | - |
| Zero Input Reading | Conversion Result when $\mathrm{V}_{\text {in }}=\mathrm{V}_{\mathrm{RL}}$ | 00 | - | - | Hex |
| Full Scale Reading | Conversion Result when $\mathrm{V}_{\text {in }}=\mathrm{V}_{\text {RH }}$ | - | - | FF | Hex |
| Sample Acquisition Time | Analog Input Acquisition Sampling Time: <br> a. E Clock <br> b. Internal RC Oscillator | - | $12$ | $\overline{12}$ | $\begin{aligned} & \mathrm{t}_{\mathrm{cyc}} \\ & \mu \mathrm{~s} \end{aligned}$ |
| Sample/Hold Capacitance | Input Capacitance during Sample PE0-PE7 | - | 20 (Typ) | - | pF |
| Input Leakage | Input Leakage on A/D Pins $\mathrm{PEO}-\mathrm{PE7}$ <br>  $\mathrm{~V}_{\mathrm{RL}}, \mathrm{V}_{\mathrm{RH}}$ | - | - | $\begin{gathered} 400 \\ 1.0 \end{gathered}$ | $\begin{aligned} & \mathrm{nA} \\ & \mu \mathrm{~A} \end{aligned}$ |

NOTES:

1. Source impedances greater than $10 \mathrm{k} \Omega$ affect accuracy adversely because of input leakage.

Table A-7. Expansion Bus Timing
$V_{D D}=5.0 \mathrm{Vdc} \pm 10 \%, V_{S S}=0 \mathrm{Vdc}, T_{A}=T_{L}$ to $T_{H}$

| Num | Characteristic | Symbol | 1.0 MHz |  | 2.0 MHz |  | 3.0 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max | Min | Max | Min | Max |  |
|  | Frequency of Operation (E-Clock Frequency) | $\mathrm{f}_{0}$ | dc | 1.0 | dc | 2.0 | dc | 3.0 | MHz |
| 1 | Cycle Time | $\mathrm{t}_{\text {cyc }}$ | 1000 | - | 500 | - | 333 | - | ns |
| 2 | Pulse Width, E Low $P W_{E L}=1 / 2 \mathrm{t}_{\mathrm{cyc}}-23 \mathrm{~ns}$ <br> (Note 1) | PWEL | 477 | - | 227 | - | 146 | - | ns |
| 3 | Pulse Width, E High <br> $P W_{E H}=1 / 2 \mathrm{t}_{\text {cyc }}-28 \mathrm{~ns}$ <br> (Note 1) | $\mathrm{PW}_{\text {EH }}$ | 472 | - | 222 | - | 141 | - | ns |
| 4a, b | E and AS Rise and Fall Time | $\begin{aligned} & t_{r} \\ & t_{f} \end{aligned}$ | - | $\begin{aligned} & 20 \\ & 20 \end{aligned}$ | - | $\begin{aligned} & 20 \\ & 20 \end{aligned}$ | - | $\begin{aligned} & 20 \\ & 15 \end{aligned}$ | ns |
| 9 | Address Hold Time $\mathrm{t}_{\mathrm{AH}}=1 / 8 \mathrm{t}_{\mathrm{cyc}}-29.5 \mathrm{~ns}$ <br> (Note 1, 2a) | $\mathrm{t}_{\mathrm{AH}}$ | 95.5 | - | 33 | - | 26 | - | ns |
| 12 | Non-Muxed Address Valid Time to E Rise $\mathrm{t}_{\mathrm{AV}}=\mathrm{PW} \mathrm{ELL}-\left(\mathrm{t}_{\mathrm{ASD}}+80 \mathrm{~ns}\right)$ <br> (Note 1, 2a) | $t^{\text {AV }}$ | 281.5 | - | 94 | - | 54 | - | ns |
| 17 | Read Data Setup Time | $\mathrm{t}_{\text {DSR }}$ | 30 | - | 30 | - | 30 | - | ns |
| 18 | Read Data Hold Time ( $\mathrm{Max}=\mathrm{t}_{\text {MAD }}$ ) | $\mathrm{t}_{\mathrm{DHR}}$ | 0 | 145.5 | 0 | 83 | 0 | 51 | ns |
| 19 | Write Data Delay Time $\mathrm{t}_{\mathrm{DDW}}=1 / 8 \mathrm{t}_{\mathrm{cyc}}+65.5 \mathrm{~ns}$ <br> (Note 1, 2a) | ${ }^{\text {t }}$ DDW | - | 190.5 | - | 128 | - | 71 | ns |
| 21 | Write Data Hold Time $\mathrm{t}_{\mathrm{DHW}}=1 / 8 \mathrm{t}_{\mathrm{cyc}}-29.5 \mathrm{~ns}$ <br> (Note 1, 2a) | ${ }^{\text {t }}$ HW | 95.5 | - | 33 | - | 26 | - | ns |
| 22 | Muxed Address Valid Time to E Rise <br> $\mathrm{t}_{\mathrm{AVM}}=\mathrm{PW}$ <br> EL$-\left(\mathrm{t}_{\mathrm{ASD}}+90 \mathrm{~ns}\right)$ (Note 1, 2a) | $\mathrm{t}_{\text {AVM }}$ | 271.5 | - | 84 | - | 54 | - | ns |
| 24 | Muxed Address Valid Time to AS Fall $\mathrm{t}_{\text {ASL }}=\mathrm{PW}_{\text {ASH }}-70 \mathrm{~ns}$ (Note 1) | $\mathrm{t}_{\text {ASL }}$ | 151 | - | 26 | - | 13 | - | ns |
| 25 | Muxed Address Hold Time $\mathrm{t}_{\mathrm{AHL}}=1 / 8 \mathrm{t}_{\mathrm{cyc}}-29.5 \mathrm{~ns}$ <br> (Note 1, 2b) | $\mathrm{t}_{\text {AHL }}$ | 95.5 | - | 33 | - | 31 | - | ns |
| 26 | Delay Time, E to AS Rise $\mathrm{t}_{\mathrm{ASD}}=1 / 8 \mathrm{t}_{\mathrm{cyc}}-9.5 \mathrm{~ns}$ <br> (Note 1, 2a) | $t_{\text {ASD }}$ | 115.5 | - | 53 | - | 31 | - | ns |
| 27 | Pulse Width, AS High <br> PW ASH $=1 / 4 \mathrm{t}_{\mathrm{cyc}}-29 \mathrm{~ns}$ <br> (Note 1) | $\mathrm{PW}_{\text {ASH }}$ | 221 | - | 96 | - | 63 | - | ns |
| 28 | Delay Time, AS to E Rise $\mathrm{t}_{\text {ASED }}=1 / 8 \mathrm{t}_{\mathrm{cyc}}-9.5 \mathrm{~ns}$ <br> (Note 1, 2b) | $\mathrm{t}_{\text {ASED }}$ | 115.5 | - | 53 | - | 31 | - | ns |
| 29 | MPU Address Access Time  <br> $t_{\text {ACCA }}=t_{\text {cyc }}-\left(P W_{E L}-t_{A V M}\right)-t_{\text {DSR }}-t_{f}$ (Note 2a) <br>   | $\mathrm{t}_{\text {ACCA }}$ | 744.5 | - | 307 | - | 196 | - | ns |
| 35 | MPU Access Time $\mathrm{t}_{\mathrm{ACCE}}=\mathrm{PW}_{\mathrm{EH}}-\mathrm{t}_{\mathrm{DSR}}$ | $t_{\text {tace }}$ | - | 442 | - | 192 | - | 111 | ns |
| 36 | Muxed Address Delay (Previous Cycle MPU Read) $t_{M A D}=t_{A S D}+30 \mathrm{~ns}$ <br> (Note 1, 2a) | $\mathrm{t}_{\text {MAD }}$ | 145.5 | - | 83 | - | 51 | - | ns |

NOTES:

1. Formula only for dc to 2 MHz .
2. Input clocks with duty cycles other than $50 \%$ affect bus performance. Timing parameters affected by input clock duty cycle are identified by (a) and (b). To recalculate the approximate bus timing values, substitute the following expressions in place of $1 / 8 \mathrm{t}_{\mathrm{cyc}}$ in the above formulas, where applicable:
(a) (1-DC) $\times 1 / 4 \mathrm{t}_{\text {cyc }}$
(b) $\mathrm{DC} \times 1 / 4 \mathrm{t}_{\text {cyc }}$

Where:
$D C$ is the decimal value of duty cycle percentage (high time).
3. All timing is shown with respect to $20 \% \mathrm{~V}_{\mathrm{DD}}$ and $70 \% \mathrm{~V}_{\mathrm{DD}}$, unless otherwise noted.

Table A-7a. Expansion Bus Timing (MC68L11A8)
$\mathrm{V}_{\mathrm{DD}}=3.0 \mathrm{Vdc}$ to $5.5 \mathrm{Vdc}, \mathrm{V}_{\mathrm{SS}}=0 \mathrm{Vdc}, \mathrm{T}_{\mathrm{A}}=\mathrm{T}_{\mathrm{L}}$ to $\mathrm{T}_{\mathrm{H}}$

| Num | Characteristic | Symbol | 1.0 MHz |  | 2.0 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max | Min | Max |  |
|  | Frequency of Operation (E-Clock Frequency) | $\mathrm{f}_{0}$ | dc | 1.0 | dc | 2.0 | MHz |
| 1 | Cycle Time | $\mathrm{t}_{\mathrm{cyc}}$ | 1000 | - | 500 | - | ns |
| 2 | Pulse Width, E Low $P W_{E L}=1 / 2 t_{\mathrm{cyc}}-23 \mathrm{~ns}$ <br> (Note 1) | $\mathrm{PW}_{\mathrm{EL}}$ | 475 | - | 225 | - | ns |
| 3 | Pulse Width, E High $P W_{E H}=1 / 2 \mathrm{t}_{\mathrm{cyc}}-28 \mathrm{~ns}$ <br> (Note 1) | $\mathrm{PW}_{\text {EH }}$ | 470 | - | 220 | - | ns |
| 4a, b | E and AS Rise and Fall Time | $\begin{aligned} & \mathrm{t}_{\mathrm{r}} \\ & \mathrm{t}_{\mathrm{f}} \end{aligned}$ | - | $\begin{aligned} & 25 \\ & 25 \end{aligned}$ | - | $\begin{aligned} & 25 \\ & 25 \end{aligned}$ | ns |
| 9 | Address Hold Time $\mathrm{t}_{\mathrm{AH}}=1 / 8 \mathrm{t}_{\mathrm{cyc}}-29.5 \mathrm{~ns}$ <br> (Note 1, 2a) | $\mathrm{t}_{\mathrm{AH}}$ | 95 | - | 33 | - | ns |
| 12 | Non-Muxed Address Valid Time to E Rise $t_{\mathrm{AV}}=P W_{E L}-\left(\mathrm{t}_{\mathrm{ASD}}+80 \mathrm{~ns}\right)$ <br> (Note 1, 2a) | $t_{\text {AV }}$ | 275 | - | 88 | - | ns |
| 17 | Read Data Setup Time | $\mathrm{t}_{\text {DSR }}$ | 30 | - | 30 | - | ns |
| 18 | Read Data Hold Time ( $\mathrm{Max}=\mathrm{t}_{\text {MAD }}$ ) | $t_{\text {DHR }}$ | 0 | 150 | 0 | 88 | ns |
| 19 | Write Data Delay Time $\mathrm{t}_{\mathrm{DDW}}=1 / 8 \mathrm{t}_{\mathrm{cyc}}+65.5 \mathrm{~ns}$ <br> (Note 1, 2a) | $t_{\text {DDW }}$ | - | 195 | - | 133 | ns |
| 21 | Write Data Hold Time $\mathrm{t}_{\mathrm{DHW}}=1 / 8 \mathrm{t}_{\mathrm{cyc}}-29.5 \mathrm{~ns}$ <br> (Note 1, 2a) | ${ }^{\text {t }}$ HW | 95 | - | 33 | - | ns |
| 22 | Muxed Address Valid Time to E Rise $\mathrm{t}_{\mathrm{AVM}}=\mathrm{PW} \mathrm{EL}-\left(\mathrm{t}_{\mathrm{ASD}}+90 \mathrm{~ns}\right)$ <br> (Note 1, 2a) | $\mathrm{t}_{\text {AVM }}$ | 265 | - | 78 | - | ns |
| 24 | Muxed Address Valid Time to AS Fall $\mathrm{t}_{\mathrm{ASL}}=\mathrm{PW} \text { ASH }-70 \mathrm{~ns}$ <br> (Note 1) | ${ }^{\text {taSL }}$ | 150 | - | 25 | - | ns |
| 25 | Muxed Address Hold Time <br> $\mathrm{t}_{\mathrm{AHL}}=1 / 8 \mathrm{t}_{\text {cyc }}-29.5 \mathrm{~ns}$$\quad$ (Note 1, 2b) | $\mathrm{t}_{\text {AHL }}$ | 95 | - | 33 | - | ns |
| 26 | Delay Time, E to AS Rise $t_{\mathrm{ASD}}=1 / 8 \mathrm{t}_{\mathrm{cyc}}-9.5 \mathrm{~ns}$ <br> (Note 1, 2a) | $\mathrm{t}_{\text {ASD }}$ | 120 | - | 58 | - | ns |
| 27 | Pulse Width, AS High <br> $\mathrm{PW}_{\mathrm{ASH}}=1 / 4 \mathrm{t}_{\mathrm{cyc}}-29 \mathrm{~ns} \quad$ (Note 1) | $\mathrm{PW}_{\text {ASH }}$ | 220 | - | 95 | - | ns |
| 28 | Delay Time, AS to E Rise $t_{\text {ASED }}=1 / 8 \mathrm{t}_{\mathrm{cyc}}-9.5 \mathrm{~ns}$ <br> (Note 1, 2b) | $\mathrm{t}_{\text {ASED }}$ | 120 | - | 58 | - | ns |
| 29 | $\begin{array}{\|l\|} \hline \text { MPU Address Access Time } \\ t_{A C C A}=t_{c y c}-\left(P W_{E L}-t_{A V M}\right)-t_{D S R}-t_{f} \end{array} \quad \text { (Note 2a) }$ | $\mathrm{t}_{\mathrm{ACCA}}$ | 735 | - | 298 | - | ns |
| 35 | MPU Access Time $\mathrm{t}_{\mathrm{ACCE}}=\mathrm{PW}_{\mathrm{EH}}-\mathrm{t}_{\mathrm{DSR}}$ | $\mathrm{t}_{\text {ACCE }}$ | - | 440 | - | 190 | ns |
| 36 | Muxed Address Delay (Previous Cycle MPU Read) $t_{M A D}=t_{A S D}+30 \mathrm{~ns}$ <br> (Note 1, 2a) | ${ }^{\text {mad }}$ | 150 | - | 88 | - | ns |

NOTES:

1. Formula only for dc to 2 MHz .
2. Input clocks with duty cycles other than $50 \%$ affect bus performance. Timing parameters affected by input clock duty cycle are identified by (a) and (b). To recalculate the approximate bus timing values, substitute the following expressions in place of $1 / 8 \mathrm{t}_{\mathrm{cyc}}$ in the above formulas, where applicable:
(a) $(1-D C) \times 1 / 4 t_{\text {cyc }}$
(b) $D C \times 1 / 4 t_{\text {cyc }}$

Where:
$D C$ is the decimal value of duty cycle percentage (high time).
3. All timing is shown with respect to $20 \% \mathrm{~V}_{\mathrm{DD}}$ and $70 \% \mathrm{~V}_{\mathrm{DD}}$, unless otherwise noted.


NOTE: Measurement points shown are $20 \%$ and $70 \%$ of $V_{D D}$.
mux BuS TIM
Figure A-14. Multiplexed Expansion Bus Timing Diagram

Table A-8. Serial Peripheral Interface (SPI) Timing
$V_{D D}=5.0 \mathrm{Vdc} \pm 10 \%, V_{S S}=0 \mathrm{Vdc}, \mathrm{T}_{\mathrm{A}}=\mathrm{T}_{\mathrm{L}}$ to $\mathrm{T}_{\mathrm{H}}$

| Num | Characteristic | Symbol | 2.0 MHz |  | 3.0 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max | Min | Max |  |
|  | Operating Frequency Master Slave | $\begin{aligned} & \left.\mathrm{f}_{\mathrm{op}(\mathrm{~m})}\right) \\ & \left.\mathrm{f}_{\mathrm{op}(\mathrm{~s})}\right) \end{aligned}$ | $\begin{aligned} & \mathrm{dc} \\ & \mathrm{dc} \end{aligned}$ | $\begin{aligned} & 0.5 \\ & 2.0 \end{aligned}$ | $\begin{aligned} & \mathrm{dc} \\ & \mathrm{dc} \end{aligned}$ | $\begin{aligned} & 0.5 \\ & 3.0 \end{aligned}$ | $\begin{gathered} \mathrm{f}_{\mathrm{op}} \\ \mathrm{MHz} \end{gathered}$ |
| 1 | Cycle Time Master Slave | $\begin{gathered} \mathrm{t}_{\mathrm{cyc}(\mathrm{~m})} \\ \mathrm{t}_{\mathrm{cyc}(\mathrm{~s})} \end{gathered}$ | $\begin{aligned} & 2.0 \\ & 500 \end{aligned}$ | - | $\begin{aligned} & 2.0 \\ & 333 \end{aligned}$ | - | $\mathrm{t}_{\text {cyc }}$ ns |
| 2 | Enable Lead Time <br> Master <br> Slave (Note 2) | $t_{\text {lead(m) }}$ <br> $t_{\text {lead(s) }}$ | $\overline{250}$ | 二 | 240 | - | $\begin{aligned} & \mathrm{ns} \\ & \mathrm{~ns} \end{aligned}$ |
| 3 | Enable Lag Time <br> Master <br> Slave (Note 2) | $\begin{aligned} & \mathrm{t}_{\log (\mathrm{m})} \\ & \mathrm{t}_{\log (\mathrm{s})} \end{aligned}$ | 250 | - | 240 | - | $\begin{aligned} & \text { ns } \\ & \text { ns } \end{aligned}$ |
| 4 | Clock (SCK) High Time Master Slave | $\begin{gathered} \mathrm{t}_{\mathrm{w}(\mathrm{SCKH}) \mathrm{m}} \\ \mathrm{t}_{\mathrm{w}(\mathrm{SCKH}) \mathrm{s}} \\ \hline \end{gathered}$ | $\begin{array}{r} 340 \\ 190 \\ \hline \end{array}$ | - | $\begin{array}{r} 227 \\ 127 \\ \hline \end{array}$ | - | $\begin{aligned} & \mathrm{ns} \\ & \mathrm{~ns} \end{aligned}$ |
| 5 | Clock (SCK) Low Time Master Slave | $\begin{gathered} \mathrm{t}_{\mathrm{w}(\mathrm{SCKL}) \mathrm{m}} \\ \mathrm{t}_{\mathrm{w}(\mathrm{SCKL}) \mathrm{s}} \\ \hline \end{gathered}$ | $\begin{aligned} & 340 \\ & 190 \end{aligned}$ | - | 227 127 | 二 | $\begin{aligned} & \text { ns } \\ & \text { ns } \end{aligned}$ |
| 6 | Data Setup Time (Inputs) Master Slave | $t_{s u(m)}$ <br> $\mathrm{t}_{\mathrm{su}}(\mathrm{s})$ | $\begin{aligned} & 100 \\ & 100 \end{aligned}$ |  | $\begin{aligned} & 100 \\ & 100 \end{aligned}$ | - | $\begin{aligned} & \text { ns } \\ & \text { ns } \end{aligned}$ |
| 7 | Data Hold Time (Inputs) Master Slave | $\begin{aligned} & t_{h(m)} \\ & t_{h(s)} \end{aligned}$ | $\begin{aligned} & 100 \\ & 100 \end{aligned}$ | - | $\begin{aligned} & 100 \\ & 100 \end{aligned}$ | - | $\begin{aligned} & \text { ns } \\ & \text { ns } \end{aligned}$ |
| 8 | Access Time (Time to Data Active from HighImpedance State) Slave | $\mathrm{ta}_{\text {a }}$ | 0 | 120 | 0 | 120 | ns |
| 9 | Disable Time (Hold Time to High-Impedance State) Slave | $t_{\text {dis }}$ | - | 240 | - | 167 | ns |
| 10 | Data Valid (After Enable Edge) (Note 3) | $\mathrm{t}_{\mathrm{v}(\mathrm{s})}$ | - | 240 | - | 167 | ns |
| 11 | Data Hold Time (Outputs) (After Enable Edge) | $t_{\text {ho }}$ | 0 | - | 0 | - | ns |
| 12 | Rise Time ( $20 \% \mathrm{~V}_{\mathrm{DD}}$ to $70 \% \mathrm{~V}_{\mathrm{DD}}$, CL $=200 \mathrm{pF}$ ) SPI Outputs (SCK, MOSI, and MISO) SPI Inputs (SCK, MOSI; MISO, and $\overline{\text { SS }}$ ) | $\begin{aligned} & \mathrm{t}_{\mathrm{rm}} \\ & \mathrm{t}_{\mathrm{rs}} \\ & \hline \end{aligned}$ | - | $\begin{gathered} 100 \\ 2.0 \end{gathered}$ | - | $\begin{aligned} & 100 \\ & 2.0 \end{aligned}$ | $\begin{aligned} & \mathrm{ns} \\ & \mu \mathrm{~s} \end{aligned}$ |
| 13 | Fall Time $\left(70 \% V_{D D}\right.$ to $\left.20 \% V_{D D}, C_{L}=200 \mathrm{pF}\right)$ SPI Outputs (SCK, MOSI, and MISO) SPI Inputs (SCK, MOSI, MISO, and SS) | $\underset{\mathrm{t}_{\mathrm{fs}}}{\mathrm{t}_{\mathrm{f}}}$ | - | $\begin{gathered} 100 \\ 2.0 \end{gathered}$ | - | $\begin{aligned} & 100 \\ & 2.0 \end{aligned}$ | $\begin{aligned} & \mathrm{ns} \\ & \mu \mathrm{~s} \end{aligned}$ |

NOTES:

1. All timing is shown with respect to $20 \% \mathrm{~V}_{\mathrm{DD}}$ and $70 \% \mathrm{~V}_{\mathrm{DD}}$, unless otherwise noted.
2. Signal production depends on software.
3. Assumes 200 pF load on all SPI pins.

Table A－8a．Serial Peripheral Interface（SPI）Timing（MC68L11A8）
$\mathrm{V}_{\mathrm{DD}}=3.0 \mathrm{Vdc}$ to $5.5 \mathrm{Vdc}, \mathrm{V}_{\mathrm{SS}}=0 \mathrm{Vdc}, \mathrm{T}_{\mathrm{A}}=\mathrm{T}_{\mathrm{L}}$ to $\mathrm{T}_{\mathrm{H}}$

| Num | Characteristic | Symbol | 1．0 MHz |  | 2．0 MHz |  | Unit |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: | :---: |
|  |  |  | Min | Max | Min | Max |  |
|  | Operating Frequency Master Slave | $\begin{aligned} & \left.\mathrm{f}_{\mathrm{op}(\mathrm{~m})}\right) \\ & \mathrm{f}_{\mathrm{op}(\mathrm{~s})} \end{aligned}$ | $\begin{aligned} & \mathrm{dc} \\ & \mathrm{dc} \end{aligned}$ | $\begin{aligned} & 0.5 \\ & 1.0 \end{aligned}$ | $\mathrm{dc}$ | $\begin{aligned} & 0.5 \\ & 2.0 \\ & \hline \end{aligned}$ | $\stackrel{\mathrm{f}_{\mathrm{op}}}{\mathrm{MHz}}$ |
| 1 | Cycle Time Master Slave | $\begin{aligned} & \mathrm{t}_{\mathrm{cyc}(\mathrm{~m})} \\ & \mathrm{t}_{\mathrm{cyc}(\mathrm{~s})} \\ & \hline \end{aligned}$ | $\begin{gathered} 2.0 \\ 1000 \\ \hline \end{gathered}$ | － | $\begin{aligned} & 2.0 \\ & 500 \end{aligned}$ | 二 | $\begin{aligned} & \mathrm{t}_{\mathrm{cyc}} \\ & \mathrm{~ns} \end{aligned}$ |
| 2 | Enable Lead Time <br> Master <br> Slave  <br> （Note 2）  | $t_{\text {lead（m）}}$ <br> $t_{\text {lead（s）}}$ | 500 | 二 | 250 | 二 | $\begin{aligned} & \text { ns } \\ & \text { ns } \end{aligned}$ |
| 3 | Enable Lag Time <br> Master <br> Slave （Note 2） | $\begin{aligned} & \mathrm{t}_{\log (\mathrm{m})} \\ & \mathrm{t}_{\operatorname{lag}(\mathrm{s})} \\ & \hline \end{aligned}$ | $500$ | － | 250 | － | $\begin{aligned} & \text { ns } \\ & \text { ns } \end{aligned}$ |
| 4 | Clock（SCK）High Time Master Slave | $\begin{gathered} \mathrm{t}_{\mathrm{w}(\text { SCKH }) \mathrm{m}} \\ \mathrm{t}_{\mathrm{w}(\text { SCKH }) \mathrm{s}} \\ \hline \end{gathered}$ | $\begin{aligned} & 680 \\ & 380 \\ & \hline \end{aligned}$ | － | $\begin{array}{r} 340 \\ 190 \\ \hline \end{array}$ | － | $\begin{aligned} & \text { ns } \\ & \text { ns } \end{aligned}$ |
| 5 | Clock（SCK）Low Time Master Slave | $\begin{gathered} \mathrm{t}_{\mathrm{w}(\mathrm{SCKL}) \mathrm{m}} \\ \mathrm{t}_{\mathrm{w}(\mathrm{SCKL}) \mathrm{s}} \\ \hline \end{gathered}$ | $\begin{aligned} & 680 \\ & 380 \\ & \hline \end{aligned}$ | 三－ | $\begin{array}{r} 340 \\ 190 \\ \hline \end{array}$ | 二 | $\begin{aligned} & \mathrm{ns} \\ & \text { ns } \end{aligned}$ |
| 6 | Data Setup Time（Inputs） Master Slave | $\begin{aligned} & \mathrm{t}_{\mathrm{su}(\mathrm{~m})} \\ & \mathrm{t}_{\mathrm{su}(\mathrm{~s})} \end{aligned}$ | $\begin{aligned} & 100 \\ & 100 \\ & \hline \end{aligned}$ | － | $\begin{aligned} & 100 \\ & 100 \\ & \hline \end{aligned}$ | 二 | $\begin{aligned} & \mathrm{ns} \\ & \mathrm{~ns} \\ & \hline \end{aligned}$ |
| 7 | Data Hold Time（Inputs） <br> Master <br> Slave | $\begin{aligned} & t_{h(m)} \\ & t_{h(s)} \end{aligned}$ | $\begin{aligned} & 100 \\ & 100 \\ & \hline \end{aligned}$ |  | $\begin{aligned} & 100 \\ & 100 \\ & \hline \end{aligned}$ | 二 | $\begin{aligned} & \text { ns } \\ & \text { ns } \end{aligned}$ |
| 8 | Access Time（Time to Data Active from High－ Impedance State） Slave | $\mathrm{t}_{\mathrm{a}}$ | 0 | 120 | 0 | 120 | ns |
| 9 | Disable Time（Hold Time to High－Impedance State） Slave | $t_{\text {dis }}$ | － | 240 | － | 240 | ns |
| 10 | Data Valid（After Enable Edge）（Note 3） | $\mathrm{t}_{\mathrm{v}(\mathrm{s})}$ | － | 240 | － | 240 | ns |
| 11 | Data Hold Time（Outputs）（After Enable Edge） | $t_{\text {ho }}$ | 0 | － | 0 | － | ns |
| 12 | Rise Time（ $20 \% \mathrm{~V}_{\mathrm{DD}}$ to $70 \% \mathrm{~V}_{\mathrm{DD}}$ ， $\mathrm{CL}=200 \mathrm{pF}$ ） SPI Outputs（SCK，MOSI，and MISO） SPI Inputs（SCK，MOSI，MISO，and SS） | $\begin{aligned} & \mathrm{t}_{\mathrm{rm}} \\ & \mathrm{t}_{\mathrm{rs}} \\ & \hline \end{aligned}$ | － | $\begin{array}{r} 100 \\ 2.0 \\ \hline \end{array}$ | － | $\begin{aligned} & 100 \\ & 2.0 \\ & \hline \end{aligned}$ | $\begin{aligned} & \mathrm{ns} \\ & \mu \mathrm{~s} \end{aligned}$ |
| 13 | Fall Time $\left(70 \% V_{D D}\right.$ to $\left.20 \% V_{D D}, C_{L}=200 \mathrm{pF}\right)$ SPI Outputs（SCK，MOSI，and MISO） SPI Inputs（SCK，MOSI，MISO，and $\overline{\text { SS }}$ ） | $\begin{aligned} & \mathrm{t}_{\mathrm{fm}} \\ & \mathrm{t}_{\mathrm{fs}} \end{aligned}$ | － | $\begin{aligned} & 100 \\ & 2.0 \end{aligned}$ | － | 100 2.0 | $\begin{aligned} & \mathrm{ns} \\ & \mu \mathrm{~s} \end{aligned}$ |

NOTES：
1．All timing is shown with respect to $20 \% \mathrm{~V}_{\mathrm{DD}}$ and $70 \% \mathrm{~V}_{\mathrm{DD}}$ ，unless otherwise noted．
2．Signal production depends on software．
3．Assumes 200 pF load on all SPI pins．


NOTE: This first clock edge is generated internally but is not seen at the SCK pin.

SPI MASTER CPHAO TIM
a) SPI Master Timing (CPHA $=0$ )


NOTE: This last clock edge is generated internally but is not seen at the SCK pin.
SPI MASTER CPHAI TIM
b) SPI Master Timing (CPHA $=1$ )

Figure A-15. SPI Timing Diagram (1 of 2)


NOTE: Not defined but normally MSB of character just received.
SPI SLAVE CPHAO TIM
c) SPI Slave Timing $(\mathbf{C P H A}=0)$


NOTE: Not defined but normally LSB of character previously transmitted.

## d) SPI Slave Timing $(C P H A=1)$

Figure A-15. SPI Timing Diagrams (2 of 2)

Table A-9. EEPROM Characteristics

| Characteristic | Temperature Range |  |  | Unit |
| :---: | :---: | :---: | :---: | :---: |
|  | -40 to $85^{\circ} \mathrm{C}$ | -40 to $105^{\circ} \mathrm{C}$ | -40 to $125^{\circ} \mathrm{C}$ |  |
| Programming Time $<1.0 \mathrm{MHz}$, RCO Enabled <br> (Note 1) 1.0 to 2.0 MHz, RCO Enabled <br>  $\geq 2.0 \mathrm{MHz}$ (or Anytime RCO Enabled) | $\begin{aligned} & 10 \\ & 20 \\ & 10 \end{aligned}$ | $\begin{gathered} \hline 15 \\ \text { Must use RCO } \\ 15 \end{gathered}$ | $\begin{array}{\|c\|} \hline 20 \\ \text { Must use RCO } \\ 20 \end{array}$ | ms |
| Erase Time (Note 1) Byte, Row and Bulk | 10 | 10 | 10 | ms |
| Write/Erase Endurance (Note 2) | 10,000 | 10,000 | 10,000 | Cycles |
| Data Retention (Note 2) | 10 | 10 | 10 | Years |

## NOTES:

1. The RC oscillator (RCO) must be enabled (by setting the CSEL bit in the OPTION register) for EEPROM programming and erasure when the E-clock frequency is below 1.0 MHz .
2. Refer to Reliability Monitor Report (current quarterly issue) for current failure rate information.

Table A-9a. EEPROM Characteristics (MC68L11A8)
$\mathrm{V}_{\mathrm{DD}}=3.0 \mathrm{Vdc}$ to $5.5 \mathrm{Vdc}, \mathrm{V}_{\mathrm{SS}}=0 \mathrm{Vdc}, \mathrm{T}_{\mathrm{A}}=\mathrm{T}_{\mathrm{L}}$ to $\mathrm{T}_{\mathrm{H}}$

| Characteristic | $\begin{array}{c}\text { Temperature Range } \\ -\mathbf{2 0} \text { to } \mathbf{7 0} 0^{\circ} \mathbf{C}\end{array}$ | Unit |  |
| :--- | :--- | :---: | :---: |
| Programming Time | $\begin{array}{c}25 \\ \text { (Note 1) }\end{array}$ | $5 \mathrm{~V}, \mathrm{E} \leq 2.0 \mathrm{MHz}$, RCO Enabled | ms |
| Erase Time (Byte, Row and Bulk) | $3 \mathrm{~V}, \mathrm{E} \leq 2.0 \mathrm{MHz}$, RCO Enabled |  |  |$)$

NOTES:

1. The RC oscillator (RCO) must be enabled (by setting the CSEL bit in the OPTION register) for EEPROM programming and erasure.
2. Refer to Reliability Monitor Report (current quarterly issue) for current failure rate information.

## APPENDIX B MECHANICAL DATA AND ORDERING INFORMATION

## B. 1 Pin Assignments

The MC68HC11A8 is available in the 52-pin plastic leaded chip carrier (PLCC), the 48-pin dual in-line package (DIP), or the 64-pin quad flat pack (QFP).


Figure B-1. 52-Pin PLCC


Figure B-2. 48-Pin DIP


Figure B-3. 64-Pin QFP


VIEW S


VIEW D-D

NOTES:

1. DATUMS - L-, -M-, AND - N- DETERMINED WHERE TOP OF LEAD SHOULDER EXITS PLASTIC BODY AT MOLD PARTING LINE
2. DIM G1, TRUE POSITION TO BE MEASURED AT DATUM -T-, SEATING PLANE
3. DIM R AND U DO NOT INCLUDE MOLD FLASH ALLOWABLE MOLD FLASH IS 0.010 (0.250) PER SIDE.
4. DIMENSIONING AND TOLERANCING PER ANSI Y14.5M, 1982.
5. CONTROLLING DIMENSION: $\operatorname{INCH}$
6. THE PACKAGE TOP MAY BE SMALLER THAN THE PACKAGE BOTTOM BY UP TO $0.012(0.300)$. DIMENSIONS R AND U ARE DETERMINED AT THE OUTERMOST EXTREMES OF THE PLASTIC BODY EXCLUSIVE OF MOLD FLASH, TIE BAR BURRS, GATE BURRS AND INTERLEAD FLASH, BUT INCLUDING ANY MISMATCH BETWEEN THE TOP AND BOTTOM ON MISMATCH BETWEEN
7. DIMENSION H DOES NOT INCLUDE DAMBAR PROTRUSION OR INTRUSION. THE DAMBAR PROTRUSION(S) SHALL NOT CAUSE THE H DIMENSION TO BE GREATER THAN 0.037 (0.940) THE DAMBAR INTRUSION(S) SHALL NOT CAUSE THE H DIMENSION TO BE SMALLER THAN 0.025 (0.635).

| DIM | INCHES |  | MILLIMETERS |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN |  | MAX |
| A | 0.785 | 0.795 | 19.94 | 20.19 |  |
| B | 0.785 | 0.795 | 19.94 | 20.19 |  |
| C | 0.165 | 0.180 | 4.20 | 4.57 |  |
| E | 0.090 | 0.110 | 2.29 | 2.79 |  |
| F | 0.013 | 0.019 | 0.33 | 0.48 |  |
| G | 0.050 BSC |  | 1.27 BSC |  |  |
| H | 0.026 | 0.032 | 0.66 | 0.81 |  |
| J | 0.020 | - | 0.51 | - |  |
| K | 0.025 | - | 0.64 | - |  |
| R | 0.750 | 0.756 | 19.05 | 19.20 |  |
| U | 0.750 | 0.756 | 19.05 | 19.20 |  |
| V | 0.042 | 0.048 | 1.07 | 1.21 |  |
| W | 0.042 | 0.048 | 1.07 | 1.21 |  |
| $\mathbf{X}$ | 0.042 | 0.056 | 1.07 | 1.42 |  |
| $\mathbf{Y}$ | - | 0.020 | - | 0.50 |  |
| $\mathbf{Z}$ | $2^{\circ}$ | $10^{\circ}$ | $2^{\circ}$ | $10^{\circ}$ |  |
| G1 | 0.710 | 0.730 | 18.04 | 18.54 |  |
| K1 | 0.040 | - | 1.02 | - |  |

CASE 778-02
ISSUE C

Figure B-4. Case Outline 778-02

NOTES:

1. DIMENSIONS AND TOLERANCING PER ANSI Y14.5M, 1982.
2. CONTROLLING DIMENSION: INCH.
3. DIMENSION L TO CENTER OF LEAD WHEN FORMED PARALLEL.
4. DIMENSIONS A AND B DO NOT INCLUDE MOLD
FLASH. MAXIMUM MOLD FLASH 0.25 ( 0.010 ).


| DIM | INCHES |  | MILLIMETERS |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: |
|  | MIN | MAX | MIN | MAX |  |
| A | 2.415 | 2.445 | 61.34 | 62.10 |  |
| B | 0.540 | 0.560 | 13.72 | 14.22 |  |
| C | 0.155 | 0.200 | 3.94 | 5.08 |  |
| D | 0.014 | 0.022 | 0.36 | 0.55 |  |
| F | 0.040 | 0.060 | 1.02 | 1.52 |  |
| G | 0.100 |  | BSC | 2.54 BSC |  |
| H | 0.070 |  | BSC | 1.79 BSC |  |
| J | 0.008 | 0.015 | 0.20 |  | 0.38 |
| K | 0.115 | 0.150 | 2.92 | 3.81 |  |
| L | 0.600 BSC |  | 15.24 BSC |  |  |
| M | $0^{\circ}$ |  | $155^{\circ}$ | $0^{\circ}$ | $15^{\circ}$ |
| N | 0.020 | 0.040 | 0.51 | 1.01 |  |

CASE 767-02
ISSUE B

Figure B-5. Case Outline 767-02



DETAIL C

NOTES:

1. DIMENSIONING AND TOLERANCING PER ANSI Y14.5M, 1982.
2. CONTROLLING DIMENSION: MILLIMETER.
3. DATUM PLANE -H- IS LOCATED AT BOTTOM OF

LEAD AND IS COINCIDENT WITH THE LEAD WHERE THE LEAD EXITS THE PLASTIC BODY AT THE BOTTOM OF THE PARTING LINE.
4. DATUMS A-B AND -D- TO BE DETERMINED AT DATUM PLANE-H.
5. DIMENSIONS S AND V TO BE DETERMINED AT SEATING PLANE -C-
6. DIMENSIONS A AND B DO NOT INCLUDE MOLD PROTRUSION. ALLOWABLE PROTRUSION IS 0.2 (0.010) PER SIDE. DIMENSIONS A AND B DO INCLUDE MOLD MISMATCH AND ARE DETERMINED AT DATUM PLANE -H.
7. DIMENSION D DOES NOT INCLUDE DAMBAR PROTRUSION. ALLOWABLE DAMBAR PROTRUSION SHALL BE 0.08 ( 0.003 ) TOTAL IN EXCESS OF THE D DIMENSION AT MAXIMUM MATERIAL CONDITION. DAMBAR CANNOT BE LOCATED ON THE LOWER RADIUS OR THE FOOT

|  | MILLIMETERS |  | INCHES |  |  |
| :---: | :---: | :---: | :---: | :---: | :---: | :---: |
| DIM | MIN | MAX | MIN | MAX |  |
| A | 13.90 | 14.10 | 0.547 | 0.555 |  |
| B | 13.90 | 14.10 | 0.547 | 0.555 |  |
| C | 2.15 | 2.45 | 0.085 | 0.096 |  |
| D | 0.30 | 0.45 | 0.012 | 0.018 |  |
| E | 2.00 | 2.40 | 0.079 | 0.094 |  |
| F | 0.30 | 0.40 | 0.012 | 0.016 |  |
| G | 0.80 BSC |  | 0.031 BSC |  |  |
| H | - | 0.25 | - |  | 0.010 |
| J | 0.13 | 0.23 | 0.005 | 0.009 |  |
| K | 0.65 | 0.95 | 0.026 | 0.037 |  |
| L | 12.00 | REF | 0.472 |  | REF |
| M | $5^{\circ}$ | $10^{\circ}$ | $5^{\circ}$ |  | $10^{\circ}$ |
| N | 0.13 | 0.17 | 0.005 | 0.007 |  |
| P | 0.40 BSC |  | 0.016 |  | BSC |
| Q | $0^{\circ}$ | $7^{\circ}$ | $0^{\circ}$ |  | $7^{\circ}$ |
| R | 0.13 | 0.30 | 0.005 | 0.012 |  |
| S | 16.95 | 17.45 | 0.667 | 0.687 |  |
| T | 0.13 | - | 0.005 | - |  |
| U | $0^{\circ}$ | - | $0^{\circ}$ | - |  |
| V | 16.95 | 17.45 | 0.667 | 0.687 |  |
| W | 0.35 | 0.45 | 0.014 | 0.018 |  |
| X | 1.6 REF |  | 0.063 |  | REF |

CASE 840B-01
ISSUE 0
DATE 11/19/90

Figure B-6. Case Outline 840B-01

Table B-1. Ordering Information

| Package | Temperature | CONFIG | Description | MC Order Number |
| :---: | :--- | :--- | :--- | :--- |
|  | $-40^{\circ}$ to $+85^{\circ} \mathrm{C}$ | $\$ 0 \mathrm{C}$ | No ROM, No EEPROM | MC68HC11A0CFN2 |
|  | $-40^{\circ}$ to $+85^{\circ} \mathrm{C}$ | $\$ 0 \mathrm{C}$ | No ROM, No EEPROM, 3 MHz | MC68HC11A0CFN3 |
|  | $-40^{\circ}$ to $+85^{\circ} \mathrm{C}$ | $\$ 0 \mathrm{D}$ | No ROM | MC68HC11A1CFN2 |
|  | $-40^{\circ}$ to $+85^{\circ} \mathrm{C}$ | $\$ 0 \mathrm{D}$ | No ROM, 3 MHz | MC68HC11A1CFN3 |
|  | $-40^{\circ}$ to $+105^{\circ} \mathrm{C}$ | $\$ 0 \mathrm{D}$ | No ROM | MC68HC11A1VFN2 |
|  | $-40^{\circ}$ to $+125^{\circ} \mathrm{C}$ | $\$ 0 \mathrm{D}$ | No ROM | MC68HC11A1MFN2 |
|  | $-40^{\circ}$ to $+85^{\circ} \mathrm{C}$ | $\$ 09$ | No ROM, COP On | MC68HCP11A1CFN2 |
|  | $-40^{\circ}$ to $+85^{\circ} \mathrm{C}$ | $\$ 09$ | No ROM, COP On, 3 MHz | MC68HCP11A1CFN3 |
|  | $-40^{\circ}$ to $+105^{\circ} \mathrm{C}$ | $\$ 09$ | No ROM, COP On | MC68HCP11A1VFN2 |
|  | $-40^{\circ}$ to $+125^{\circ} \mathrm{C}$ | $\$ 09$ | No ROM, COP On | MC68HCP11A1MFN2 |
|  | $-40^{\circ}$ to $+85^{\circ} \mathrm{C}$ | $\$ 0 \mathrm{~F}$ | BUFFALO ROM | MC68HC11A8BCFN2 |
|  | $-40^{\circ}$ to $+105^{\circ} \mathrm{C}$ | $\$ 0 \mathrm{~F}$ | BUFFALO ROM | MC68HC11A8VCFN2 |
|  | $-40^{\circ}$ to $+125^{\circ} \mathrm{C}$ | $\$ 0 \mathrm{~F}$ | BUFFALO ROM | MC68HC11A8MCFN2 |


|  | $-40^{\circ}$ to $+85^{\circ} \mathrm{C}$ | $\$ 0 \mathrm{C}$ | No ROM, No EEPROM | MC68HC11A0CP2 |
| :---: | :---: | :---: | :--- | :--- |
|  | $-40^{\circ}$ to $+85^{\circ} \mathrm{C}$ | $\$ 0 \mathrm{C}$ | No ROM, No EEPROM, 3 MHz | MC68HC11A0CP3 |
|  | $-40^{\circ}$ to $+85^{\circ} \mathrm{C}$ | $\$ 0 \mathrm{D}$ | No ROM | MC68HC11A1CP2 |
|  | $-40^{\circ}$ to $+85^{\circ} \mathrm{C}$ | $\$ 0 \mathrm{D}$ | No ROM, 3 MHz | MC68HC11A1CP3 |
|  | $-40^{\circ}$ to $+105^{\circ} \mathrm{C}$ | $\$ 0 \mathrm{D}$ | No ROM | MC68HC11A1VP2 |
|  | $-40^{\circ}$ to $+125^{\circ} \mathrm{C}$ | $\$ 0 \mathrm{D}$ | No ROM | MC68HC11A1MP2 |
|  | $-40^{\circ}$ to $+85^{\circ} \mathrm{C}$ | $\$ 09$ | No ROM, COP On | MC68HCP11A1CP2 |
|  | $-40^{\circ}$ to $+85^{\circ} \mathrm{C}$ | $\$ 09$ | No ROM, COP On, 3 MHz | MC68HCP11A1CP3 |
|  | $-40^{\circ}$ to $+105^{\circ} \mathrm{C}$ | $\$ 09$ | No ROM, COP On | MC68HCP11A1VP2 |
|  | $-40^{\circ}$ to $+125^{\circ} \mathrm{C}$ | $\$ 09$ | No ROM, COP On | MC68HCP11A1MP2 |
|  | $-40^{\circ}$ to $+85^{\circ} \mathrm{C}$ | $\$ 0 \mathrm{~F}$ | BUFFALO ROM | MC68HC11A8BCP2 |
|  | $-40^{\circ}$ to $+105^{\circ} \mathrm{C}$ | $\$ 0 \mathrm{~F}$ | BUFFALO ROM | MC68HC11A8BVP2 |
|  | $-40^{\circ}$ to $+125^{\circ} \mathrm{C}$ | $\$ 0 \mathrm{~F}$ | BUFFALO ROM | MC68HC11A8BMP2 |


| 64-Pin QFP | $-40^{\circ}$ to $+85^{\circ} \mathrm{C}$ | $\$ 0 \mathrm{C}$ | No ROM, No EEPROM | MC68HC11A0CFU2 |
| :--- | :--- | :--- | :--- | :--- |
|  | $-40^{\circ}$ to $+85^{\circ} \mathrm{C}$ | $\$ 0 \mathrm{C}$ | No ROM, No EEPROM, 3 MHz | MC68HC11A0CFU3 |
|  | $-40^{\circ}$ to $+85^{\circ} \mathrm{C}$ | $\$ 0 \mathrm{D}$ | No ROM | MC68HC11A1CFU2 |
|  | $-40^{\circ}$ to $+85^{\circ} \mathrm{C}$ | $\$ 0 \mathrm{D}$ | No ROM, 3 MHz | MC68HC11A1CFU3 |
|  | $-40^{\circ}$ to $+105^{\circ} \mathrm{C}$ | $\$ 0 \mathrm{D}$ | No ROM | MC68HC11 A1VFU2 |
|  | $-40^{\circ}$ to $+125^{\circ} \mathrm{C}$ | $\$ 0 \mathrm{D}$ | No ROM | MC68HC11A1MFU2 |
|  | $-40^{\circ}$ to $+85^{\circ} \mathrm{C}$ | $\$ 0 \mathrm{~F}$ | BUFFALO ROM | MC68HC11A8BCFU2 |
|  | $-40^{\circ}$ to $+105^{\circ} \mathrm{C}$ | $\$ 0 \mathrm{~F}$ | BUFFALO ROM | MC68HC11A8VCFU2 |



Figure B-7. M68HC11 P/N Options

## APPENDIX C DEVELOPMENT SUPPORT

## C. 1 M68HC11EVB - Evaluation Board

Refer to the M68HC11EVB Evaluation Board User's Manual (M68HC11EVB/D1). The Evaluation Board (EVB) is a low cost tool for debugging and evaluating M68HC11 MCU-based target system equipment. The EVB is designed to operate in either the debugging or evaluation mode of operation.

## C.1.1 EVB Features

- A low cost means of debugging user-assembled code and evaluating target systems incorporating M68HC11 MCUs
- One-line assembler/disassembler
- Host computer downloading capability
- M68HC11 MCU-based debugging/evaluating circuitry
- MC68HC24 Port Replacement Unit (PRU)-based MCU I/O expansion circuitry
- MC6850 Asynchronous Communications Interface Adaptor (ACIA)-based terminal I/O port circuitry
- RS-232C compatible terminal/host computer I/O ports


## C. 2 M68HC11EVBU - Universal Evaluation Board

Refer to M68HC11EVBU Universal Evaluation Board User's Manual (M68HC11EVBU/AD1). The EVBU is a low cost development tool for debugging and evaluation of MC68HC11A8, E9, 7E9, and 8E2 MCUs. The EVBU was designed along with a monitor/debugging program called BUFFALO (Bit User Fast Friendly Aid to Logical Operations). This monitor program is contained in MCU ROM. The debugging/evaluation operation allows the user to debug user code under control of the BUFFALO monitor program.

## C.2.1 EVBU Features

- A low-cost means of debugging user assembled code and evaluating MC68HC11A8, E9, 7E9, and 8E2 MCU devices
- BUFFALO monitor in ROM or PCBUG11 software working through boot mode
- One-line assembler/disassembler
- Program downloading capability
- M68HC11-based debugging/evaluating circuitry
- RS-232C compatible terminal I/O port
- Wire-wrap area for custom interfacing
- Single ( +5 Vdc ) input power source requirements


## C. 3 M68HC11EVM - Evaluation Module

Refer to M68HC11EVM Evaluation Module User's Manual (M68HC11EVM/AD7). The EVM is a tool for designing, debugging, and evaluation of M68HC11 MCU-based target system equipment. By providing MCU timing and I/O circuitry, the EVM simplifies user evaluation of the prototype hardware/software product. The EVM requires a user-supplied power supply and an RS232C compatible terminal for operation. The EVM evaluates both single-chip and expandedmultiplexed modes of operation. Generating, executing, and debugging target system MCU code is accomplished in either mode.

## C.3.1 EVM Features

- Low cost means of evaluating target systems with M68HC11 A- and E-series devices
- Monitor/debugger firmware
- One-line assembler/disassembler
- Host computer download capability
- Dual 64 Kbyte memory maps:
- 16 Kbyte monitor EPROM
- 8 Kbyte/16 Kbyte user pseudo-ROM
- EEPROM MCU programmer
- MCU (single-chip/expanded-multiplexed mode) extension I/O ports
- RS-232C terminal and host computer I/O ports


## C. 4 MMDS11 - Modular Development System

The M68MMDS11 Motorola Modular Development System (MMDS11) is an emulator system for developing embedded systems based on an M68HC11 microcontroller unit (MCU). The MMDS11 provides a bus state analyzer and real-time memory windows. The unit's integrated development environment includes an editor, an assembler, user interface, and source-level debugging capability. These features significantly reduce the time necessary to develop and debug an embedded control system. The unit's compact size requires a minimum of bench space. The MMDS11 is one component of Motorola's modular approach to MCU-based product development. This modular approach allows easy configuration of the MMDS11 to fit a wide range of requirements. It also reduces development system cost by allowing the user to purchase only the modular components necessary to support the particular MCU device family.

The station module is a metal enclosure that contains a printed circuit board (the control board), a test emulator module (TEM), and an internal power supply. A power cable, an RS-232 serial cable, two logic clip cables (with clips), and a 9 - to 25 -pin RS-232 adapter come with the MMDS11. The system requires an IBM-PC (or compatible) host computer. Connection to a target system is via a separately purchased M 68 HC 11 emulator module (EM) and target cable. The EM completes MMDS11 functionality for a particular MCU derivative or MCU family. The many EMs available let the system emulate a variety of different M68HC11 MCUs. Connection to a target system is made with a separately purchased cable (with the appropriate connector) which connects the EM to the target system. MMDS11 features include:

## C.4.1 MMDS11Features

- Real-time, non-intrusive, in-circuit emulation at the MCU's operating frequency
- Real-time bus state analyzer
- $8 \mathrm{~K} \times 64$ real-time trace buffer
- Display of real-time trace data as raw data, disassembled instructions, raw data and disassembled instructions, or assembly-language source code
- Four hardware triggers for commencing trace and to provide breakpoints
- Nine triggering modes
- As many as 8190 pre- or post-trigger points for trace data
- 16 general-purpose logic clips, four of which can be used to trigger the bus state analyzer sequencer
- 16-bit time tag, or an optional 24-bit time tag that reduces the logic clips traced from sixteen to eight
- Four data breakpoints (hardware breakpoints)
- Hardware instruction breakpoints over either the 64 K byte M68HC11 memory map, or over a 1MB bank-switched memory map
- Thirty-two real-time variables, nine of which can be displayed in the variables window. These variables may be read or written while the MCU is running
- Thirty-two bytes of real-time memory can be displayed in the memory window. This memory may be read or written while the MCU is running
- 64 Kbytes of fast emulation memory (SRAM)
- Target input/output connections are current limited
- Six software-selectable oscillator clock sources: five internally generated frequencies and an external frequency via a bus analyzer logic clip
- Command and response logging to MS DOS disk files to save session history
- SCRIPT command for automatic execution of a sequence of MMDS11 commands
- Assembly or C-language source-level debugging with global variable viewing
- Host/emulator communications speeds as high as 57600 baud for quick program loading
- Extensive on-line MCU information via the CHIPINFO command. View memory-map, vectors, register, and pin-out information pertaining to the device being emulated
- Host software supports
- An editor
- An assembler, user interface, and source-level debugging capability
- Bus state analysis
- IBM mouse


## SUMMARY OF CHANGES

This is a revision with complete reprint. All known errors in the publication have been corrected. The following summary lists significant changes. References to parts no longer manufactured have been removed throughout the document and are not noted individually. Typographical errors which do not effect content have not been noted.

## Section 5 Serial Communications Interface (SCI)

Page 5-10 $\quad 12 \mathrm{MHz}$ references added to table $5-3(E=3 \mathrm{MHz})$.
Page 5-11 4800 Baud references added to table 5-4.

Section 8 Programmable Timer, Real Time Interrupt, and Pulse Accumulator
Page 8-8
12 MHz references added to table 8-1.

Section 9 Resets, Interrupts, and Low Power Modes
Page 9-5
12 MHz references added to table 9-1 ( $\mathrm{E}=3 \mathrm{MHz}$ ).

## Appendix A Electrical Characteristics

Page A-1 through A-26 Appendix A has been updated throughout to include low-voltage characteristics.

## Appendix B Mechanical Data and Ordering Information

Page B-8
Figure B-7 has been replaced.

## Literature Distribution Centers:

USA: Motorola Literature Distribution; P.O. Box 20912; Phoenix, Arizona 85036.
EUROPE: Motorola Ltd.; European Literature Centre; 88 Tanners Drive, Blakelands, Milton Keynes, MK14 5BP, England. JAPAN: Nippon Motorola Ltd.; 4-32-1, Nishi-Gotanda, Shinagawa-ku, Tokyo 141, Japan.
ASIA PACIFIC: Motorola Semiconductors H.K. Ltd.; Silicon Harbour Center, No. 2 Dai King Street, Tai Po Industrial Estate, Tai Po, N.T., Hong Kong.

1ATX18641-16 PRINTED IN USA 9/94 IMPERIAL LITHO $99308 \quad 8,000 \quad$ MCU YGACAA


[^0]:    *Cycle-by-cycle number provides a reference to Tables 10-2 through 10-8 which detail cycle-by-cycle operation.

[^1]:    *Cycle-by-cycle number provides a reference to Tables 10-2 through 10-8 which detail cycle-by-cycle operation.

[^2]:    *The reference number is given to provide a cross-reference to Table 10-1

[^3]:    *The reference number is given to provide a cross-reference to Table 10-1

[^4]:    *The reference number is given to provide a cross-reference to Table 10-1

[^5]:    *The reference number is given to provide a cross-reference to Table 10-1

[^6]:    *The reference number is given to provide a cross-reference to Table 10-1

[^7]:    *The reference number is given to provide a cross-reference to Table 10-1

