M68HC11K Family Technical Data

HCMOS
Microcontroller Unit



# MC68HC11K Family

### **Technical Data**

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 which may be provided in Motorola data sheets and/or specifications can and do vary in different applications and actual performance may vary over time. All operating parameters, including "Typicals" must be validated for each customer application by customer's technical experts. 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, Inc. is an Equal Opportunity/Affirmative Action Employer.

Motorola and 
are registered trademarks of Motorola, Inc.

DigitalDNA is a trademark of Motorola, Inc.

© Motorola, Inc., 2001

M68HC11K Family Technical Data

MOTOROLA 3

#### **Revision History**

To provide the most up-to-date information, the revision of our documents on the World Wide Web will be the most current. Your printed copy may be an earlier revision. To verify you have the latest information available, refer to:

http://www.motorola.com/semiconductors

The following revision history table summarizes changes contained in this document. For your convenience, the page number designators have been linked to the appropriate location.

#### **Revision History**

| Date          | Revision<br>Level | Description      | Page<br>Number(s) |
|---------------|-------------------|------------------|-------------------|
| October, 2001 | N/A               | Original release | N/A               |

Technical Data M68HC11K Family

4 MOTOROLA

M68HC11K Family

## **List of Sections**

**Technical Data** 

| Section 1. General Description25                  |
|---------------------------------------------------|
| Section 2. Pin Description                        |
| Section 3. Central Processor Unit (CPU)45         |
| Section 4. Operating Modes and On-Chip Memory     |
| Section 5. Resets and Interrupts                  |
| Section 6. Parallel Input/Output135               |
| Section 7. Serial Communications Interface (SCI)  |
| Section 8. Serial Peripheral Interface (SPI)167   |
| Section 9. Timing System181                       |
| Section 10. Analog-to-Digital (A/D) Converter 221 |
| Section 11. Memory Expansion and Chip Selects231  |
| Section 12. Electrical Characteristics            |
| Section 13. Mechanical Data273                    |
| Section 14. Ordering Information281               |
| Section 15. Development Support283                |
| Index                                             |
|                                                   |

## List of Sections

### **Table of Contents**

# Section 1. General Description

| 1.1  | Contents                                                                                                |
|------|---------------------------------------------------------------------------------------------------------|
| 1.2  | Introduction                                                                                            |
| 1.3  | M68HC11K Family Members                                                                                 |
| 1.4  | Features                                                                                                |
| 1.5  | Structure                                                                                               |
|      | Section 2. Pin Description                                                                              |
| 2.1  | Contents                                                                                                |
| 2.2  | Introduction31                                                                                          |
| 2.3  | Power Supply (V <sub>DD</sub> , V <sub>SS</sub> , AV <sub>DD</sub> , and AV <sub>SS</sub> )             |
| 2.4  | Reset (RESET)                                                                                           |
| 2.5  | Crystal Driver and External Clock Input (XTAL and EXTAL) 37                                             |
| 2.6  | XOUT38                                                                                                  |
| 2.7  | E-Clock Output (E)                                                                                      |
| 2.8  | Interrupt Request (IRQ) and Non-Maskable Interrupt (XIRQ) .38                                           |
| 2.9  | Mode Selection, Instruction Cycle Reference, and Standby Power (MODA/LIR and MODB/V <sub>STBY</sub> )39 |
| 2.10 | V <sub>RH</sub> and V <sub>RL</sub> 41                                                                  |
| 2.11 | Port Signals41                                                                                          |

# Section 3. Central Processor Unit (CPU)

| 3.1                                                       | Contents                                                                                                                                                                                                                                                                                                     |
|-----------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3.2                                                       | Introduction46                                                                                                                                                                                                                                                                                               |
| 3.3<br>3.3.3<br>3.3.3<br>3.3.4<br>3.3.6<br>3.3.6<br>3.3.6 | 2       Index Register X (IX)       .47         3       Index Register Y (IY)       .47         4       Stack Pointer (SP)       .48         5       Program Counter (PC)       .50         6       Condition Code Register (CCR)       .50                                                                  |
| 3.3.0<br>3.3.0<br>3.3.0<br>3.3.0<br>3.3.0<br>3.3.0        | 6.2       Overflow (V)       .50         6.3       Zero (Z)       .50         6.4       Negative (N)       .51         6.5       Interrupt Mask (I)       .51         6.6       Half Carry (H)       .51         6.7       Non-Maskable Interrupt (X)       .52         6.8       Stop Disable (S)       .52 |
| 3.4                                                       | Data Types                                                                                                                                                                                                                                                                                                   |
| 3.5<br>3.6<br>3.6.3<br>3.6.3<br>3.6.4<br>3.6.6            | 2       Direct       .54         3       Extended       .54         4       Indexed       .54         5       Inherent       .55         6       Relative       .55                                                                                                                                          |
| 3.7                                                       | Instruction Set55                                                                                                                                                                                                                                                                                            |

| 4.1                                              | Contents                                                                                                                                                                                                                                                                                                                      |
|--------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4.2                                              | Introduction                                                                                                                                                                                                                                                                                                                  |
| 4.3                                              | Control Registers                                                                                                                                                                                                                                                                                                             |
| 4.4                                              | System Initialization                                                                                                                                                                                                                                                                                                         |
| 4.5<br>4.5.1<br>4.5.2<br>4.5.3<br>4.5.4<br>4.5.5 | Operating Modes         77           Single-Chip Mode         77           Expanded Mode         77           Bootstrap Mode         78           Special Test Mode         79           Mode Selection         79                                                                                                            |
| 4.6<br>4.6.1<br>4.6.2<br>4.6.3<br>4.6.4          | Memory Map.81Control Registers and RAM84ROM or EPROM.87EEPROM87Bootloader ROM.90                                                                                                                                                                                                                                              |
| 4.7<br>4.7.1<br>4.7.2                            | EPROM/OTPROM (M68HC711K4 and M68HC711KS2)90 Programming the EPROM with Downloaded Data90 Programming the EPROM from Memory91                                                                                                                                                                                                  |
| 4.8.2.<br>4.8.2.<br>4.8.2.                       | 2       Block Protect Register       .96         3       System Configuration Options Register       .97         EEPROM Programming       .97         1       EEPROM Programming       .98         2       EEPROM Bulk Erase       .99         3       EEPROM Row Erase       .99         4       EEPROM Byte Erase       .99 |
| 4.8.3<br>4.8.4                                   | CONFIG Register Programming                                                                                                                                                                                                                                                                                                   |

# **Table of Contents**

| 4.9 XOUT Pin Control                                                                                                                                                                                                                                                                                                       |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4.9.2 System Configuration Options 2 Register                                                                                                                                                                                                                                                                              |
| Section 5. Resets and Interrupts                                                                                                                                                                                                                                                                                           |
| 5.1 Contents                                                                                                                                                                                                                                                                                                               |
| 5.2 Introduction                                                                                                                                                                                                                                                                                                           |
| 5.3       Sources of Resets                                                                                                                                                                                                                                                                                                |
| 5.3.3.1System Configuration Register                                                                                                                                                                                                                                                                                       |
| 5.4 Effects of Reset                                                                                                                                                                                                                                                                                                       |
| 5.5       Interrupts.       117         5.5.1       Non-Maskable Interrupts       120         5.5.1.1       Non-Maskable Interrupt Request (XIRQ)       120         5.5.1.2       Illegal Opcode Trap       120         5.5.1.3       Software Interrupt (SWI)       121         5.5.2       Maskable Interrupts       121 |
| 5.6 Reset and Interrupt Priority122                                                                                                                                                                                                                                                                                        |
| 5.7 Reset and Interrupt Processing123                                                                                                                                                                                                                                                                                      |
| 5.8       Low-Power Operation       129         5.8.1       Wait Mode       130         5.8.2       Stop Mode       130         5.8.3       Slow Mode       132                                                                                                                                                            |

**Technical Data** 

## Section 6. Parallel Input/Output

| 6.1                             | Contents                                                                                |
|---------------------------------|-----------------------------------------------------------------------------------------|
| 6.2                             | Introduction                                                                            |
| 6.3                             | Port A                                                                                  |
| 6.4                             | Port B                                                                                  |
| 6.5                             | Port C                                                                                  |
| 6.6                             | Port D                                                                                  |
| 6.7                             | Port E                                                                                  |
| 6.8                             | Port F                                                                                  |
| 6.9                             | Port G                                                                                  |
| 6.10                            | Port H                                                                                  |
| 6.11                            | Internal Pullup Resistors147                                                            |
| ,                               | Section 7. Serial Communications Interface (SCI)                                        |
|                                 |                                                                                         |
| 7.1                             | Contents                                                                                |
| 7.1<br>7.2                      | Introduction                                                                            |
|                                 |                                                                                         |
| 7.2                             | Introduction149                                                                         |
| 7.2<br>7.3                      | Introduction                                                                            |
| 7.2<br>7.3<br>7.4               | Introduction.149Data Format.150Transmit Operation.151                                   |
| 7.2<br>7.3<br>7.4<br>7.5        | Introduction149Data Format150Transmit Operation151Receive Operation153                  |
| 7.2<br>7.3<br>7.4<br>7.5<br>7.6 | Introduction149Data Format150Transmit Operation151Receive Operation153Wakeup Feature156 |

M68HC11K Family

## Section 8. Serial Peripheral Interface (SPI)

| 8.1                                              | Contents                                                                                                                                                                                                                          |
|--------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8.2                                              | Introduction                                                                                                                                                                                                                      |
| 8.3                                              | SPI Functional Description                                                                                                                                                                                                        |
| 8.4<br>8.4.1<br>8.4.2<br>8.4.3<br>8.4.4<br>8.4.5 | SPI Signal Descriptions       170         Master In Slave Out (MISO)       170         Master Out Slave In (MOSI)       170         Serial Clock (SCK)       170         Slave Select (SS)       171         SPI Timing       171 |
| 8.5<br>8.5.1<br>8.5.2                            | SPI System Errors172Mode Fault Error172Write Collision Error173                                                                                                                                                                   |
| 8.6<br>8.6.1<br>8.6.2<br>8.6.3<br>8.6.4<br>8.6.5 | SPI Registers173Serial Peripheral Control Register174Serial Peripheral Status Register176Serial Peripheral Data Register177Port D Data Direction Register178System Configuration Options 2179                                     |
|                                                  | Section 9. Timing System                                                                                                                                                                                                          |
| 9.1                                              | Contents                                                                                                                                                                                                                          |
| 9.2                                              | Introduction                                                                                                                                                                                                                      |
| 9.3                                              | Timer Structure183                                                                                                                                                                                                                |
| 9.4<br>9.4.1<br>9.4.2<br>9.4.3<br>9.4.4          | Input Capture and Output Compare Overview                                                                                                                                                                                         |
| 9.4.5                                            | Pulse Accumulator Control Register                                                                                                                                                                                                |

| 9.5    | Input Capture (IC)191                               |
|--------|-----------------------------------------------------|
| 9.5.1  | Timer Input Capture Registers                       |
| 9.5.2  | Timer Input Capture 4/Output Compare 5 Register 193 |
| 9.5.3  | Timer Interrupt Flag 1 Register194                  |
| 9.5.4  | Timer Interrupt Mask 1 Register194                  |
| 9.5.5  | Timer Control 2 Register                            |
| 9.6    | Output Compare (OC)                                 |
| 9.6.1  | Timer Output Compare Registers197                   |
| 9.6.2  | Timer Input Capture 4/Output Compare 5 Register 199 |
| 9.6.3  | Timer Interrupt Flag 1 Register199                  |
| 9.6.4  | Timer Interrupt Mask 1 Register200                  |
| 9.6.5  | Timer Control 1 Register                            |
| 9.6.6  | Timer Compare Force Register                        |
| 9.6.7  | Output Compare 1 Mask Register                      |
| 9.6.8  | Output Compare 1 Data Register202                   |
| 9.7    | Pulse Accumulator (PA)                              |
| 9.7.1  | Port A Data Direction Register                      |
| 9.7.2  | Pulse Accumulator Control Register205               |
| 9.7.3  | Timer Interrupt Flag 2 Register206                  |
| 9.7.4  | Timer Interrupt Mask 2 Register207                  |
| 9.7.5  | Pulse Accumulator Count Register208                 |
| 9.8    | Real-Time Interrupt (RTI)                           |
| 9.8.1  | Timer Interrupt Flag 2 Register209                  |
| 9.8.2  | Timer Interrupt Mask 2 Register209                  |
| 9.8.3  | Pulse Accumulator Control Register210               |
| 9.9    | Pulse-Width Modulator (PWM)                         |
| 9.9.1  | PWM System Description211                           |
| 9.9.2  | Pulse-Width Modulation Control Registers213         |
| 9.9.2. | Pulse-Width Modulation Timer Clock                  |
|        | Select Register                                     |
| 9.9.2. | Pulse-Width Modulation Timer Polarity Register 215  |
| 9.9.2. | Pulse-Width Modulation Timer Prescaler Register 215 |
| 9.9.2. | Pulse-Width Modulation Timer Enable Register 216    |
| 9.9.2. | 5 Pulse-Width Modulation Timer                      |
|        | Counters 1 to 4 Registers 217                       |

| 9.9.2.6  | Pulse-Width Modulation Timer                    |
|----------|-------------------------------------------------|
|          | Periods 1 to 4 Registers                        |
| 9.9.2.7  | Pulse-Width Modulation Timer Duty               |
|          | Cycle 1 to 4 Registers                          |
| S        | Section 10. Analog-to-Digital (A/D) Converter   |
| 10.1 C   | ontents221                                      |
| 10.2 In  | troduction221                                   |
| 10.3 Fu  | unctional Description                           |
| 10.3.1   | Multiplexer                                     |
| 10.3.2   | Analog Converter                                |
| 10.3.3   | Result Registers                                |
| 10.3.4   | Digital Control224                              |
| 10.4 A   | /D Control/Status Registers                     |
| 10.4.1   | System Configuration Options Register           |
| 10.4.2   | A/D Control/Status Register                     |
| 10.4.3   | Analog-to-Digital Converter Result Registers229 |
| 10.5 D   | esign Considerations                            |
| 10.5.1   | A/D Input Pins                                  |
| 10.5.2   | Operation in Stop and Wait Modes230             |
| Se       | ction 11. Memory Expansion and Chip Selects     |
| 11.1 C   | ontents                                         |
| 11.2 In  | troduction231                                   |
| 11.3 M   | emory Expansion232                              |
| 11.3.1   | Memory Size and Address Line Allocation232      |
| 11.3.2   | Control Registers                               |
| 11.3.2.1 | Port G Assignment Register234                   |
| 11.3.2.2 | Memory Mapping Size Register                    |
| 11.3.2.3 | Memory Mapping Window Base Register             |
| 11.3.2.4 | Memory Mapping Window Control Registers237      |

| 11.4   | Chip Selects                                   | .238  |  |
|--------|------------------------------------------------|-------|--|
| 11.4.1 | Program Chip Select                            | .240  |  |
| 11.4.2 | Input/Output Chip Select                       | .241  |  |
| 11.4.3 | General-Purpose Chip Selects                   | .242  |  |
| 11.4.3 | Memory Mapping Size Register                   | .243  |  |
| 11.4.3 | General-Purpose Chip Select 1 Address Register | .243  |  |
| 11.4.3 | General-Purpose Chip Select 1 Control Register | .244  |  |
| 11.4.3 | 1 1                                            |       |  |
| 11.4.3 | 3                                              |       |  |
| 11.4.4 | <b>3</b>                                       |       |  |
| 11.4.4 | 3                                              |       |  |
| 11.4.4 | 3                                              |       |  |
| 11.4.5 | Clock Stretching                               | .248  |  |
| 11.5   | Memory Expansion Examples                      | .249  |  |
|        |                                                |       |  |
|        | Section 12. Electrical Characteristics         |       |  |
| 12.1   | Contents                                       | .253  |  |
| 12.2   | Introduction                                   | .254  |  |
| 12.3   | Maximum Ratings for Standard Devices254        |       |  |
| 12.4   | Functional Operating Range255                  |       |  |
| 12.5   | Thermal Characteristics                        |       |  |
| 12.6   | Electrical Characteristics                     |       |  |
| 12.7   | Power Dissipation Characteristics              | . 257 |  |
| 12.8   | Control Timing                                 | .259  |  |
| 12.9   | Peripheral Port Timing                         | .263  |  |
| 12.10  | Analog-to-Digital Converter Characteristics    | . 265 |  |
| 12.11  | 1 Expansion Bus Timing                         |       |  |
| 12.12  | Serial Peripheral Interface Timing269          |       |  |
| 12.13  | EEPROM Characteristics                         | .272  |  |

### **Table of Contents**

#### **Section 13. Mechanical Data**

| 13.1                             | Contents                                      |  |  |
|----------------------------------|-----------------------------------------------|--|--|
| 13.2                             | Introduction                                  |  |  |
| 13.3                             | 84-Pin Plastic-Leaded Chip Carrier (Case 780) |  |  |
| 13.4                             | 84-Pin J-Cerquad (Case 780A)                  |  |  |
| 13.5                             | 80-Pin Quad Flat Pack (Case 841B)277          |  |  |
| 13.6                             | 80-Pin Low-Profile Quad Flat Pack (Case 917A) |  |  |
| 13.7                             | 68-Pin Plastic Leaded Chip Carrier (Case 779) |  |  |
| 13.8                             | 68-Pin J-Cerquad (Case 779A)                  |  |  |
| Section 14. Ordering Information |                                               |  |  |
| Section 15. Development Support  |                                               |  |  |
| Index                            |                                               |  |  |

# **List of Figures**

| Figur | e Title                                            | Page |  |
|-------|----------------------------------------------------|------|--|
| 1-1   | M68HC11K4 Family Block Diagram                     | 29   |  |
| 1-2   | M68HC11KS Family Block Diagram                     | 30   |  |
| 2-1   | Pin Assignments for M68HC11K 84-Pin PLCC/J-Cerquad |      |  |
| 2-2   | Pin Assignments for M6811K 80-Pin QFP              |      |  |
| 2-3   | Pin Assignments for M6811KS 68-Pin PLCC/J-Cerquad  |      |  |
| 2-4   | Pin Assignments for M6811KS 80-Pin LQFP            |      |  |
| 2-5   | External Reset Circuit                             |      |  |
| 2-6   | Common Crystal Connections                         |      |  |
| 2-7   | System Configuration Options 2 (OPT2)              |      |  |
| 2-8   | LIR Timing                                         |      |  |
| 2-9   | MODB/V <sub>STBY</sub> Connection                  | 41   |  |
| 3-1   | Programming Model                                  | 46   |  |
| 3-2   | Stacking Operations                                | 49   |  |
| 4-1   | Register and Control Bit Assignments               | 65   |  |
| 4-2   | Highest Priority I-Bit Interrupt                   |      |  |
|       | and Miscellaneous Register (HPRIO)                 | 80   |  |
| 4-3   | M68HC11K4 Family Memory Map                        | 82   |  |
| 4-4   | M68HC11KS2 Family Memory Map                       | 83   |  |
| 4-5   | RAM and I/O Mapping Register (INIT)                | 84   |  |
| 4-6   | System Configuration Register (CONFIG)             |      |  |
| 4-7   | EEPROM Mapping Register (INIT2)                    | 89   |  |
| 4-8   | EPROM Programming Control Register (EPROG)         | 91   |  |
| 4-9   | EEPROM Programming Control Register (PPROG)        | 94   |  |
| 4-10  | Block Protect Register (BPROT)                     | 96   |  |
| 4-11  | System Configuration Options Register (OPTION)     | 97   |  |
| 4-12  | Block Protect Register (BPROT)                     | 100  |  |
|       |                                                    |      |  |

# List of Figures

| Figur | e Title                                         | Page |  |
|-------|-------------------------------------------------|------|--|
| 4-13  | System Configuration Register (CONFIG)          | 101  |  |
| 4-14  | System Configuration Register (CONFIG)          | 102  |  |
| 4-15  | System Configuration Options 2 Register (OPT2)  | 103  |  |
| 5-1   | System Configuration Register (CONFIG)          |      |  |
| 5-2   | System Configuration Options Register (OPTION)  |      |  |
| 5-3   | Arm/Reset COP Timer Circuitry Register (COPRST) |      |  |
| 5-4   | System Configuration Options Register (OPTION)  |      |  |
| 5-5   | System Configuration Options Register 2 (OPT2)  |      |  |
| 5-6   | System Configuration Options Register (OPTION)  | 121  |  |
| 5-7   | Highest Priority I-Bit Interrupt                |      |  |
|       | and Miscellaneous Register (HPRIO)              |      |  |
| 5-8   | Processing Flow Out of Reset                    |      |  |
| 5-9   | Interrupt Priority Resolution                   |      |  |
| 5-10  | Interrupt Priority Resolution Within SCI System |      |  |
| 5-11  | System Configuration Options Register (OPTION)  |      |  |
| 5-12  | System Configuration Options 3 Register (OPT3)  |      |  |
| 5-13  | Slow Mode Example for M68HC(7)11KS Devices Only | 133  |  |
| 6-1   | Port A Data Register (PORTA)                    | 138  |  |
| 6-2   | Port A Data Direction Register (DDRA)           | 138  |  |
| 6-3   | Port B Data Register (PORTB)                    | 139  |  |
| 6-4   | Port B Data Direction Register (DDRB)           | 139  |  |
| 6-5   | Port C Data Register (PORTC)                    | 140  |  |
| 6-6   | Port C Data Direction Register (DDRC)           | 141  |  |
| 6-7   | System Configuration Options 2 Register (OPT2)  |      |  |
| 6-8   | Port D Data Register (PORTD)                    |      |  |
| 6-9   | Port D Data Direction Register (DDRD)           |      |  |
| 6-10  | Port E Data Register (PORTE)                    |      |  |
| 6-11  | Port F Data Register (PORTF)                    |      |  |
| 6-12  | Port F Data Direction Register (DDRF)           |      |  |
| 6-13  | Port G Data Register (PORTG)                    |      |  |
| 6-14  | Port G Data Direction Register (DDRG)           |      |  |
| 6-15  | Port H Data Register (PORTH)                    |      |  |
| 6-16  | Port H Data Direction Register (DDRH)           | 146  |  |

| Figur | e Title                                        | Page |  |
|-------|------------------------------------------------|------|--|
| 6-17  | Port Pullup Assignment Register (PPAR)         | 147  |  |
| 6-18  | System Configuration Register (CONFIG)         | 147  |  |
| 7-1   | SCI Data Formats                               |      |  |
| 7-2   | SCI Transmitter Block Diagram                  |      |  |
| 7-3   | SCI Receiver Block Diagram                     |      |  |
| 7-4   | SCI Baud Generator Circuit Diagram             |      |  |
| 7-5   | SCI Baud Rate Control Register High (SCBDH)    |      |  |
| 7-6   | SCI Baud Rate Control Register Low (SCBDL)     |      |  |
| 7-7   | SCI Control Register 1 (SCCR1)                 |      |  |
| 7-8   | SCI Control Register 2 (SCCR2)                 |      |  |
| 7-9   | SCI Status Register 1 (SCSR1)                  |      |  |
| 7-10  | SCI Status Register 2 (SCSR2)                  |      |  |
| 7-11  | SCI Data Register (SCDR)                       | 165  |  |
| 8-1   | SPI Block Diagram                              |      |  |
| 8-2   | Data Clock Timing Diagram                      |      |  |
| 8-3   | Serial Peripheral Control Register (SPCR)      |      |  |
| 8-4   | Serial Peripheral Status Register (SPSR)       |      |  |
| 8-5   | Serial Peripheral Data Register (SPDR)         |      |  |
| 8-6   | Port D Data Direction Register (DDRD)          |      |  |
| 8-7   | System Configuration Options 2 Register (OPT2) | 179  |  |
| 9-1   | Timer Clock Divider Chains                     |      |  |
| 9-2   | Capture/Compare Block Diagram                  |      |  |
| 9-3   | Timer Counter Register (TCNT)                  |      |  |
| 9-4   | Timer Interrupt Flag 2 (TFLG2)                 |      |  |
| 9-5   | Timer Interrupt Mask 2 (TMSK2)                 |      |  |
| 9-6   | Port A Data Direction Register (DDRA)          |      |  |
| 9-7   | Pulse Accumulator Control Register (PACTL)     |      |  |
| 9-8   | Timer Input Capture Registers (TIC1–TIC3)      | 192  |  |
| 9-9   | Timer Input Capture 4/Output                   |      |  |
|       | Compare 5 Register (TI4/O5)                    |      |  |
| 9-10  | Timer Interrupt Flag 1 Register (TFLG1)        |      |  |
| 9-11  | Timer Interrupt Mask 1 Register (TMSK1)        |      |  |
| 9-12  | Timer Control 2 Register (TCTL2)               | 195  |  |

**Technical Data** 

| Figure | e Title                                           | Page |
|--------|---------------------------------------------------|------|
| 9-13   | Timer Output Compare                              |      |
|        | Registers (TOC1–TOC4)                             | 197  |
| 9-14   | Timer Input Capture 4/Output                      |      |
|        | Compare 5 Register (TI4/O5)                       | 199  |
| 9-15   | Timer Interrupt Flag 1 Register (TFLG1)           | 199  |
| 9-16   | Timer Interrupt Mask 1 Register (TMSK1)           | 200  |
| 9-17   | Timer Control Register 1 (TCTL1)                  | 200  |
| 9-18   | Timer Compare Force Register (CFORC)              | 201  |
| 9-19   | Output Compare 1 Mask Register (OC1M)             | 202  |
| 9-20   | Output Compare 1 Data Register (OC1D)             | 202  |
| 9-21   | Pulse Accumulator                                 | 204  |
| 9-22   | Port A Data Direction Register (DDRA)             | 205  |
| 9-23   | Pulse Accumulator Control Register (PACTL)        | 205  |
| 9-24   | Timer Interrupt Flag 2 (TFLG2)                    | 206  |
| 9-25   | Timer Interrupt Mask 2 (TMSK2)                    | 207  |
| 9-26   | Pulse Accumulator Count Register (PACNT)          | 208  |
| 9-27   | Timer Interrupt Flag 2 Register (TFLG2)           | 209  |
| 9-28   | Timer Interrupt Mask 2 Register (TMSK2)           | 209  |
| 9-29   | Pulse Accumulator Control Register (PACTL)        | 210  |
| 9-30   | Pulse-Width Modulation Timer Block Diagram        | 212  |
| 9-31   | Pulse-Width Modulation Timer Clock Select (PWCLK) | 213  |
| 9-32   | Pulse-Width Modulation Timer                      |      |
|        | Polarity Register (PWPOL)                         | 215  |
| 9-33   | Pulse-Width Modulation Timer                      |      |
|        | Prescaler Register (PWSCAL)                       | 215  |
| 9-34   | Pulse-Width Modulation Timer                      |      |
|        | Enable Register (PWEN)                            | 216  |
| 9-35   | Pulse-Width Modulation Timer                      |      |
|        | Counters 1 to 4 (PWCNT1 to PWCNT4)                | 217  |
| 9-36   | Pulse-Width Modulation Timer                      |      |
|        | Periods 1 to 4 (PWPER1 to PWPER4)                 | 218  |
| 9-37   | Pulse-Width Modulation Timer                      |      |
|        | Duty Cycle 1 to 4 (PWDTY1 to PWDTY4)              | 219  |
| 10.4   | A/D Convertor Block Diagram                       | 222  |
|        | A/D Conversion Sequence                           |      |
| 10-2   | A/D Conversion Sequence                           | 224  |
|        |                                                   |      |

M68HC11K Family

Technical Data

21

| Figure | e Title                                                 | Page |
|--------|---------------------------------------------------------|------|
| 10-3   | System Configuration Options Register (OPTION)          |      |
| 10-4   | Analog-to-Digital Control/Status Register (ADCTL)       |      |
| 10-5   | Analog-to-Digital Result Registers (ADR1–ADR4))         |      |
| 10-6   | Electrical Model of an A/D Input Pin (Sample Mode)      | 230  |
| 11-1   | Port G Assignment Register (PGAR)                       |      |
| 11-2   | Memory Mapping Size Register (MMSIZ)                    |      |
| 11-3   | Memory Mapping Window Base Register (MMWBR)             | 236  |
| 11-4   | Memory Mapping Window Control                           | 007  |
| 44.5   | Registers (MM1CR and MM2CR)                             |      |
| 11-5   | Chip-Select Control Register (CSCTL)                    |      |
| 11-6   | Chip-Select Control Register (CSCTL)                    |      |
| 11-7   | Memory Mapping Size Register (MMSIZ)                    | 243  |
| 11-8   | General-Purpose Chip Select 1 Address Register (GPCS1A) | 242  |
| 11.0   | General-Purpose Chip Select 1                           | 243  |
| 11-9   | Control Register (GPCS1C)                               | 244  |
| 11-10  | General-Purpose Chip Select 2                           | 244  |
| 11-10  | Address Register (GPCS2A)                               | 245  |
| 11-11  | General-Purpose Chip Select 2                           | 240  |
|        | Control Register (GPCS2C)                               | 245  |
| 11-12  | General-Purpose Chip Select 1                           | 10   |
|        | Control Register (GPCS1C)                               | 247  |
| 11-13  | General-Purpose Chip Select 2                           |      |
|        | Control Register (GPCS2C)                               | 247  |
| 11-14  | Chip Select Clock Stretch Register (CSCSTR)             |      |
|        | Memory Expansion Example 1 — Memory Map                 |      |
|        | for a Single 8-Kbyte Window with Eight Banks            |      |
|        | of External Memory                                      | 250  |
| 11-16  | Memory Expansion Example 2 Memory Map                   |      |
|        | for One 8-Kbyte Window with Eight Banks                 |      |
|        | and One 16-Kbyte Window with 16 Banks                   |      |
|        | of External Memory                                      | 251  |
| 12-1   | Test Methods                                            | 258  |
| 12-2   | Timer Inputs                                            |      |
|        | •                                                       |      |

M68HC11K Family

MOTOROLA

# List of Figures

| Figure | e Title                                    | Page |
|--------|--------------------------------------------|------|
| 12-3   | POR External Reset Timing Diagram          | 260  |
| 12-4   | STOP Recovery Timing Diagram               | 261  |
| 12-5   | WAIT Recovery from Inerrupt Timing Diagram | 262  |
| 12-6   | Interrupt Timing Diagram                   | 262  |
| 12-7   | Port Read Timing Diagram                   | 264  |
| 12-8   | Port Write Timing Diagram                  | 264  |
| 12-9   | Expansion Bus Timing                       | 268  |
| 12-10  | SPI Timing Diagram                         | 270  |

## **List of Tables**

| Table | Title                                  | Page |  |
|-------|----------------------------------------|------|--|
| 1-1   | M68HC11K Family Devices                | 26   |  |
| 2-1   | I/O Ports and Peripheral Functions     | 42   |  |
| 2-2   | Port Signal Summary                    | 43   |  |
| 3-1   | Instruction Set                        | 56   |  |
| 4-1   | Registers with Limited Write Access    | 76   |  |
| 4-2   | Synchronization Character Selection    | 79   |  |
| 4-3   | Hardware Mode Select Summary           | 80   |  |
| 4-4   | Default Memory Map Addresses           | 83   |  |
| 4-5   | RAM Mapping                            | 85   |  |
| 4-6   | Register Mapping                       | 86   |  |
| 4-7   | EEPROM Map                             | 89   |  |
| 4-8   | Scope of EEPROM Erase                  | 95   |  |
| 4-9   | EEPROM Block Protect                   | 97   |  |
| 4-10  | XOUT Frequencies                       | 103  |  |
| 5-1   | Reset Vectors                          | 106  |  |
| 5-2   | COP Timeout                            | 109  |  |
| 5-3   | IRVNE Operation After Reset            | 113  |  |
| 5-4   | XOUT Clock Divide Select               |      |  |
| 5-5   | Interrupt and Reset Vector Assignments | 118  |  |
| 5-6   | Stacking Order on Entry to Interrupts  | 119  |  |
| 5-7   | Highest Priority Interrupt Selection   |      |  |
| 6-1   | Port Configuration                     | 136  |  |

## List of Tables

| Table | e Title                                    |     |
|-------|--------------------------------------------|-----|
| 7-1   | SCI Receiver Flags                         | 153 |
| 7-2   | SCI+ Baud Rates                            | 159 |
| 8-1   | SPI+ Baud Rates                            | 175 |
| 9-1   | Main Timer Rates                           | 184 |
| 9-2   | Timer Prescale                             | 190 |
| 9-3   | Input Capture Edge Selection               | 195 |
| 9-4   | Timer Output Compare Actions               | 201 |
| 9-5   | Pulse Accumulator Timing                   | 203 |
| 9-6   | Pulse Accumulator Edge Control             |     |
| 9-7   | Real-Time Interrupt Rate versus RTR[1:0]   |     |
| 9-8   | Clock A Prescaler                          |     |
| 9-9   | Clock B Prescaler                          | 214 |
| 10-1  | A/D Converter Channel Selection            | 225 |
| 11-1  | CPU Address and Address Expansion Signals  | 233 |
| 11-2  | Window Size Select                         |     |
| 11-3  | Memory Expansion Window Base Address       |     |
| 11-4  | Chip Select Control Parameter Summary      |     |
| 11-5  | Program Chip Select Size                   |     |
| 11-6  | General-Purpose Chip Select 1 Size Control |     |
| 11-7  | General-Purpose Chip Select 2 Size Control |     |
| 11-8  | One Chip Select Driving Another            |     |
| 11-9  | CSCSTR Bits Versus Clock Cycles            | 249 |
| 14-1  | M68HC11K Family Devices                    | 281 |

### **Section 1. General Description**

#### 1.1 Contents

| 1.2 | Introduction            | 25 |
|-----|-------------------------|----|
| 1.3 | M68HC11K Family Members | 26 |
| 1.4 | Features                | 27 |
| 1.5 | Structure               | 29 |

#### 1.2 Introduction

The M68HC11K Family of high-performance microcontroller units (MCUs) offers a non-multiplexed expanded bus, high speed and low power consumption. The fully static design allows operation at frequencies from dc to 4 MHz.

This manual contains information concerning standard and custom-ROM (read-only memory) devices. Standard devices include those replacing the ROM with:

- Disabled ROM
- Disabled EEPROM (electrically erasable, programmable read-only memory)
- EPROM (erasable, programmable read-only memory)
- OTPROM (one-time programmable read-only memory)

Custom-ROM devices have a ROM array that is programmed at the factory to customer specifications.

#### 1.3 M68HC11K Family Members

M68HC11K Family devices feature up to 62 input/output (I/O) lines distributed among eight ports, A through H. The KS Family removes seven pins from port G and four pins from port H for a total of 51 I/O lines. The KSx versions feature a slow mode for the clocks to allow power conservation. **Table 1-1** lists devices currently available in the K Family along with their distinguishing features.

**NOTE:** The KA2 and KA4 devices have been replaced by the pin-for-pin compatible KS2.

| <b>Table 1-1.</b> | M68HC11K | Family | Devices |
|-------------------|----------|--------|---------|
|-------------------|----------|--------|---------|

| Device<br>Number                                | ROM<br>or <i>EPROM</i><br>(Bytes) <sup>(1)</sup> | RAM<br>(Bytes)    | EEPROM<br>(Bytes) | I/O<br>(Pins)  | Chip<br>Select    | Slow<br>Mode   | Packages                                                     |
|-------------------------------------------------|--------------------------------------------------|-------------------|-------------------|----------------|-------------------|----------------|--------------------------------------------------------------|
| MC68HC(L)11K0<br>MC68HC(L)11K1<br>MC68HC(L)11K4 | 0<br>0<br>24 K                                   | 768<br>768<br>768 | 0<br>640<br>640   | 37<br>37<br>62 | Yes<br>Yes<br>Yes | No<br>No<br>No | 84-pin PLCC <sup>(2)</sup><br>80-pin QFP <sup>(3)</sup>      |
| MC68HC711K4                                     | 24 K                                             | 768               | 640               | 62             | Yes               | No             | 84-pin J-cerquad <sup>(4)</sup><br>84-pin PLCC<br>80-pin QFP |
| MC68HC11KS2                                     | 32 K                                             | 1 K               | 640               | 51             | No                | Yes            | 68-pin PLCC and 80-pin LQFP <sup>(5)</sup>                   |
| MC68HC711KS2                                    | 32 K                                             | 1 K               | 640               | 51             | No                | Yes            | 68-pin J-cerquad, 68-pin PLCC, and 80-pin LQFP               |

<sup>1.</sup> Where applicable, EPROM bytes appear in italics.

<sup>2.</sup> PLCC = Plastic leaded chip carrier

<sup>3.</sup> QFP = Quad flat pack

<sup>4.</sup> J-cerquad = Ceramic windowed version of PLCC

<sup>5.</sup> LQFP = Low-profile quad flat pack

#### 1.4 Features

#### M68HC11K Family features include:

- 8-bit opcodes and data
- 16-bit addressing
- Two 8-bit accumulators, which can be concatenated to form one 16-bit accumulator
- On-board memory:
  - 24 Kbytes or 32 Kbytes of ROM, EPROM, or OTPROM
  - 768 bytes or 1 Kbyte of static RAM (random-access memory)
  - 640 bytes of EEPROM
  - 128-byte register block
- Dual-function I/O lines Any pins used for the microcontroller's peripheral functions can be configured as general-purpose I/O lines.
- Non-multiplexed address and data buses
- 68HC11K4 offers:
  - 1 Mbyte of address space, using on-chip memory mapping logic
  - Four programmable chip selects (expanded modes)
- 16-bit timer system:
  - Three input capture (IC) channels, record event timing by storing the value of the timing system's 16-bit free-running counter when an input signal transition occurs.
  - Four output compare (OC) channels, provide timed outputs by signaling when the free-running counter reaches a predetermined number.
  - One IC or OC channel (software selectable)
- 8-bit pulse accumulator
- Four 8-bit pulse-width modulation (PWM) outputs
- Enhanced asynchronous serial communications interface (SCI)

### **General Description**

- Enhanced synchronous serial peripheral interface (SPI)
- 8-channel, 8-bit, analog-to-digital (A/D) converter
- Computer operating properly (COP) watchdog system to guard against infinite loops and other system problems
- · Real-time interrupt timer
- Power-saving modes:
  - Slow mode reduces power consumption by slowing down internal operations.
  - Wait mode shuts down various system features selected by the user with power consumption typically dropping to 10–100 mW.
  - Stop mode also shuts down system clocks, typically reducing power consumption to about 1.5 mW.
- Package availability for ROM devices:
  - K versions:

84-pin plastic leaded chip carrier (PLCC) 80-pin quad flat pack (QFP)

- KS versions:

68-pin plastic leaded chip carrier (PLCC) 80-pin low-profile quad flat pack (LQFP)

- Package availability for EPROM devices:
  - K versions:

80-pin quad flat pack (QFP)

84-pin J-cerquad (ceramic windowed version of PLCC)

84-pin plastic leaded chip carrier (PLCC)

- KS versions:

68-pin J-cerquad (ceramic windowed version of PLCC)

80-pin low-profile quad flat pack (LQFP)

68-pin plastic leaded chip carrier (PLCC)

#### 1.5 Structure

**Figure 1-1** is a block diagram of the M68HC11K Family MCU. **Figure 1-2** is a block diagram of the M68HC11KS devices.



#### Notes:

- 1. XOUT pin omitted on 80-pin QFP
- 2. V<sub>PP</sub> applies only to EPROM devices.

Figure 1-1. M68HC11K4 Family Block Diagram



#### Notes:

- 1. The configuration shown in this diagram is the MC68HC11KS2.
- 2. V<sub>PP</sub> applies only to EPROM devices.

Figure 1-2. M68HC11KS Family Block Diagram

## **Section 2. Pin Description**

#### 2.1 Contents

| 2.2  | Introduction31                                                                                          |
|------|---------------------------------------------------------------------------------------------------------|
| 2.3  | Power Supply (V <sub>DD</sub> , V <sub>SS</sub> , AV <sub>DD</sub> , and AV <sub>SS</sub> )             |
| 2.4  | Reset (RESET)                                                                                           |
| 2.5  | Crystal Driver and External Clock Input (XTAL and EXTAL)                                                |
| 2.6  | XOUT38                                                                                                  |
| 2.7  | E-Clock Output (E)                                                                                      |
| 2.8  | Interrupt Request (IRQ) and Non-Maskable Interrupt (XIRQ)                                               |
| 2.9  | Mode Selection, Instruction Cycle Reference, and Standby Power (MODA/LIR and MODB/V <sub>STBY</sub> )39 |
| 2.10 | V <sub>RH</sub> and V <sub>RL</sub> 41                                                                  |
| 2.11 | Port Signals                                                                                            |

#### 2.2 Introduction

The M68HC11K Family is available in a variety of packages, as shown in **Table 1-1. M68HC11K Family Devices**. Most pins on this MCU serve two or more functions, as described in this section. Pin assignments for the various package types are shown in **Figure 2-1**, **Figure 2-2**, **Figure 2-3**, and **Figure 2-4**.



1. Pins 20, 22, and 25 are used only during factory testing and should not be connected to external circuitry. 2. V<sub>PP</sub> applies only to EPROM devices.

Figure 2-1. Pin Assignments for M68HC11K 84-Pin PLCC/J-Cerquad



<sup>\*</sup> V<sub>PP</sub> applies only to EPROM devices.

Figure 2-2. Pin Assignments for M6811K 80-Pin QFP



 $<sup>^{\</sup>ast}$   $V_{PP}$  applies only to EPROM devices.

Figure 2-3. Pin Assignments for M6811KS 68-Pin PLCC/J-Cerquad



<sup>\*</sup> V<sub>PP</sub> applies only to EPROM devices.

Figure 2-4. Pin Assignments for M6811KS 80-Pin LQFP

### 2.3 Power Supply (V<sub>DD</sub>, V<sub>SS</sub>, AV<sub>DD</sub>, and AV<sub>SS</sub>)

The MCU operates from a single 5-volt (nominal) power supply.  $V_{DD}$  is the positive power input and  $V_{SS}$  is ground. There are three  $V_{DD}/V_{SS}$  pairs of pins on the K series devices and two sets on the KS devices. All devices contain a separate pair of power inputs,  $AV_{DD}$  and  $AV_{SS}$ , for the analog-to-digital (A/D) converter, so that the A/D circuitry can be bypassed independently.

Very fast signal transitions occur on the MCU pins. The short rise and fall times place high, short duration current demands on the power supply. To prevent noise problems, provide good power supply bypassing at the MCU. Also, use bypass capacitors that have good high-frequency characteristics and situate them as close to the MCU as possible. Bypass requirements vary, depending on how heavily the MCU pins are loaded.

### 2.4 Reset (RESET)

This active-low, bidirectional control signal acts as an input to initialize the MCU to a known start-up state. It also serves 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.

The CPU distinguishes between internal and external reset conditions by counting the number of E-clock cycles that occur between the start of reset and the presence of a logic 1 voltage level on the reset pin. Less than two cycles indicates an internal reset; greater than two, an external reset. To prevent the device from misinterpreting the kind of reset that occurs, do not connect an external resistor-capacitor (RC) power-up delay circuit directly to the reset pin.



Figure 2-5. External Reset Circuit

It is important to protect the MCU against corruption of RAM and EEPROM during power transitions. This can be done with a low-voltage interrupt (LVI) circuit which holds the RESET pin low when V<sub>DD</sub> drops below the minimum operating level. Figure 2-5 shows a suggested reset circuit that incorporates two LVI devices and an external switch.

### 2.5 Crystal Driver and External Clock Input (XTAL and 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 is four times higher than the desired E-clock rate.

When an external CMOS-compatible clock input is connected to the EXTAL pin, the XTAL pin must be left unterminated.

**CAUTION:** In all cases, use caution around the oscillator pins.

Load capacitances shown in **Figure 2-6** are specified by the crystal manufacturer and should include all stray layout capacitances.



\* This value includes all stray capacitances.

Figure 2-6. Common Crystal Connections

### **2.6 XOUT**

The XOUT pin provides a buffered clock signal if enabled to synchronize external devices with the MCU. See **4.9 XOUT Pin Control**.

**NOTE:** This signal is not present on the 80-pin M68HC(7)11K device QFP package.

### 2.7 E-Clock Output (E)

The internally generated instruction cycle clock, or E clock, is available on the E pin as a timing reference. Its frequency is one fourth the input frequency at the XTAL and EXTAL pins. The E clock is low during the address portion of a bus cycle and high during the data access portion of the bus cycle. All clocks, including the E clock, are halted when the MCU is in stop mode. The E-pin driver can be turned off in single-chip modes to reduce radio frequency interference (RFI) and current consumption.

# 2.8 Interrupt Request (IRQ) and Non-Maskable Interrupt (XIRQ)

The MCU provides two pins for applying asynchronous interrupt requests. Interrupts applied to the  $\overline{IRQ}$  pin can be masked by setting the I bit in the condition code register (CCR), which can be set or cleared by software at any time. Triggering is level sensitive by default, which is

required for wire-OR configuration. Software can change the triggering to edge sensitive.

XIRQ interrupts can be non-maskable after reset initialization. Out of reset, the X bit in the CCR is set, masking XIRQ interrupts. Once software clears the X bit, it cannot be reset, and the XIRQ interrupts become non-maskable. The XIRQ input is level sensitive only. XIRQ is often used as a power-loss detect interrupt.

Whenever  $\overline{IRQ}$  or  $\overline{XIRQ}$  is used with multiple interrupt sources, each source must drive the interrupt input with an open-drain type of driver to avoid contention between outputs. There should be a single pullup resistor near the MCU interrupt pin (typically 4.7 k $\Omega$ ). There must also be an interlock mechanism at each interrupt source which holds the interrupt line low until the MCU recognizes and acknowledges the interrupt request. If any interrupt sources are still pending after the MCU services a request, the interrupt line will remain low, interrupting the MCU again as soon as the I bit in the MCU is cleared (normally upon return from an interrupt). Interrupt mechanisms are explained further in Section 5. Resets and Interrupts.

On EPROM devices, the  $\overline{\text{XIRQ}}$  pin also functions as the high-voltage supply,  $V_{PP}$ , during EPROM or OTPROM programming.

**CAUTION:** 

Ensure that the voltage level at this pin is equal to V<sub>DD</sub> during normal operation to avoid programming accidents.

# 2.9 Mode Selection, Instruction Cycle Reference, and Standby Power (MODA/LIR and MODB/V<sub>STBY</sub>)

During reset, MODA and MODB select one of four operating modes:

- 1. Single-chip
- 2. Expanded
- 3. Bootstrap
- 4. Special test

For full descriptions of these modes, refer to **4.5 Operating Modes**.

In single-chip and bootstrap modes, the MODA pin typically is grounded and has no function after reset. In expanded and special test modes, MODA is normally connected to  $V_{DD}$  through a 4.7-k $\Omega$  pullup resistor and functions as the load instruction register (LIR) pin after reset. The open-drain, active-low LIR output drives low during the first E-clock cycle of each instruction (opcode fetch), providing a useful signal for system debugging.

LIR can be driven high for a portion of each instruction cycle by setting the LIRDV bit in the system configuration options 2 (OPT2) register (see Figure 2-7 and Figure 2-8). This feature can help detect consecutive instructions and prevent false triggering in high-speed applications.



Figure 2-7. System Configuration Options 2 (OPT2)

LIRDV —  $\overline{\text{LIR}}$  Driven Bit 0 =  $\overline{\text{LIR}}$  not driven high

 $1 = \overline{LIR}$  driven high for one quarter cycle to reduce transition time



Figure 2-8. LIR Timing

The MODB pin is grounded to select special modes, and has no function after reset. To select the normal operating modes (single-chip and expanded) the MODB pin is pulled to a logic high level. Connecting MODB to a voltage source other than  $V_{DD}$  enables it to function as a battery backup input,  $V_{STBY}$ . When  $V_{DD}$  drops more than one MOS threshold (about 0.7 volts) below the voltage at  $V_{STBY}$ , the MCU's RAM and part of the reset logic are powered from  $V_{STBY}$  rather than  $V_{DD}$ . Reset must be driven low before  $V_{DD}$  is removed and must remain low until  $V_{DD}$  has been restored to a valid level. The extra hardware required to utilize  $V_{STBY}$  may be justified in certain applications where a significant amount of external circuitry operates from  $V_{DD}$ . Figure 2-9 shows a suggested circuit employing the  $V_{STBY}$  pin.



Figure 2-9. MODB/V<sub>STBY</sub> Connection

### 2.10 $V_{RH}$ and $V_{RL}$

These pins provide the reference voltage for the analog-to-digital converter.

### 2.11 Port Signals

The K series contains 62 input/output lines arranged in eight ports, A through H; all ports are eight bits except port D, which is six bits. The KS series drops seven lines from port G and four from port H, for a total of

51 I/O lines. All ports are fully bidirectional except port E, which is input only.

Each port can serve as either general-purpose I/O or as part of the microcontroller's specialized functions, depending on the operating mode or peripheral functions selected. The functions of ports B, C, and F and port G bit 7 depend on the operating mode. They serve as general-purpose I/O lines in single-chip and bootstrap modes and provide the address and data buses in expanded and special test modes. The other ports serve as general-purpose I/O out of reset; writes to control registers enable their special functions. Section 6. Parallel Input/Output describes general-purpose I/O operation in detail. Table 2-1 summarizes the ports and references for peripheral functions. Table 2-2 summarizes the port signals.

Table 2-1. I/O Ports and Peripheral Functions

| I/O Port                                      | Special Function(s)                                                     | Enabled by                                                    | Refer to                                                                                                |
|-----------------------------------------------|-------------------------------------------------------------------------|---------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|
| Port A                                        | Timer and pulse accumulator                                             | Control registers                                             | Section 9. Timing System                                                                                |
| Port B                                        | High-order address bus                                                  | Expanded operating modes                                      | Section 4. Operating Modes and On-Chip Memory                                                           |
| Port C                                        | Data bus                                                                | Expanded operating modes                                      | Section 4. Operating Modes and On-Chip Memory                                                           |
| Port D                                        | Serial communication<br>interface and<br>Serial peripheral<br>interface | Control registers                                             | Section 7. Serial Communications Interface (SCI)<br>and<br>Section 8. Serial Peripheral Interface (SPI) |
| Port E                                        | A/D converter                                                           | Control registers                                             | Section 10. Analog-to-Digital (A/D) Converter                                                           |
| Port F                                        | Low-order address bus                                                   | Expanded operating modes                                      | Section 4. Operating Modes and On-Chip Memory                                                           |
| Port G<br>bit 7<br>bits 6–0 <sup>(1)</sup>    | R/W line<br>and expansion<br>address lines                              | Expanded operating modes and control registers <sup>(2)</sup> | Section 4. Operating Modes and On-Chip Memory and Section 11. Memory Expansion and Chip Selects         |
| Port H<br>bits 7–4 <sup>(1)</sup><br>bits 3–0 | Chip-select lines<br>and<br>pulse-width modulator                       | Control registers                                             | Section 9. Timing System<br>and<br>Section 11. Memory Expansion and Chip Selects                        |

<sup>1.</sup> Not available on KS devices

<sup>2.</sup> Control registers can enable these functions only in expanded operating modes.

**Table 2-2. Port Signal Summary** 

| Port/Bit | Single-Chip and<br>Bootstrap Modes | Expanded and<br>Special Test Modes |  |  |  |  |
|----------|------------------------------------|------------------------------------|--|--|--|--|
| PA0      | PA0                                | /IC3                               |  |  |  |  |
| PA1      | PA1                                | /IC2                               |  |  |  |  |
| PA2      | PA2                                | /IC1                               |  |  |  |  |
| PA3      | PA3/OC5/IC4                        | 1/and-or OC1                       |  |  |  |  |
| PA4      | PA4/OC4/a                          | and-or OC1                         |  |  |  |  |
| PA5      | PA5/OC3/a                          | and-or OC1                         |  |  |  |  |
| PA6      | PA6/OC2/a                          | and-or OC1                         |  |  |  |  |
| PA7      | PA7/PAI/a                          | nd-or OC1                          |  |  |  |  |
| PB[7:0]  | PB[7:0]                            | ADDR[15:8]                         |  |  |  |  |
| PC[7:0]  | PC[7:0]                            | DATA[7:0]                          |  |  |  |  |
| PD0      | PD0                                | /RxD                               |  |  |  |  |
| PD1      | PD1.                               | /TxD                               |  |  |  |  |
| PD2      | PD2/I                              | MISO                               |  |  |  |  |
| PD3      | PD3/I                              | MOSI                               |  |  |  |  |
| PD4      | PD4/                               | SCK                                |  |  |  |  |
| PD5      | PD5                                | 5/SS                               |  |  |  |  |
| PE[7:0]  | PE[7:0]/                           | /AN[7:0]                           |  |  |  |  |
| PF[7:0]  | PF[7:0]                            | ADDR[7:0]                          |  |  |  |  |
| PG0      | PG0                                | PG0/XA13                           |  |  |  |  |
| PG1      | PG1                                | PG1/XA14                           |  |  |  |  |
| PG2      | PG2                                | PG2/XA15                           |  |  |  |  |
| PG3      | PG3                                | PG3/XA16                           |  |  |  |  |
| PG4      | PG4                                | PG4/XA17                           |  |  |  |  |
| PG5      | PG5                                | PG5/XA18                           |  |  |  |  |
| PG6      | PG6                                | PG6                                |  |  |  |  |
| PG7      | PG7                                | PG7/R/W                            |  |  |  |  |
| PH0      | PH0/                               | PW1                                |  |  |  |  |
| PH1      | PH1/                               | PW2                                |  |  |  |  |
| PH2      | PH2/                               | PW3                                |  |  |  |  |
| PH3      | PH3/                               | PW4                                |  |  |  |  |
| PH4      | PH4                                | PH4/CSIO                           |  |  |  |  |
| PH5      | PH5                                | PH5/CSGP1                          |  |  |  |  |
| PH6      | PH6                                | PH6/CSGP2                          |  |  |  |  |
| PH7      | PH7                                | PH7/CSPROG                         |  |  |  |  |

# Pin Description

# **Section 3. Central Processor Unit (CPU)**

### 3.1 Contents

| 3.2                                                                                           | Introduction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|-----------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3.3<br>3.3.1<br>3.3.2<br>3.3.3<br>3.3.4<br>3.3.5<br>3.3.6<br>3.3.6<br>3.3.6<br>3.3.6<br>3.3.6 | CPU Registers       .46         Accumulators A, B, and D (ACCA, ACCB, and ACCD)       .47         Index Register X (IX)       .47         Index Register Y (IY)       .47         Stack Pointer (SP)       .48         Program Counter (PC)       .50         Condition Code Register (CCR)       .50         .1       Carry/Borrow (C)       .50         .2       Overflow (V)       .50         .3       Zero (Z)       .50         .4       Negative (N)       .51         .5       Interrupt Mask (I)       .51 |
| 3.3.6.<br>3.3.6.                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 3.3.6.                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 3.4                                                                                           | Data Types                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 3.5                                                                                           | Opcodes and Operands                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 3.6<br>3.6.1<br>3.6.2<br>3.6.3<br>3.6.4<br>3.6.5<br>3.6.6                                     | Addressing Modes       .53         Immediate       .54         Direct       .54         Extended       .54         Indexed       .54         Inherent       .55         Relative       .55                                                                                                                                                                                                                                                                                                                          |
| 3.7                                                                                           | Instruction Set                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |

### 3.2 Introduction

This section presents information on M68HC11 central processor unit (CPU) architecture, data types, addressing modes, the instruction set, and special operations, such as subroutine calls and interrupts.

The CPU employs memory-mapped input/output (I/O). There are no special instructions for I/O; all peripheral, I/O, and memory locations are simply addresses in the 64-Kbyte memory map. This architecture also enables access to operands from external memory locations with no execution time penalty.

### 3.3 CPU Registers

M68HC11 CPU registers are an integral part of the CPU and are not addressed as memory locations. The seven registers are shown in Figure 3-1.



Figure 3-1. Programming Model

### 3.3.1 Accumulators A, B, and D (ACCA, ACCB, and ACCD)

Accumulators A and B are general-purpose 8-bit registers that hold operands and results of arithmetic calculations or data manipulations. Some instructions treat these two accumulators as a single double-byte (16-bit) accumulator called accumulator D. Most operations can use either accumulator A or B, with these exceptions:

- The ABX and ABY instructions add the contents of 8-bit accumulator B to the contents of 16-bit register X or Y, but there are no equivalent instructions that use A instead of B.
- The TAP and TPA instructions transfer data from accumulator A to the condition code register or from the condition code register to accumulator A. However, there are no equivalent instructions that use B rather than A.
- The DAA instruction adjusts accumulator A after binary-coded decimal (BCD) arithmetic operations, but there is no equivalent BCD instruction to adjust accumulator B.
- The add, subtract, and compare instructions associated with both A and B (ABA, SBA, and CBA) only operate in one direction, making planning ahead important to ensure the correct operand is in the correct accumulator.

### 3.3.2 Index Register X (IX)

The IX register provides a 16-bit indexing value that can be added to the 8-bit offset provided in an instruction to create an effective address. The IX register can be used also as a counter or as a temporary storage register.

#### 3.3.3 Index Register Y (IY)

The IY register provides a 16-bit indexed mode function similar to that of the IX register. Instructions using the IY register require an extra byte of machine code and an extra cycle of execution time because of the way the opcode map is implemented.

### 3.3.4 Stack Pointer (SP)

The stack pointer holds the 16-bit address of the next free location in the M68HC11 CPU's automatic program stack. This stack is a data structure that grows downward from high memory to low memory. The stack can be located anywhere in the address space and can be any size up to the amount of memory available in the system. Most application programs initialize the SP at the beginning of an application program with a load stack (LDS) instruction. Thereafter, each time the CPU pushes a new byte onto the stack, it decrements the SP. To pull a byte from the stack, the CPU first increments the SP. Figure 3-2 is a summary of SP operations.

A jump-to-subroutine (JSR) or branch-to-subroutine (BSR) instruction pushes the address of the instruction immediately after the JSR or BSR onto the stack, least significant byte first. The last instruction of the subroutine is a return-from-subroutine (RTS), which pulls the previously stored return address from the stack and loads it into the program counter. Execution then continues at this recovered return address.

When the processor recognizes an interrupt, it finishes the current instruction, pushes the return address (the current value in the program counter) onto the stack, pushes all of the CPU registers onto the stack, and continues at the address specified by the vector for the interrupt. The interrupt service routine ends with a return-from-interrupt (RTI) instruction, which pulls the saved registers off the stack in reverse order. Program execution resumes at the return address with all register contents restored.

There are instructions that push and pull the A and B accumulators and the X and Y index registers to preserve program context. For example, push accumulator A onto the stack when entering a subroutine that uses accumulator A, and pull accumulator A off the stack just before leaving the subroutine, to ensure that the contents of that register will be the same after returning from the subroutine as it was before starting the subroutine.



Figure 3-2. Stacking Operations

### 3.3.5 Program Counter (PC)

The 16-bit program counter contains the address of the next instruction to be executed. Its initial value after reset is fetched from one of six possible vectors, depending on operating mode and the cause of reset, as described in **5.3 Sources of Resets**.

### 3.3.6 Condition Code Register (CCR)

This 8-bit register contains:

- Five condition code indicators (C, V, Z, N, and H)
- Two interrupt masking bits (IRQ and XIRQ)
- A stop disable bit (S)

Most instructions update condition codes automatically, as described in the following paragraphs. Certain instructions, such as pushes, pulls, add B to X (ABX), add B to Y (ABY), and transfer/exchange instructions do not affect the condition codes. **Table 3-1** shows which condition codes are affected by each instruction.

### 3.3.6.1 Carry/Borrow (C)

The C bit is set if the CPU performs a carry or borrow during an arithmetic operation. This bit also acts as an error flag for multiply and divide operations. Shift and rotate instructions operate with and through the carry bit to facilitate multiple-word shift operations.

#### 3.3.6.2 Overflow (V)

The overflow bit is set if an operation results in a two's complement overflow of the 8-bit signed range –128 to +127. Otherwise, the V bit is cleared.

#### 3.3.6.3 Zero (Z)

The Z bit is set if the result of an arithmetic, logic, or data manipulation operation is 0. Otherwise, the Z bit is cleared. Compare instructions do

an internal implied subtraction and the condition codes, including Z, reflect the results of that subtraction. A few operations (INX, DEX, INY, and DEY) affect the Z bit and no other condition flags.

### 3.3.6.4 Negative (N)

The N bit is set if the result of an arithmetic, logic, or data manipulation operation is negative, meaning that the most significant bit (MSB) of the result is a 1. Otherwise, the N bit is cleared. To determine quickly if the MSB of a particular byte is set, load it into an accumulator and then check the status of the N bit.

### 3.3.6.5 Interrupt Mask (I)

When the interrupt mask bit is set, it disables all maskable interrupt requests (IRQs). The CPU continues to operate uninterrupted while interrupts remain pending until the I bit is cleared. Every reset sets the I bit by default and only a software instruction can clear it. When the processor recognizes an interrupt, it stacks the registers, sets the I bit, and then fetches the interrupt vector. The final instruction of an interrupt service routine is usually a return from interrupt (RTI), which restores the registers to the values that were present before the interrupt occurred and clears the I bit.

#### NOTE:

Although the I bit can be cleared earlier in the interrupt service routine, avoid nesting interrupts in this way without a clear understanding of latency and of the arbitration mechanism.

Refer to **Section 5. Resets and Interrupts**.

### 3.3.6.6 Half Carry (H)

The H bit is set 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. Half carry is used during binary-coded decimal (BCD) operations.

### 3.3.6.7 Non-Maskable Interrupt (X)

Setting the XIRQ mask (X) bit disables non-maskable interrupts from the XIRQ pin. Every reset sets the X bit by default and only a software instruction can clear it. When the processor recognizes a non-maskable interrupt, it stacks the registers, sets the X and I bits, and then fetches the interrupt vector. An interrupt service routine usually ends with a return from interrupt (RTI), which restores the registers to the values that were present before the interrupt occurred and clears the X bit. Only hardware or an acknowledge can set the X bit. Only software can clear the X bit (for example, the TAP instruction which transfers data from accumulator A to the condition code register). There is no hardware action for clearing X.

### 3.3.6.8 Stop Disable (S)

Setting the STOP disable (S) bit prevents the STOP instruction from putting the M68HC11 into a low-power stop condition. If the S bit is set, the CPU treats a STOP instruction as if it were a no-operation (NOP) instruction and continues to the next instruction.

**NOTE:** S is set by reset and STOP is disabled by default.

The STOP instruction can be cleared by using the TAP instruction which transfers data from accumulator A to the condition code register.

### 3.4 Data Types

The MC68HC11 CPU supports these data types:

- Bit data
- 8-bit and 16-bit signed and unsigned integers
- 16-bit unsigned fractions
- 16-bit addresses

A byte is eight bits wide and can be accessed at any byte location. A word is composed of two consecutive bytes with the most significant byte at the lower value address. Because the M68HC11 is an 8-bit CPU,

there are no special requirements for alignment of instructions or operands.

### 3.5 Opcodes and Operands

The M68HC11 Family of microcontrollers uses 8-bit opcodes. Every instruction requires a unique opcode for each of its addressing modes. The resulting number of opcodes exceeds the 256 available in an 8-bit binary number. A 4-page opcode map has been implemented to accommodate the extra instructions. An additional byte, called a prebyte, directs the processor from page 0 of the opcode map to one of the other three pages. As its name implies, the additional byte precedes the opcode.

A complete instruction consists of a prebyte, if any, an opcode, and zero to three operands. The operands contain information the CPU needs for executing the instruction. Complete instructions can be from one to five bytes long.

### 3.6 Addressing Modes

Six addressing modes can be used to access memory:

- 1. Immediate
- 2. Direct
- 3. Extended
- 4. Indexed
- 5. Inherent
- Relative

All modes except inherent mode use an effective address. The effective address is the memory address where the argument is fetched or stored or the address from which execution is to proceed. The effective address can be specified within an instruction or it can be calculated.

#### 3.6.1 Immediate

In the immediate addressing mode, the byte(s) immediately following the opcode contain the arguments. The number of bytes following the opcode matches the size of the register or memory location being used. Immediate instructions can be two, three, or (if a prebyte is required) four bytes.

#### **3.6.2 Direct**

In the direct addressing mode, the user specifies only the low-order byte of the effective address in a single byte following the opcode. The processor assumes the high-order byte of the address to be \$00. Thus, the CPU accesses addresses \$00–\$FF directly, using 2-byte instructions. This reduces execution time by eliminating the additional memory access required for the high-order address byte. Most applications reserve this 256-byte area for frequently referenced data, but various combinations of internal registers, RAM, or external memory can occupy these addresses.

#### 3.6.3 Extended

In the extended addressing mode, the two bytes following the opcode byte contain the effective address of the argument. For this reason, instructions are three bytes, or they are four bytes if a prebyte is required.

#### 3.6.4 Indexed

In the indexed addressing mode, the CPU computes the effective address of the argument by adding an 8-bit unsigned offset to the value contained in an index register (IX or IY). Any memory location in the 64-Kbyte address space can be accessed with this mode. The instructions are from two to five bytes.

#### 3.6.5 Inherent

In the inherent addressing mode, the opcode contains all required information. The operands (if any) are registers, so no memory access is required. This mode includes:

- Control instructions with no arguments
- Operations that only involve the index registers or accumulators

These instructions are one or two bytes.

#### 3.6.6 Relative

Only branch instructions use the relative addressing mode. If the branch condition is true, the CPU adds the 8-bit signed offset following the opcode to the contents of the program counter to form the effective branch address. Otherwise, control proceeds to the next instruction. These are usually 2-byte instructions.

### 3.7 Instruction Set

**Table 3-1** presents a detailed listing of all the M68HC11 instructions in all possible addressing modes.

Table 3-1. Instruction Set (Sheet 1 of 7)

| Mnemonic            | Operation                   | Description                               | A                | ddressing                           |    | Ir                         | struction                        |                       |   |   | Co | onditio | n Co | des |   |   |
|---------------------|-----------------------------|-------------------------------------------|------------------|-------------------------------------|----|----------------------------|----------------------------------|-----------------------|---|---|----|---------|------|-----|---|---|
| WITEHIOHIC          | Operation                   | Description                               |                  | Mode                                | Op | ocode                      | Operand                          | Cycles                | S | Х | Н  | ı       | N    | Z   | ٧ | С |
| ABA                 | Add<br>Accumulators         | $A + B \Rightarrow A$                     |                  | INH                                 |    | 1B                         | _                                | 2                     |   | _ | Δ  | _       | Δ    | Δ   | Δ | Δ |
| ABX                 | Add B to X                  | IX + (00 : B) ⇒ IX                        |                  | INH                                 |    | 3A                         | _                                | 3                     | _ | _ |    |         | _    | _   |   |   |
| ABY                 | Add B to Y                  | IY + (00 : B) ⇒ IY                        |                  | INH                                 | 18 | 3A                         | _                                | 4                     | _ | _ |    |         | _    | _   | _ | _ |
| ADCA (opr)          | Add with Carry              | $A + M + C \Rightarrow A$                 | Α                | IMM                                 | +  | 89                         | ii                               | 2                     |   |   | Δ  |         | Δ    | Δ   | Δ | Δ |
|                     | to A                        | 7. m · · · · · · · ·                      | A<br>A<br>A      | DIR<br>EXT<br>IND,X<br>IND,Y        | 18 | 99<br>B9<br>A9<br>A9       | dd<br>hh II<br>ff                | 3<br>4<br>4<br>5      |   |   |    |         |      |     |   |   |
| ADCB (opr)          | Add with Carry<br>to B      | $B + M + C \Rightarrow B$                 | B<br>B<br>B<br>B | IMM<br>DIR<br>EXT<br>IND,X<br>IND,Y | 18 | C9<br>D9<br>F9<br>E9       | ii<br>dd<br>hh II<br>ff          | 2<br>3<br>4<br>4<br>5 |   | _ | Δ  | _       | Δ    | Δ   | Δ | Δ |
| ADDA (opr)          | Add Memory to<br>A          | $A + M \Rightarrow A$                     | A<br>A<br>A<br>A | IMM<br>DIR<br>EXT<br>IND,X<br>IND,Y | 18 | 8B<br>9B<br>BB<br>AB<br>AB | ii<br>dd<br>hh II<br>ff          | 2<br>3<br>4<br>4<br>5 |   | _ | Δ  | _       | Δ    | Δ   | Δ | Δ |
| ADDB (opr)          | Add Memory to<br>B          | $B + M \Rightarrow B$                     | B<br>B<br>B<br>B | IMM<br>DIR<br>EXT<br>IND,X<br>IND,Y | 18 | CB<br>DB<br>FB<br>EB       | ii<br>dd<br>hh II<br>ff          | 2<br>3<br>4<br>4<br>5 |   | _ | Δ  | _       | Δ    | Δ   | Δ | Δ |
| ADDD (opr)          | Add 16-Bit to D             | $D + (M : M + 1) \Rightarrow D$           |                  | IMM<br>DIR<br>EXT<br>IND,X<br>IND,Y | 18 | C3<br>D3<br>F3<br>E3<br>E3 | jj kk<br>dd<br>hh II<br>ff<br>ff | 4<br>5<br>6<br>6<br>7 |   | _ | _  | _       | Δ    | Δ   | Δ | Δ |
| ANDA (opr)          | AND A with<br>Memory        | $A \bullet M \Rightarrow A$               | A<br>A<br>A<br>A | IMM<br>DIR<br>EXT<br>IND,X<br>IND,Y | 18 | 84<br>94<br>B4<br>A4<br>A4 | ii<br>dd<br>hh II<br>ff          | 2<br>3<br>4<br>4<br>5 |   | _ | _  | _       | Δ    | Δ   | 0 | _ |
| ANDB (opr)          | AND B with<br>Memory        | $B \bullet M \Rightarrow B$               | B<br>B<br>B<br>B | IMM<br>DIR<br>EXT<br>IND,X<br>IND,Y | 18 | C4<br>D4<br>F4<br>E4       | ii<br>dd<br>hh II<br>ff          | 2<br>3<br>4<br>4<br>5 |   | _ | _  | _       | Δ    | Δ   | 0 | _ |
| ASL (opr)           | Arithmetic Shift<br>Left    | ←<br>□←□□□□←0<br>C b7 b0                  |                  | EXT<br>IND,X<br>IND,Y               | 18 | 78<br>68<br>68             | hh II<br>ff<br>ff                | 6<br>6<br>7           | _ | _ | _  | _       | Δ    | Δ   | Δ | Δ |
| ASLA                | Arithmetic Shift<br>Left A  |                                           | A                | INH                                 |    | 48                         | _                                | 2                     | _ | _ | _  | _       | Δ    | Δ   | Δ | Δ |
| ASLB                | Arithmetic Shift<br>Left B  |                                           | В                | INH                                 |    | 58                         | _                                | 2                     | _ | _ | _  | _       | Δ    | Δ   | Δ | Δ |
| ASLD                | Arithmetic Shift<br>Left D  | ← ← ← 0<br>C b7 A b0 b7 B b0              |                  | INH                                 |    | 05                         | _                                | 3                     |   | _ | _  | _       | Δ    | Δ   | Δ | Δ |
| ASR                 | Arithmetic Shift<br>Right   | b7 b0 C                                   |                  | EXT<br>IND,X<br>IND,Y               | 18 | 77<br>67<br>67             | hh II<br>ff<br>ff                | 6<br>6<br>7           | _ | _ | _  | _       | Δ    | Δ   | Δ | Δ |
| ASRA                | Arithmetic Shift<br>Right A | →<br>b7 b0 C                              | A                | INH                                 |    | 47                         | _                                | 2                     | _ | _ | _  | _       | Δ    | Δ   | Δ | Δ |
| ASRB                | Arithmetic Shift<br>Right B | b7 b0 C                                   | В                | INH                                 |    | 57                         | _                                | 2                     | _ | _ | _  | _       | Δ    | Δ   | Δ | Δ |
| BCC (rel)           | Branch if Carry<br>Clear    | ? C = 0                                   |                  | REL                                 |    | 24                         | rr                               | 3                     | _ | _ | _  | _       | -    | _   | _ | _ |
| BCLR (opr)<br>(msk) | Clear Bit(s)                | $M \bullet (\overline{mm}) \Rightarrow M$ |                  | DIR<br>IND,X<br>IND,Y               | 18 | 15<br>1D<br>1D             | dd mm<br>ff mm<br>ff mm          | 6<br>7<br>8           | _ | _ | _  | _       | Δ    | Δ   | 0 | _ |
| BCS (rel)           | Branch if Carry<br>Set      | ? C = 1                                   |                  | REL                                 |    | 25                         | rr                               | 3                     |   | _ | _  | _       | _    |     | _ | _ |

Table 3-1. Instruction Set (Sheet 2 of 7)

| _          | F 1                         |                        | Addre | seina        |         | Inct  | ruction   |        |   |   | Co | nditio | n Cor | loc |   |   |
|------------|-----------------------------|------------------------|-------|--------------|---------|-------|-----------|--------|---|---|----|--------|-------|-----|---|---|
| Mnemonic   | Operation                   | Description            | Mod   | _            | Opcode  |       | Operand   | Cycles | S | Х | H  | I      | N     | Z   | V | С |
| DEO ( 1)   | D 1 " 7                     | 0.7. 4                 |       |              |         |       | •         |        |   |   |    |        |       |     |   |   |
| BEQ (rel)  | Branch if = Zero            | ? Z = 1                |       | EL           | 27      |       |           | 3      |   | _ |    |        | _     |     |   |   |
| BGE (rel)  | Branch if ∆ Zero            | ? N ⊕ V = 0            |       | EL           | 20      |       |           | 3      | _ | _ |    |        | _     |     |   |   |
| BGT (rel)  | Branch if > Zero            | ? Z + (N ⊕ V) = 0      |       | EL           | 2E      |       |           | 3      | _ | _ | _  |        |       |     |   |   |
| BHI (rel)  | Branch if<br>Higher         | ? C + Z = 0            | R     | EL           | 22      | 2 rr  | •         | 3      | _ | _ | _  | _      | _     | _   | _ | _ |
| BHS (rel)  | Branch if<br>Higher or Same | ? C = 0                | R     | EL           | 24      | 1 rr  |           | 3      | _ | _ | _  | _      | _     | _   | _ | _ |
| BITA (opr) | Bit(s) Test A               | A • M                  | A II  | ИΜ           | 85      | 5 ii  |           | 2      | _ | _ | _  | _      | Δ     | Δ   | 0 | _ |
|            | with Memory                 |                        |       | IR           | 95      |       |           | 3      |   |   |    |        |       |     |   |   |
|            |                             |                        |       | XT           | В       |       | h II      | 4      |   |   |    |        |       |     |   |   |
|            |                             |                        |       | ND,X         | A.      |       |           | 4      |   |   |    |        |       |     |   |   |
|            |                             |                        |       | ND,Y         | 18 A    |       |           | 5      |   |   |    |        |       |     |   |   |
| BITB (opr) | Bit(s) Test B               | B • M                  |       | MM           | C       |       |           | 2      | _ | _ | _  | _      | Δ     | Δ   | 0 | _ |
|            | with Memory                 |                        |       | IR<br>XT     | D:<br>F |       | a<br>h II | 3<br>4 |   |   |    |        |       |     |   |   |
|            |                             |                        |       | ND,X         | E:      |       |           | 4      |   |   |    |        |       |     |   |   |
|            |                             |                        |       | ND,Y         | 18 E    |       |           | 5      |   |   |    |        |       |     |   |   |
| BLE (rel)  | Branch if $\Delta$ Zero     | ? Z + (N ⊕ V) = 1      |       | EL           | 2F      |       |           | 3      |   |   |    |        | _     |     |   |   |
| BLO (rel)  | Branch if Lower             | ? C = 1                |       | EL           | 25      |       |           | 3      |   | _ |    |        | -     |     |   |   |
| BLS (rel)  | Branch if Lower             | ? C + Z = 1            |       | EL           | 23      | _     |           | 3      |   |   |    |        |       |     |   |   |
| . ,        | or Same                     |                        |       |              |         |       |           |        |   |   |    |        |       |     |   |   |
| BLT (rel)  | Branch if < Zero            | ? N ⊕ V = 1            |       | EL           | 2[      |       |           | 3      | _ | _ | _  | _      | _     | _   | _ | _ |
| BMI (rel)  | Branch if Minus             | ? N = 1                | R     | EL           | 2E      | 3 rr  |           | 3      | _ | _ | _  | _      | _     | _   | _ | _ |
| BNE (rel)  | Branch if not = Zero        | ? Z = 0                | R     | EL           | 26      | S rr  |           | 3      | _ | _ | _  | _      | _     | _   | _ | _ |
| BPL (rel)  | Branch if Plus              | ? N = 0                | R     | EL           | 2/      | A rr  |           | 3      | _ | _ | _  | _      | _     | _   | _ | _ |
| BRA (rel)  | Branch Always               | ? 1 = 1                | R     | EL           | 20      | ) rr  |           | 3      | _ | _ | _  | _      | _     | _   | _ | _ |
| BRCLR(opr) | Branch if                   | ? M • mm = 0           | D     | IR           | 13      | 3 d   | d mm rr   | 6      | _ | _ | _  | _      | _     |     | _ | _ |
| (msk)      | Bit(s) Clear                |                        | 11    | ND,X         | 1 F     | =  ff | mm rr     | 7      |   |   |    |        |       |     |   |   |
| (rel)      |                             |                        | 11    | ND,Y         | 18 1F   | =  ff | mm rr     | 8      |   |   |    |        |       |     |   |   |
| BRN (rel)  | Branch Never                | ? 1 = 0                | R     | EL           | 21      | l rr  |           | 3      | _ | _ | _  | _      | _     | _   | _ | _ |
| BRSET(opr) | Branch if Bit(s)            | ? (M) • mm = 0         |       | IR           | 12      |       | d mm rr   | 6      | _ | _ | _  | _      | —     | _   | _ | _ |
| (msk)      | Set                         |                        |       | ND,X         | 1E      |       | mm rr     | 7      |   |   |    |        |       |     |   |   |
| (rel)      |                             |                        |       | ND,Y         | 18 1E   |       | mm rr     | 8      |   |   |    |        |       |     |   |   |
| BSET (opr) | Set Bit(s)                  | $M + mm \Rightarrow M$ |       | IR V         | 14      |       | d mm      | 6      | _ | _ | _  | _      | Δ     | Δ   | 0 | _ |
| (msk)      |                             |                        |       | ND,X<br>ND,Y | 10      |       | mm<br>mm  | 7<br>8 |   |   |    |        |       |     |   |   |
| DCD (rel)  | Dronoh to                   | See Figure 3-2         |       | EL           |         |       |           | 6      |   |   |    |        |       |     |   |   |
| BSR (rel)  | Branch to<br>Subroutine     |                        |       |              | 18      |       |           |        |   |   |    |        |       |     |   |   |
| BVC (rel)  | Branch if<br>Overflow Clear | ? V = 0                |       | EL           | 28      | 3 rr  | •         | 3      | 1 | _ |    |        | _     |     |   |   |
| BVS (rel)  | Branch if<br>Overflow Set   | ? V = 1                | R     | EL           | 29      | rr    |           | 3      | - | _ | _  | _      | _     | _   | _ | _ |
| CBA        | Compare A to B              | A – B                  | 11    | νΗ           | 11      |       | _         | 2      | _ | _ | _  | _      | Δ     | Δ   | Δ | Δ |
| CLC        | Clear Carry Bit             | 0 ⇒ C                  | 11    | NΗ           | 00      | 2     | _         | 2      | _ | _ | _  | _      | _     | _   | _ | 0 |
| CLI        | Clear Interrupt<br>Mask     | 0 ⇒ I                  | 11    | NH           | OE      | ≣     | _         | 2      | _ | _ | _  | 0      | _     | _   | _ | _ |
| CLR (opr)  | Clear Memory                | 0 ⇒ M                  | F     | XT           | 7F      | - h   | h II      | 6      |   | _ |    |        | 0     | 1   | 0 | 0 |
| OLIT (OPI) | Byte                        | 0 - W                  | l i   | ND,X         | 6F      |       |           | 6      |   |   |    |        | "     | •   | Ū | Ü |
|            |                             |                        |       | ND,Y         | 18 6F   |       |           | 7      |   |   |    |        |       |     |   |   |
| CLRA       | Clear<br>Accumulator A      | 0 ⇒ A                  | A II  | NH           | 4F      | =     | _         | 2      | _ | _ | _  | _      | 0     | 1   | 0 | 0 |
| CLRB       | Clear<br>Accumulator B      | 0 ⇒ B                  | B II  | NH           | 5F      | =     | _         | 2      | _ | _ | _  | _      | 0     | 1   | 0 | 0 |
| CLV        | Clear Overflow              | $0 \Rightarrow V$      | 11    | NH           | 0.4     | Α     | _         | 2      | _ | _ | _  | _      | _     | _   | 0 | _ |
| CMDA (===) | Flag                        | A – M                  | Δ     | 48.4         |         |       |           | _      |   |   |    |        |       |     |   |   |
| CMPA (opr) | Compare A to<br>Memory      | A – IVI                |       | ИМ<br>IR     | 81      |       |           | 2      | _ | _ | _  | _      | Δ     | Δ   | Δ | Δ |
|            | IVIGITIOI y                 |                        |       | XT           | В       |       | u<br>h II | 4      |   |   |    |        |       |     |   |   |
|            |                             |                        |       | ND,X         | A.      |       |           | 4      |   |   |    |        |       |     |   |   |
|            |                             |                        |       | ND,Y         | 18 A    |       |           | 5      |   |   |    |        |       |     |   |   |
| CMPB (opr) | Compare B to                | B – M                  | B IN  | ИΜ           | C.      | 1 ii  |           | 2      | _ | _ |    |        | Δ     | Δ   | Δ | Δ |
| ```        | Memory                      |                        | B D   | IR           | D.      | 1 d   |           | 3      |   |   |    |        |       |     |   |   |
|            |                             |                        |       | XT           | F       |       | h II      | 4      |   |   |    |        |       |     |   |   |
|            |                             |                        |       | ND,X         | 10 E    |       |           | 4<br>5 |   |   |    |        |       |     |   |   |
|            |                             |                        | D II  | ND,Y         | 18 E    | 1 ff  |           | ່      |   |   |    |        |       |     |   |   |

Table 3-1. Instruction Set (Sheet 3 of 7)

| Mnemonic   | Operation                         | Dogorintian                                 | Α                | ddressing                           |                            | Ir                         | nstruc                           | tion  |                       |   |   | Co | onditio | n Cod | des |   |   |
|------------|-----------------------------------|---------------------------------------------|------------------|-------------------------------------|----------------------------|----------------------------|----------------------------------|-------|-----------------------|---|---|----|---------|-------|-----|---|---|
| winemonic  | Operation                         | Description                                 |                  | Mode                                | 0                          | pcode                      | Ope                              | erand | Cycles                | S | Х | Н  | ı       | N     | Z   | ٧ | С |
| COM (opr)  | Ones<br>Complement<br>Memory Byte | $FF - M \Rightarrow M$                      |                  | EXT<br>IND,X<br>IND,Y               | 18                         | 73<br>63<br>63             | hh II<br>ff<br>ff                | I     | 6<br>6<br>7           | _ | _ | _  | _       | Δ     | Δ   | 0 | 1 |
| COMA       | Ones<br>Complement<br>A           | \$FF – A ⇒ A                                | А                | INH                                 |                            | 43                         | -                                | _     | 2                     | _ | _ | _  | _       | Δ     | Δ   | 0 | 1 |
| COMB       | Ones<br>Complement<br>B           | \$FF – B ⇒ B                                | В                | INH                                 |                            | 53                         | -                                | _     | 2                     | _ | _ | _  | _       | Δ     | Δ   | 0 | 1 |
| CPD (opr)  | Compare D to<br>Memory 16-Bit     | D-M:M +1                                    |                  | IMM<br>DIR<br>EXT<br>IND,X<br>IND,Y | 1A<br>1A<br>1A<br>1A<br>CD | 83<br>93<br>B3<br>A3<br>A3 | jj kk<br>dd<br>hh ll<br>ff       |       | 5<br>6<br>7<br>7<br>7 | _ | _ | _  | _       | Δ     | Δ   | Δ | Δ |
| CPX (opr)  | Compare X to<br>Memory 16-Bit     | IX – M : M + 1                              |                  | IMM<br>DIR<br>EXT<br>IND,X<br>IND,Y | CD                         | 8C<br>9C<br>BC<br>AC<br>AC | jj kk<br>dd<br>hh ll<br>ff       |       | 4<br>5<br>6<br>6<br>7 | _ | _ | _  | _       | Δ     | Δ   | Δ | Δ |
| CPY (opr)  | Compare Y to<br>Memory 16-Bit     | IY – M : M + 1                              |                  | IMM<br>DIR<br>EXT<br>IND,X<br>IND,Y | 18<br>18<br>18<br>1A<br>18 | 8C<br>9C<br>BC<br>AC<br>AC | jj kk<br>dd<br>hh ll<br>ff<br>ff |       | 5<br>6<br>7<br>7<br>7 | _ | _ | _  | _       | Δ     | Δ   | Δ | Δ |
| DAA        | Decimal Adjust<br>A               | Adjust Sum to BCD                           |                  | INH                                 |                            | 19                         |                                  | _     | 2                     | _ | _ | _  | _       | Δ     | Δ   | Δ | Δ |
| DEC (opr)  | Decrement<br>Memory Byte          | $M-1 \Rightarrow M$                         |                  | EXT<br>IND,X<br>IND,Y               | 18                         | 7A<br>6A<br>6A             | hh II<br>ff<br>ff                | I     | 6<br>6<br>7           | _ | _ | _  | _       | Δ     | Δ   | Δ | _ |
| DECA       | Decrement<br>Accumulator<br>A     | A − 1 ⇒ A                                   | A                | INH                                 |                            | 4A                         | -                                | _     | 2                     | _ | _ | _  | _       | Δ     | Δ   | Δ | _ |
| DECB       | Decrement<br>Accumulator<br>B     | B − 1 ⇒ B                                   | В                | INH                                 |                            | 5A                         |                                  | _     | 2                     | _ | _ | _  | _       | Δ     | Δ   | Δ | _ |
| DES        | Decrement<br>Stack Pointer        | SP − 1 ⇒ SP                                 |                  | INH                                 |                            | 34                         |                                  | _     | 3                     | _ | _ | _  | _       | _     | _   | _ | _ |
| DEX        | Decrement<br>Index Register<br>X  | $IX - 1 \Rightarrow IX$                     |                  | INH                                 |                            | 09                         | -                                |       | 3                     | _ | _ | _  | _       | -     | Δ   | _ | _ |
| DEY        | Decrement<br>Index Register<br>Y  | IY – 1 ⇒ IY                                 |                  | INH                                 | 18                         | 09                         | -                                | _     | 4                     | _ | _ | _  | _       | _     | Δ   | _ | _ |
| EORA (opr) | Exclusive OR A with Memory        | $A \oplus M \Rightarrow A$                  | A<br>A<br>A<br>A | IMM<br>DIR<br>EXT<br>IND,X<br>IND,Y | 18                         | 88<br>98<br>B8<br>A8<br>A8 | ii<br>dd<br>hh II<br>ff          | I     | 2<br>3<br>4<br>4<br>5 | _ | _ | _  | _       | Δ     | Δ   | 0 | _ |
| EORB (opr) | Exclusive OR B with Memory        | $B \oplus M \Rightarrow B$                  | B<br>B<br>B<br>B | IMM<br>DIR<br>EXT<br>IND,X<br>IND,Y | 18                         | C8<br>D8<br>F8<br>E8       | ii<br>dd<br>hh II<br>ff<br>ff    | I     | 2<br>3<br>4<br>4<br>5 | _ | _ | _  | _       | Δ     | Δ   | 0 | _ |
| FDIV       | Fractional<br>Divide 16 by 16     | $D / IX \Rightarrow IX; r \Rightarrow D$    |                  | INH                                 |                            | 03                         |                                  | _     | 41                    | _ | - | -  | _       | _     | Δ   | Δ | Δ |
| IDIV       | Integer Divide<br>16 by 16        | $D  /  IX \Rightarrow IX;  r \Rightarrow D$ |                  | INH                                 |                            | 02                         |                                  |       | 41                    | _ | _ | _  | _       | _     | Δ   | 0 | Δ |
| INC (opr)  | Increment<br>Memory Byte          | M + 1 ⇒ M                                   |                  | EXT<br>IND,X<br>IND,Y               | 18                         | 7C<br>6C<br>6C             | hh II<br>ff<br>ff                | ı     | 6<br>6<br>7           | _ | _ | _  | _       | Δ     | Δ   | Δ | _ |
| INCA       | Increment<br>Accumulator<br>A     | A + 1 ⇒ A                                   | A                | INH                                 |                            | 4C                         |                                  | _     | 2                     | _ | _ | _  | _       | Δ     | Δ   | Δ | _ |
| INCB       | Increment<br>Accumulator<br>B     | B + 1 ⇒ B                                   | В                | INH                                 |                            | 5C                         |                                  | _     | 2                     | _ | _ | _  | _       | Δ     | Δ   | Δ | _ |

Table 3-1. Instruction Set (Sheet 4 of 7)

| Mnemonic   | Operation                        | Description                            | Addressing                          |                                           | nstruction                 |                       |   |   | Co | onditio | n Cod | des |   |   |
|------------|----------------------------------|----------------------------------------|-------------------------------------|-------------------------------------------|----------------------------|-----------------------|---|---|----|---------|-------|-----|---|---|
|            | Operation                        | -                                      | Mode                                | Opcode                                    | Operand                    | Cycles                | S | Х | Н  | ı       | N     | Z   | ٧ | С |
| INS        | Increment<br>Stack Pointer       | $SP + 1 \Rightarrow SP$                | INH                                 | 31                                        | _                          | 3                     | _ | _ | _  | _       | _     | _   | _ | _ |
| INX        | Increment<br>Index Register<br>X | IX + 1 ⇒ IX                            | INH                                 | 08                                        | _                          | 3                     | _ | _ | _  | _       | _     | Δ   | _ | _ |
| INY        | Increment<br>Index Register<br>Y | IY + 1 ⇒ IY                            | INH                                 | 18 08                                     | _                          | 4                     | _ | - | _  | _       | _     | Δ   | _ | _ |
| JMP (opr)  | Jump                             | See Figure 3-2                         | EXT<br>IND,X<br>IND,Y               | 7E<br>6E<br>18 6E                         | hh II<br>ff<br>ff          | 3<br>3<br>4           | _ | _ | _  | _       | _     | _   | _ |   |
| JSR (opr)  | Jump to<br>Subroutine            | See Figure 3-2                         | DIR<br>EXT<br>IND,X<br>IND,Y        | 9D<br>BD<br>AD<br>18 AD                   | dd<br>hh II<br>ff          | 5<br>6<br>6<br>7      | _ | _ | _  | _       | _     | _   |   |   |
| LDAA (opr) | Load<br>Accumulator<br>A         | $M \Rightarrow A$                      | A IMM A DIR A EXT A IND,X A IND,Y   | 86<br>96<br>B6<br>A6<br>18 A6             | ii<br>dd<br>hh II<br>ff    | 2<br>3<br>4<br>4<br>5 | _ | _ | _  | _       | Δ     | Δ   | 0 | _ |
| LDAB (opr) | Load<br>Accumulator<br>B         | $M\RightarrowB$                        | B IMM B DIR B EXT B IND,X B IND,Y   | C6<br>D6<br>F6<br>E6                      | ii<br>dd<br>hh II<br>ff    | 2<br>3<br>4<br>4<br>5 | _ | _ | _  | _       | Δ     | Δ   | 0 |   |
| LDD (opr)  | Load Double<br>Accumulator<br>D  | $M \Rightarrow A, M + 1 \Rightarrow B$ | IMM<br>DIR<br>EXT<br>IND,X<br>IND,Y | CC<br>DC<br>FC<br>EC<br>18 EC             | jj kk<br>dd<br>hh II<br>ff | 3<br>4<br>5<br>5<br>6 | _ | _ | _  | _       | Δ     | Δ   | 0 | _ |
| LDS (opr)  | Load Stack<br>Pointer            | M : M + 1 ⇒ SP                         | IMM<br>DIR<br>EXT<br>IND,X<br>IND,Y | 8E<br>9E<br>BE<br>AE<br>18 AE             | jj kk<br>dd<br>hh II<br>ff | 3<br>4<br>5<br>5<br>6 | _ | _ | _  | _       | Δ     | Δ   | 0 |   |
| LDX (opr)  | Load Index<br>Register<br>X      | $M: M+1 \Rightarrow IX$                | IMM<br>DIR<br>EXT<br>IND,X<br>IND,Y | CE<br>DE<br>FE<br>EE<br>CD EE             | jj kk<br>dd<br>hh II<br>ff | 3<br>4<br>5<br>5<br>6 | _ | _ | _  | _       | Δ     | Δ   | 0 | _ |
| LDY (opr)  | Load Index<br>Register<br>Y      | $M: M+1 \Rightarrow IY$                | IMM<br>DIR<br>EXT<br>IND,X<br>IND,Y | 18 CE<br>18 DE<br>18 FE<br>1A EE<br>18 EE | jj kk<br>dd<br>hh II<br>ff | 4<br>5<br>6<br>6      | _ | _ | _  | _       | Δ     | Δ   | 0 | _ |
| LSL (opr)  | Logical Shift<br>Left            |                                        | EXT<br>IND,X<br>IND,Y               | 78<br>68<br>18 68                         | hh II<br>ff<br>ff          | 6<br>6<br>7           | _ | _ | _  | _       | Δ     | Δ   | Δ | Δ |
| LSLA       | Logical Shift<br>Left A          |                                        | A INH                               | 48                                        | _                          | 2                     | _ | _ | _  | _       | Δ     | Δ   | Δ | Δ |
| LSLB       | Logical Shift<br>Left B          | —————————————————————————————————————  | B INH                               | 58                                        | _                          | 2                     | _ | _ | _  | _       | Δ     | Δ   | Δ | Δ |
| LSLD       | Logical Shift<br>Left Double     | ← ← ← ← 0<br>C b7 A b0 b7 B b0         | INH                                 | 05                                        | _                          | 3                     | _ | _ | _  | _       | Δ     | Δ   | Δ | Δ |
| LSR (opr)  | Logical Shift<br>Right           | 0                                      | EXT<br>IND,X<br>IND,Y               | 74<br>64<br>18 64                         | hh II<br>ff<br>ff          | 6<br>6<br>7           | _ | _ | _  | _       | 0     | Δ   | Δ | Δ |
| LSRA       | Logical Shift<br>Right A         | 0                                      | A INH                               | 44                                        | _                          | 2                     | _ | _ | _  | _       | 0     | Δ   | Δ | Δ |
| LSRB       | Logical Shift<br>Right B         | 0                                      | B INH                               | 54                                        | _                          | 2                     | _ | _ | _  | _       | 0     | Δ   | Δ | Δ |

Table 3-1. Instruction Set (Sheet 5 of 7)

| B.d        | 0                                  | Description (                       | Ad               | dressing                            |    | Ir                   | nstru                | ction |                       |   |              | Co | nditio | n Cod | les |   |   |
|------------|------------------------------------|-------------------------------------|------------------|-------------------------------------|----|----------------------|----------------------|-------|-----------------------|---|--------------|----|--------|-------|-----|---|---|
| Mnemonic   | Operation                          | Description                         |                  | Mode                                | Op | code                 | Or                   | erand | Cycles                | S | Х            | Н  | ı      | N     | Z   | ٧ | С |
| LSRD       | Logical Shift<br>Right Double      | 0→ → → 0 b7 A b0 b7 B b0 C          |                  | INH                                 |    | 04                   |                      | _     | 3                     |   | _            | _  | _      | 0     | Δ   | Δ | Δ |
| MUL        | Multiply 8 by 8                    | $A * B \Rightarrow D$               |                  | INH                                 |    | 3D                   |                      | _     | 10                    | _ | _            | _  | _      | _     | _   | _ | Δ |
| NEG (opr)  | Two's<br>Complement<br>Memory Byte | $0 - M \Rightarrow M$               |                  | EXT<br>IND,X<br>IND,Y               | 18 | 70<br>60<br>60       | hh<br>ff<br>ff       | II    | 6<br>6<br>7           | _ | _            | _  | _      | Δ     | Δ   | Δ | Δ |
| NEGA       | Two's<br>Complement<br>A           | 0 − A ⇒ A                           | А                | INH                                 |    | 40                   |                      | _     | 2                     | _ | _            | _  | _      | Δ     | Δ   | Δ | Δ |
| NEGB       | Two's<br>Complement<br>B           | 0 − B ⇒ B                           | В                | INH                                 |    | 50                   |                      | _     | 2                     |   | _            | _  | _      | Δ     | Δ   | Δ | Δ |
| NOP        | No operation                       | No Operation                        |                  | INH                                 |    | 01                   |                      | _     | 2                     | _ | _            |    | _      | -     | _   |   | _ |
| ORAA (opr) | OR<br>Accumulator<br>A (Inclusive) | A + M ⇒ A                           | A<br>A<br>A<br>A | IMM<br>DIR<br>EXT<br>IND,X<br>IND,Y | 18 | 8A<br>9A<br>BA<br>AA | ii<br>dd<br>hh<br>ff | II    | 2<br>3<br>4<br>4<br>5 | _ | _            | _  | _      | Δ     | Δ   | 0 | _ |
| ORAB (opr) | OR<br>Accumulator<br>B (Inclusive) | B + M ⇒ B                           | B<br>B<br>B<br>B | IMM<br>DIR<br>EXT<br>IND,X<br>IND,Y | 18 | CA<br>DA<br>FA<br>EA | ii<br>dd<br>hh<br>ff | II    | 2<br>3<br>4<br>4<br>5 |   | _            | _  | _      | Δ     | Δ   | 0 | _ |
| PSHA       | Push A onto<br>Stack               | $A \Rightarrow Stk, SP = SP - 1$    | А                | INH                                 |    | 36                   |                      | _     | 3                     |   | _            | _  | _      | _     | _   | _ | _ |
| PSHB       | Push B onto<br>Stack               | $B \Rightarrow Stk, SP = SP - 1$    | В                | INH                                 |    | 37                   |                      | _     | 3                     | _ | -            | _  | _      | _     | _   | _ | - |
| PSHX       | Push X onto<br>Stack (Lo<br>First) | $IX \Rightarrow Stk, SP = SP - 2$   |                  | INH                                 |    | 3C                   |                      | _     | 4                     |   | _            | _  | _      | _     | _   | _ | _ |
| PSHY       | Push Y onto<br>Stack (Lo<br>First) | $IY \Rightarrow Stk, SP = SP - 2$   |                  | INH                                 | 18 | 3C                   |                      | _     | 5                     |   | _            | _  | _      | _     | _   | _ | _ |
| PULA       | Pull A from<br>Stack               | SP = SP + 1, A ← Stk                |                  | INH                                 |    | 32                   |                      | _     | 4                     | l | _            | _  | _      | _     | _   | _ | _ |
| PULB       | Pull B from<br>Stack               | SP = SP + 1, B ← Stk                |                  | INH                                 |    | 33                   |                      | _     | 4                     | l | -            | _  | _      | _     | _   | _ | _ |
| PULX       | Pull X From<br>Stack (Hi<br>First) | $SP = SP + 2$ , $IX \Leftarrow Stk$ |                  | INH                                 |    | 38                   |                      | _     | 5                     |   | _            | _  | _      | _     | _   | _ | _ |
| PULY       | Pull Y from<br>Stack (Hi<br>First) | $SP = SP + 2$ , $IY \Leftarrow Stk$ |                  | INH                                 | 18 | 38                   |                      | _     | 6                     | _ | _            | _  | _      | _     | _   | _ | _ |
| ROL (opr)  | Rotate Left                        | C b7 b0                             |                  | EXT<br>IND,X<br>IND,Y               | 18 | 79<br>69<br>69       | hh<br>ff<br>ff       | II    | 6<br>6<br>7           |   | _            | _  | _      | Δ     | Δ   | Δ | Δ |
| ROLA       | Rotate Left A                      | C b7 b0                             | A                | INH                                 |    | 49                   |                      | _     | 2                     | 1 | _            | _  | _      | Δ     | Δ   | Δ | Δ |
| ROLB       | Rotate Left B                      | C b7 b0                             | В                | INH                                 |    | 59                   |                      | _     | 2                     |   | _            | _  | _      | Δ     | Δ   | Δ | Δ |
| ROR (opr)  | Rotate Right                       | b7 b0 C                             |                  | EXT<br>IND,X<br>IND,Y               | 18 | 76<br>66<br>66       | hh<br>ff<br>ff       | II    | 6<br>6<br>7           |   | _            | _  | _      | Δ     | Δ   | Δ | Δ |
| RORA       | Rotate Right A                     | b7 b0 C                             | А                | INH                                 |    | 46                   |                      | _     | 2                     | _ | _            | _  | _      | Δ     | Δ   | Δ | Δ |
| RORB       | Rotate Right B                     | b7 b0 C                             | В                | INH                                 |    | 56                   |                      | _     | 2                     | _ | _            | _  | _      | Δ     | Δ   | Δ | Δ |
| RTI        | Return from<br>Interrupt           | See Figure 3-2                      |                  | INH                                 |    | 3B                   |                      | _     | 12                    | Δ | $\downarrow$ | Δ  | Δ      | Δ     | Δ   | Δ | Δ |
| RTS        | Return from<br>Subroutine          | See Figure 3-2                      |                  | INH                                 |    | 39                   |                      | _     | 5                     | _ | _            | _  | _      | -     | _   | _ | _ |

Table 3-1. Instruction Set (Sheet 6 of 7)

| Manager    | Omeration                     | Desertation                            | Addressing                                    | l.                               | nstruction                 |                       |   |              | Co | nditio | n Coc | des |   |   |
|------------|-------------------------------|----------------------------------------|-----------------------------------------------|----------------------------------|----------------------------|-----------------------|---|--------------|----|--------|-------|-----|---|---|
| Mnemonic   | Operation                     | Description                            | Mode                                          | Opcode                           | Operand                    | Cycles                | S | Х            | Н  | ı      | N     | Z   | ٧ | С |
| SBA        | Subtract B from<br>A          | $A - B \Rightarrow A$                  | INH                                           | 10                               | _                          | 2                     | _ | _            | _  | _      | Δ     | Δ   | Δ | Δ |
| SBCA (opr) | Subtract with<br>Carry from A | $A - M - C \Rightarrow A$              | A IMM<br>A DIR<br>A EXT<br>A IND,X<br>A IND,Y | 82<br>92<br>B2<br>A2<br>18 A2    | ii<br>dd<br>hh II<br>ff    | 2<br>3<br>4<br>4<br>5 | _ | _            | _  | _      | Δ     | Δ   | Δ | Δ |
| SBCB (opr) | Subtract with<br>Carry from B | $B - M - C \Rightarrow B$              | B IMM B DIR B EXT B IND,X B IND,Y             | C2<br>D2<br>F2<br>E2<br>18 E2    | ii<br>dd<br>hh II<br>ff    | 2<br>3<br>4<br>4<br>5 | _ | _            | _  | _      | Δ     | Δ   | Δ | Δ |
| SEC        | Set Carry                     | 1 ⇒ C                                  | INH                                           | 0D                               | _                          | 2                     | _ | _            | _  | _      | _     | _   | _ | 1 |
| SEI        | Set Interrupt<br>Mask         | 1 ⇒ I                                  | INH                                           | 0F                               | _                          | 2                     | _ | _            | _  | 1      | _     | _   | _ | _ |
| SEV        | Set Overflow<br>Flag          | 1 ⇒ V                                  | INH                                           | 0B                               | _                          | 2                     | _ | _            | _  | _      | _     | _   | 1 | _ |
| STAA (opr) | Store<br>Accumulator<br>A     | $A \Rightarrow M$                      | A DIR A EXT A IND,X A IND,Y                   | 97<br>B7<br>A7<br>18 A7          | dd<br>hh II<br>ff          | 3<br>4<br>4<br>5      | _ | _            | _  | _      | Δ     | Δ   | 0 | _ |
| STAB (opr) | Store<br>Accumulator<br>B     | $B \Rightarrow M$                      | B DIR B EXT B IND,X B IND,Y                   | D7<br>F7<br>E7<br>18 E7          | dd<br>hh II<br>ff          | 3<br>4<br>4<br>5      | _ | _            | _  | _      | Δ     | Δ   | 0 | _ |
| STD (opr)  | Store<br>Accumulator<br>D     | $A \Rightarrow M, B \Rightarrow M + 1$ | DIR<br>EXT<br>IND,X<br>IND,Y                  | DD<br>FD<br>ED<br>18 ED          | dd<br>hh II<br>ff          | 4<br>5<br>5<br>6      | _ | _            | _  | _      | Δ     | Δ   | 0 | _ |
| STOP       | Stop Internal<br>Clocks       | _                                      | INH                                           | CF                               | _                          | 2                     | _ | _            | _  | _      | _     | _   | _ | _ |
| STS (opr)  | Store Stack<br>Pointer        | SP ⇒ M : M + 1                         | DIR<br>EXT<br>IND,X<br>IND,Y                  | 9F<br>BF<br>AF<br>18 AF          | dd<br>hh II<br>ff          | 4<br>5<br>5<br>6      | _ | _            | _  | _      | Δ     | Δ   | 0 | _ |
| STX (opr)  | Store Index<br>Register X     | IX ⇒ M : M + 1                         | DIR<br>EXT<br>IND,X<br>IND,Y                  | DF<br>FF<br>EF<br>CD EF          | dd<br>hh II<br>ff          | 4<br>5<br>5<br>6      | _ | _            | _  | _      | Δ     | Δ   | 0 | _ |
| STY (opr)  | Store Index<br>Register Y     | IY ⇒ M : M + 1                         | DIR<br>EXT<br>IND,X<br>IND,Y                  | 18 DF<br>18 FF<br>1A EF<br>18 EF | dd<br>hh II<br>ff          | 5<br>6<br>6           | _ | _            | _  | _      | Δ     | Δ   | 0 |   |
| SUBA (opr) | Subtract<br>Memory from<br>A  | $A-M\RightarrowA$                      | A IMM A DIR A EXT A IND,X A IND,Y             | 80<br>90<br>B0<br>A0<br>18 A0    | ii<br>dd<br>hh II<br>ff    | 2<br>3<br>4<br>4<br>5 | _ | _            | _  |        | Δ     | Δ   | Δ | Δ |
| SUBB (opr) | Subtract<br>Memory from<br>B  | $B-M\RightarrowB$                      | A IMM A DIR A EXT A IND,X A IND,Y             | C0<br>D0<br>F0<br>E0<br>18 E0    | ii<br>dd<br>hh II<br>ff    | 2<br>3<br>4<br>4<br>5 | _ | _            | _  | _      | Δ     | Δ   | Δ | Δ |
| SUBD (opr) | Subtract<br>Memory from<br>D  | D − M : M + 1 ⇒ D                      | IMM<br>DIR<br>EXT<br>IND,X<br>IND,Y           | 83<br>93<br>B3<br>A3<br>18 A3    | jj kk<br>dd<br>hh II<br>ff | 4<br>5<br>6<br>6<br>7 | _ | _            | _  | _      | Δ     | Δ   | Δ | Δ |
| SWI        | Software<br>Interrupt         | See Figure 3-2                         | INH                                           | 3F                               | _                          | 14                    | _ | _            | _  | 1      | _     | _   | _ | _ |
| TAB        | Transfer A to B               | $A \Rightarrow B$                      | INH                                           | 16                               | _                          | 2                     | _ | _            | _  | _      | Δ     | Δ   | 0 | _ |
| TAP        | Transfer A to CC Register     | A ⇒ CCR                                | INH                                           | 06                               | _                          | 2                     | Δ | $\downarrow$ | Δ  | Δ      | Δ     | Δ   | Δ | Δ |
| TBA        | Transfer B to A               | $B \Rightarrow A$                      | INH                                           | 17                               | _                          | 2                     | _ | _            | _  | _      | Δ     | Δ   | 0 | _ |
| TEST       | TEST (Only in<br>Test Modes)  | Address Bus Counts                     | INH                                           | 00                               | _                          | *                     | _ |              |    |        | _     | _   | _ | _ |

Table 3-1. Instruction Set (Sheet 7 of 7)

| Na        | 0                              | December                             | A | ddressing             |    | Ir             | struction         |             |   |   | Co | nditio | n Coo | des |   |   |
|-----------|--------------------------------|--------------------------------------|---|-----------------------|----|----------------|-------------------|-------------|---|---|----|--------|-------|-----|---|---|
| Mnemonic  | Operation                      | Description                          |   | Mode                  | 0  | code           | Operand           | Cycles      | S | Х | Н  | ı      | N     | Z   | ٧ | С |
| TPA       | Transfer CC<br>Register to A   | $CCR \Rightarrow A$                  |   | INH                   |    | 07             | _                 | 2           | _ | _ |    | _      | _     | _   | _ | _ |
| TST (opr) | Test for Zero or<br>Minus      | M – 0                                |   | EXT<br>IND,X<br>IND,Y | 18 | 7D<br>6D<br>6D | hh II<br>ff<br>ff | 6<br>6<br>7 | _ | _ | _  | _      | Δ     | Δ   | 0 | 0 |
| TSTA      | Test A for Zero or Minus       | A – 0                                | Α | INH                   |    | 4D             | _                 | 2           | _ | _ | _  | _      | Δ     | Δ   | 0 | 0 |
| TSTB      | Test B for Zero or Minus       | B – 0                                | В | INH                   |    | 5D             | _                 | 2           | _ | _ | _  | _      | Δ     | Δ   | 0 | 0 |
| TSX       | Transfer Stack<br>Pointer to X | SP + 1 ⇒ IX                          |   | INH                   |    | 30             | _                 | 3           | _ | _ | _  | _      | _     | _   | _ |   |
| TSY       | Transfer Stack<br>Pointer to Y | SP + 1 ⇒ IY                          |   | INH                   | 18 | 30             | _                 | 4           | _ | _ | _  | _      | _     | _   | _ | _ |
| TXS       | Transfer X to<br>Stack Pointer | IX – 1 ⇒ SP                          |   | INH                   |    | 35             | _                 | 3           | _ | _ | _  | _      | _     | _   | _ | _ |
| TYS       | Transfer Y to<br>Stack Pointer | IY – 1 ⇒ SP                          |   | INH                   | 18 | 35             | _                 | 4           | _ | _ | _  | _      | _     | _   | _ | _ |
| WAI       | Wait for<br>Interrupt          | Stack Regs & WAIT                    |   | INH                   |    | 3E             | _                 | **          | _ | _ | _  | _      | _     | _   | _ | _ |
| XGDX      | Exchange D with X              | $IX \Rightarrow D, D \Rightarrow IX$ |   | INH                   |    | 8F             | _                 | 3           | _ | _ | _  | _      | _     | _   | _ | _ |
| XGDY      | Exchange D with Y              | $IY \Rightarrow D, D \Rightarrow IY$ |   | INH                   | 18 | 8F             | _                 | 4           | _ | _ | _  | _      | _     | _   | _ | _ |

#### Cycle

- \* 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).

#### Operands

dd = 8-bit direct address (\$0000–\$00FF) (high byte assumed to be \$00)

ff = 8-bit positive offset \$00 (0) to \$FF (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

mm = 8-bit mask (set bits to be affected)

rr = Signed relative offset \$80 (-128) to \$7F (+127)

(offset relative to address following machine code offset byte))

#### Operators

() Contents of register shown inside parentheses

← Is transferred to

Is pulled from stack

↓ Is pushed onto stack

Boolean AND

Arithmetic addition symbol except where used as inclusive-OR symbol in Boolean formula

⊕ Exclusive-OR

\* Multiply

: Concatenation

Arithmetic subtraction symbol or negation symbol (two's complement)

#### Condition Codes

Bit not changed

0 Bit always cleared

1 Bit always set

∆ Bit cleared or set, depending on operation
 ↓ Bit can be cleared, cannot become set

# **Section 4. Operating Modes and On-Chip Memory**

### 4.1 Contents

| 4.2              | Introduction                               | 64 |
|------------------|--------------------------------------------|----|
| 4.3              | Control Registers                          | 64 |
| 4.4              | System Initialization                      |    |
| 4.5              | Operating Modes                            |    |
| 4.5.1            | Single-Chip Mode                           |    |
| 4.5.2            | Expanded Mode                              |    |
| 4.5.3            | Bootstrap Mode                             |    |
| 4.5.4            | Special Test Mode                          |    |
| 4.5.5            | Mode Selection                             |    |
| 4.6              | Memory Map                                 |    |
| 4.6.1            | Control Registers and RAM                  |    |
| 4.6.2            | ROM or EPROM                               |    |
| 4.6.3            | EEPROM                                     |    |
| 4.6.4            | Bootloader ROM                             |    |
| 4.7              | EPROM/OTPROM (M68HC711K4 and M68HC711KS2)  |    |
| 4.7.1            | Programming the EPROM with Downloaded Data |    |
| 4.7.2            | Programming the EPROM from Memory          |    |
| 4.8              | EEPROM and the CONFIG Register             |    |
| 4.8.1            | EEPROM Registers                           |    |
| 4.8.1.           |                                            |    |
| 4.8.1.           |                                            |    |
| 4.8.1.3<br>4.8.2 |                                            | 97 |
| 4.8.2.           | EEPROM Programming                         |    |
| 4.8.2.           |                                            |    |
| 4.8.2.           |                                            |    |
| 4.8.2.           |                                            |    |
| 4.8.3            | CONFIG Register Programming                |    |
| 4.8.4            | RAM and EEPROM Security                    |    |
| 4.9              | XOUT Pin Control                           |    |
| 4.9.1            | System Configuration Register              |    |
| 4.9.2            | System Configuration Options 2 Register    |    |
|                  |                                            |    |

### **Operating Modes and On-Chip Memory**

### 4.2 Introduction

This section presents the elements involved in configuring the M68HC11K/KS Family microcontrollers (MCUs), including:

- A list of the control registers, see 4.3 Control Registers
- Special registers that control system initialization, see 4.4 System Initialization
- Description of the four operating modes and how they're selected, see 4.5 Operating Modes
- Memory maps of the K Family, see 4.6 Memory Map
- Information on programming EPROM (erasable, programmable read-only memory) and EEPROM (electrically erasable, programmable read-only memory), see 4.7 EPROM/OTPROM (M68HC711K4 and M68HC711KS2) and 4.8 EEPROM and the CONFIG Register

### 4.3 Control Registers

The heart of the M68HC11 Family of MCUs is a special register block which controls the peripheral functions. In the K Family, this block is 128 bytes. The default location of this block is the first 128 bytes of memory, but software can map it to any 4-Kbyte boundary (see **4.6.1 Control Registers and RAM**).

Certain bits and registers that control initialization and the basic operation of the MCU are protected against writes in normal operating modes except under special circumstances. Some bits cannot be written at all; others can be written only once and/or within the first 64 bus cycles after any reset. The special operating modes override these restrictions. These bits and registers are discussed in **4.4 System Initialization**.

Normal and special operating modes are discussed in **4.5 Operating Modes**. The write-restricted registers and bits are summarized in **Table 4-1**.

**Figure 4-1** lists the entire 128-byte register block in ascending order by address, using the default memory block assignment \$0000–\$007F.

**NOTE:** Throughout this manual, the registers are discussed by function. In the event that not all bits in a register are referenced, the bits that are not discussed are shaded.

| Addr.  | Register Name                            |                 | Bit 7                 | 6          | 5      | 4         | 3           | 2    | 1                                          | Bit 0 |  |  |  |  |  |  |  |  |
|--------|------------------------------------------|-----------------|-----------------------|------------|--------|-----------|-------------|------|--------------------------------------------|-------|--|--|--|--|--|--|--|--|
| \$0000 | Port A Data Register<br>(PORTA)          | Read:<br>Write: | PA7                   | PA6        | PA5    | PA4       | PA3         | PA2  | PA1                                        | PA0   |  |  |  |  |  |  |  |  |
|        | See page 138.                            | Reset:          |                       |            |        | Undefined | after reset |      |                                            |       |  |  |  |  |  |  |  |  |
| \$0001 | Port A Data Direction<br>Register (DDRA) | Read:<br>Write: | DDA7                  | DDA6       | DDA5   | DDA4      | DDA3        | DDA2 | DDA1                                       | DDA0  |  |  |  |  |  |  |  |  |
|        | See page 138.                            | Reset:          | 0                     | 0          | 0      | 0         | 0           | 0    | 0                                          | 0     |  |  |  |  |  |  |  |  |
| \$0002 | Port B Data Direction<br>Register (DDRB) | Read:<br>Write: | DDB7                  | DDB6       | DDB5   | DDB4      | DDB3        | DDB2 | DDB1                                       | DDB0  |  |  |  |  |  |  |  |  |
|        | See page 139.                            | Reset:          | 0                     | 0          | 0      | 0         | 0           | 0    | 0                                          | 0     |  |  |  |  |  |  |  |  |
| \$0003 | Port F Data Direction<br>Register (DDRF) | Read:<br>Write: | DDF7                  | DDF6       | DDF5   | DDF4      | DDF3        | DDF2 | DDF1                                       | DDF0  |  |  |  |  |  |  |  |  |
|        | See page 144.                            | Reset:          | 0                     | 0          | 0      | 0         | 0           | 0    | 0                                          | 0     |  |  |  |  |  |  |  |  |
| \$0004 | Port B Data Register<br>(PORTB)          | Read:<br>Write: | PB7                   | PB6        | PB5    | PB4       | PB3         | PB2  | PB1                                        | PB0   |  |  |  |  |  |  |  |  |
|        | See page 139.                            | Reset:          | Undefined after reset |            |        |           |             |      |                                            |       |  |  |  |  |  |  |  |  |
| \$0005 | Port F Data Register<br>(PORTF)          | Read:<br>Write: | PF7                   | PF6        | PF5    | PF4       | PF3         | PF2  | PF1                                        | PF0   |  |  |  |  |  |  |  |  |
|        | See page 144.                            | Reset:          |                       |            |        | Undefined | after reset |      |                                            |       |  |  |  |  |  |  |  |  |
| \$0006 | Port C Data Register<br>(PORTC)          | Read:<br>Write: | PC7                   | PC6        | PC5    | PC4       | PC3         | PC2  | PC1                                        | PC0   |  |  |  |  |  |  |  |  |
|        | See page 140.                            | Reset:          |                       |            |        | Undefined | after reset |      |                                            |       |  |  |  |  |  |  |  |  |
| \$0007 | Port C Data Direction<br>Register (DDRC) | Read:<br>Write: | DDC7                  | DDC6       | DDC5   | DDC4      | DDC3        | DDC2 | DDC1                                       | DDC0  |  |  |  |  |  |  |  |  |
|        | See page 141.                            | Reset:          | 0                     | 0          | 0      | 0         | 0           | 0    | 0                                          | 0     |  |  |  |  |  |  |  |  |
| \$0008 | Port D Data Register<br>(PORTD)          | Read:<br>Write: | 0                     | 0          | PD5    | PD4       | PD3         | PD2  | PD1                                        | PD0   |  |  |  |  |  |  |  |  |
|        | See page 142.                            | Reset:          | 0                     | 0          | U      | U         | U           | U    | U                                          | U     |  |  |  |  |  |  |  |  |
| \$0009 | Port D Data Direction<br>Register (DDRD) | Read:<br>Write: | 0                     | 0          | DDD5   | DDD4      | DDD3        | DDD2 | DDD1                                       | DDD0  |  |  |  |  |  |  |  |  |
|        | See page 142.                            | Reset:          | 0                     | 0          | 0      | 0         | 0           | 0    | 0                                          | 0     |  |  |  |  |  |  |  |  |
|        |                                          |                 |                       | = Unimplen | nented | R         | = Reserved  |      | = Unimplemented R = Reserved U = Undefined |       |  |  |  |  |  |  |  |  |

Figure 4-1. Register and Control Bit Assignments (Sheet 1 of 11)

# **Operating Modes and On-Chip Memory**

| Addr.  | Register Name                                                   |                 | Bit 7  | 6                     | 5      | 4         | 3           | 2      | 1           | Bit 0 |
|--------|-----------------------------------------------------------------|-----------------|--------|-----------------------|--------|-----------|-------------|--------|-------------|-------|
| \$000A | Port E Data Register<br>(PORTE)<br>See page 143.                | Read:<br>Write: | PE7    | PE6                   | PE5    | PE4       | PE3         | PE2    | PD1         | PD0   |
|        |                                                                 | Reset:          |        |                       |        | Undefined | after reset |        | <u>I</u>    |       |
| \$000B | Timer Compare Force<br>Register (CFORC)                         | Read:<br>Write: | FOC1   | FOC2                  | FOC3   | FOC4      | FOC5        | 0      | 0           | 0     |
|        | See page 201.                                                   | Reset:          | 0      | 0                     | 0      | 0         | 0           | 0      | 0           | 0     |
| \$000C | Output Compare 1<br>Mask Register (OC1M)                        | Read:<br>Write: | OC1M7  | OC1M6                 | OC1M5  | OC1M4     | OC1M3       | 0      | 0           | 0     |
|        | See page 202.                                                   | Reset:          | 0      | 0                     | 0      | 0         | 0           | 0      | 0           | 0     |
| \$000D | Output Compare 1 Data<br>Register (OC1D)                        | Read:<br>Write: | OC1D7  | OC1D6                 | OC1D5  | OC1D4     | OC1D3       | 0      | 0           | 0     |
|        | See page 202.                                                   | Reset:          | 0      | 0                     | 0      | 0         | 0           | 0      | 0           | 0     |
|        | Timer Counter Register<br>High (TCNTH)<br>See page 188.         | Read:           | Bit 15 | Bit 14                | Bit 13 | Bit 12    | Bit 11      | Bit 10 | Bit 9       | Bit 8 |
| \$000E |                                                                 | Write:          |        |                       |        |           |             |        |             |       |
|        |                                                                 | Reset:          | 0      | 0                     | 0      | 0         | 0           | 0      | 0           | 0     |
|        | Timer Counter Register<br>Low (TCNTL)<br>See page 188.          | Read:           | Bit 7  | Bit 6                 | Bit 5  | Bit 4     | Bit 3       | Bit 2  | Bit 1       | Bit 0 |
| \$000F |                                                                 | Write:          |        |                       |        |           |             |        |             |       |
|        |                                                                 | Reset:          | 0      | 0                     | 0      | 0         | 0           | 0      | 0           | 0     |
| \$0010 | Timer Input Capture 1<br>Register High (TIC1H)<br>See page 192. | Read:<br>Write: | Bit 15 | Bit 14                | Bit 13 | Bit 12    | Bit 11      | Bit 10 | Bit 9       | Bit 8 |
|        |                                                                 | Reset:          |        |                       |        | Undefined | after reset |        |             |       |
| \$0011 | Timer Input Capture 1<br>Register Low (TIC1L)<br>See page 192.  | Read:<br>Write: | Bit 7  | Bit 6                 | Bit 5  | Bit 4     | Bit 3       | Bit 2  | Bit 1       | Bit 0 |
|        |                                                                 | Reset:          |        |                       |        | Undefined | after reset |        |             |       |
| \$0012 | Timer Input Capture 2<br>Register High (TIC2H)                  | Read:<br>Write: | Bit 15 | Bit 14                | Bit 13 | Bit 12    | Bit 11      | Bit 10 | Bit 9       | Bit 8 |
|        | See page 192.                                                   | Reset:          |        |                       |        | Undefined | after reset |        |             |       |
| \$0013 | Timer Input Capture 2<br>Register Low (TIC2L)                   | Read:<br>Write: | Bit 7  | Bit 6                 | Bit 5  | Bit 4     | Bit 3       | Bit 2  | Bit 1       | Bit 0 |
|        | See page 192.                                                   | Reset:          |        |                       |        | Undefined | after reset |        |             |       |
| \$0014 | Timer Input Capture 3<br>Register High (TIC3H)                  | Read:<br>Write: | Bit 15 | Bit 14                | Bit 13 | Bit 12    | Bit 11      | Bit 10 | Bit 9       | Bit 8 |
|        | See page 192.                                                   | Reset:          |        | Undefined after reset |        |           |             |        |             |       |
|        |                                                                 |                 |        | = Unimplen            | nented | R         | = Reserved  |        | U = Undefin | ned   |

Figure 4-1. Register and Control Bit Assignments (Sheet 2 of 11)

| Addr.  | Register Name                                                       |                 | Bit 7  | 6                     | 5      | 4            | 3      | 2      | 1             | Bit 0 |  |  |  |
|--------|---------------------------------------------------------------------|-----------------|--------|-----------------------|--------|--------------|--------|--------|---------------|-------|--|--|--|
| \$0015 | Timer Input Capture 3<br>Register Low (TIC3L)                       | Read:<br>Write: | Bit 7  | Bit 6                 | Bit 5  | Bit 4        | Bit 3  | Bit 2  | Bit 1         | Bit 0 |  |  |  |
|        | See page 192.                                                       | Reset:          |        | Undefined after reset |        |              |        |        |               |       |  |  |  |
| \$0016 | Timer Output<br>Compare 1 High<br>Register (TOC1H)                  | Read:<br>Write: | Bit 15 | Bit 14                | Bit 13 | Bit 12       | Bit 11 | Bit 10 | Bit 9         | Bit 8 |  |  |  |
|        | See page 197.                                                       | Reset:          | 1      | 1                     | 1      | 1            | 1      | 1      | 1             | 1     |  |  |  |
| \$0017 | Timer Output<br>Compare 1 Low<br>Register (TOC1L)                   | Read:<br>Write: | Bit 7  | Bit 6                 | Bit 5  | Bit 4        | Bit 3  | Bit 2  | Bit 1         | Bit 0 |  |  |  |
|        | See page 197.                                                       | Reset:          | 1      | 1                     | 1      | 1            | 1      | 1      | 1             | 1     |  |  |  |
|        | Timer Output<br>Compare 2 High<br>Register (TOC2H)                  | Read:<br>Write: | Bit 15 | Bit 14                | Bit 13 | Bit 12       | Bit 11 | Bit 10 | Bit 9         | Bit 8 |  |  |  |
|        | See page 197.                                                       | Reset:          | 1      | 1                     | 1      | 1            | 1      | 1      | 1             | 1     |  |  |  |
| \$0019 | Timer Output<br>Compare 2 Low<br>Register (TOC2L)<br>See page 197.  | Read:<br>Write: | Bit 7  | Bit 6                 | Bit 5  | Bit 4        | Bit 3  | Bit 2  | Bit 1         | Bit 0 |  |  |  |
|        |                                                                     | Reset:          | 1      | 1                     | 1      | 1            | 1      | 1      | 1             | 1     |  |  |  |
| \$001A | Timer Output<br>Compare 3 High<br>Register (TOC3H)<br>See page 197. | Read:<br>Write: | Bit 15 | Bit 14                | Bit 13 | Bit 12       | Bit 11 | Bit 10 | Bit 9         | Bit 8 |  |  |  |
|        |                                                                     | Reset:          | 1      | 1                     | 1      | 1            | 1      | 1      | 1             | 1     |  |  |  |
| \$001B | Timer Output<br>Compare 3 Low<br>Register (TOC3L)                   | Read:<br>Write: | Bit 7  | Bit 6                 | Bit 5  | Bit 4        | Bit 3  | Bit 2  | Bit 1         | Bit 0 |  |  |  |
|        | See page 197.                                                       | Reset:          | 1      | 1                     | 1      | 1            | 1      | 1      | 1             | 1     |  |  |  |
| \$001C | Timer Output<br>Compare 4 High<br>Register (TOC4H)<br>See page 197. | Read:<br>Write: | Bit 15 | Bit 14                | Bit 13 | Bit 12       | Bit 11 | Bit 10 | Bit 9         | Bit 8 |  |  |  |
|        |                                                                     | Reset:          | 1      | 1                     | 1      | 1            | 1      | 1      | 1             | 1     |  |  |  |
| \$001D | Timer Output<br>Compare 4 Low<br>Register (TOC4L)                   | Read:<br>Write: | Bit 7  | Bit 6                 | Bit 5  | Bit 4        | Bit 3  | Bit 2  | Bit 1         | Bit 0 |  |  |  |
|        | See page 197.                                                       | Reset:          | 1      | 1                     | 1      | 1            | 1      | 1      | 1             | 1     |  |  |  |
|        |                                                                     |                 |        | = Unimplemented       |        | R = Reserved |        |        | U = Undefined |       |  |  |  |

Figure 4-1. Register and Control Bit Assignments (Sheet 3 of 11)

# **Operating Modes and On-Chip Memory**

| Addr.          | Register Name                                                      |                 | Bit 7         | 6            | 5      | 4         | 3           | 2      | 1                  | Bit 0              |
|----------------|--------------------------------------------------------------------|-----------------|---------------|--------------|--------|-----------|-------------|--------|--------------------|--------------------|
| \$001E         | Timer Input Capture 4/<br>Output Compare 5 Reg.<br>High (TI4H/O5H) | Read:<br>Write: | Bit 15        | Bit 14       | Bit 13 | Bit 12    | Bit 11      | Bit 10 | Bit 9              | Bit 8              |
|                | See page 199.                                                      | Reset:          | 1             | 1            | 1      | 1         | 1           | 1      | 1                  | 1                  |
| \$001F         | Timer Input Capture 4/<br>Output Compare 5 Reg.<br>Low (TI4L/O5L)  | Read:<br>Write: | Bit 7         | Bit 6        | Bit 5  | Bit 4     | Bit 3       | Bit 2  | Bit 1              | Bit 0              |
|                | See page 199.                                                      | Reset:          | 1             | 1            | 1      | 1         | 1           | 1      | 1                  | 1                  |
| \$0020         | Timer Control 1<br>Register (TCTL1)                                | Read:<br>Write: | OM2           | OL2          | OM3    | OL3       | OM4         | OL4    | OM5                | OL5                |
|                | See page 200.                                                      | Reset:          | 0             | 0            | 0      | 0         | 0           | 0      | 0                  | 0                  |
| \$0021         | Timer Control 2<br>Register (TCTL2)                                | Read:<br>Write: | EDG4B         | EDG4A        | EDG1B  | EDG1A     | EDG2B       | EDG2A  | EDG3B              | EDG3A              |
|                | See page 195.                                                      | Reset:          | 0             | 0            | 0      | 0         | 0           | 0      | 0                  | 0                  |
| \$0022         | Timer Interrupt Mask 1<br>Register (TMSK1)                         | Read:<br>Write: | OC1I          | OC2I         | OC3I   | OC4I      | I4/O5I      | IC1I   | IC2I               | IC3I               |
|                | See page 200.                                                      | Reset:          | 0             | 0            | 0      | 0         | 0           | 0      | 0                  | 0                  |
| \$0023         | Timer Interrupt Flag 1<br>Register (TFLG1)                         | Read:<br>Write: | OC1F          | OC2F         | OC3F   | OC4F      | 14/O5F      | IC1F   | IC2F               | IC3F               |
|                | See page 199.                                                      | Reset:          | 0             | 0            | 0      | 0         | 0           | 0      | 0                  | 0                  |
| \$0024         | Timer Interrupt Mask 2<br>Register (TMSK2)                         | Read:<br>Write: | TOI           | RTII         | PAOVI  | PAII      | 0           | 0      | PR1 <sup>(1)</sup> | PR0 <sup>(1)</sup> |
|                | See page 209.                                                      | Reset:          | 0             | 0            | 0      | 0         | 0           | 0      | 0                  | 0                  |
| 1. Can         | be written only once in firs                                       | t 64 cycle      | es out of res | et in normal | modes  |           |             |        |                    |                    |
|                |                                                                    | Read:           |               |              |        |           |             |        |                    |                    |
| \$0025         | Timer Interrupt Flag 2<br>(TFLG2)<br>See page 209.                 | Write:          | TOF           | RTIF         | PAOVF  | PAIF      | 0           | 0      | 0                  | 0                  |
| +00 <u>-</u> 0 |                                                                    | Reset:          | 0             | 0            | 0      | 0         | 0           | 0      | 0                  | 0                  |
|                | Pulse Accumulator                                                  | Read:           |               |              | DAMOD  | DEDGE     |             | 14/05  | DTD1               | DTD0               |
| \$0026         | Control Register<br>(PACTL)                                        | Write:          | 0             | PAEN         | PAMOD  | PEDGE     | 0           | I4/O5  | RTR1               | RTR0               |
|                | See page 210.                                                      | Reset:          | 0             | 0            | 0      | 0         | 0           | 0      | 0                  | 0                  |
| \$0027         | Pulse Accumulator Count Register                                   | Read:<br>Write: | Bit 7         | Bit 6        | Bit 5  | Bit 4     | Bit 3       | Bit 2  | Bit 1              | Bit 0              |
|                | (PACNT)<br>See page 208.                                           | Reset:          |               |              |        | Undefined | after reset |        |                    |                    |
|                |                                                                    |                 |               | = Unimplen   | nented | R         | = Reserved  |        | U = Undefir        | ned                |

Figure 4-1. Register and Control Bit Assignments (Sheet 4 of 11)



Figure 4-1. Register and Control Bit Assignments (Sheet 5 of 11)

### **Operating Modes and On-Chip Memory**



Figure 4-1. Register and Control Bit Assignments (Sheet 6 of 11)

| Addr.                                                                       | Register Name                                                               |                 | Bit 7 | 6          | 5      | 4     | 3          | 2     | 1           | Bit 0    |
|-----------------------------------------------------------------------------|-----------------------------------------------------------------------------|-----------------|-------|------------|--------|-------|------------|-------|-------------|----------|
| \$003A                                                                      | Arm/Reset COP Timer<br>Circuitry Register<br>(COPRST)                       | Read:<br>Write: | Bit 7 | Bit 6      | Bit 5  | Bit 4 | Bit 3      | Bit 2 | Bit 1       | Bit 0    |
|                                                                             | See page 110.                                                               | Reset:          | 0     | 0          | 0      | 0     | 0          | 0     | 0           | 0        |
| \$003B                                                                      | EEPROM Programming<br>Control Register<br>(PPROG)                           | Read:<br>Write: | ODD   | EVEN       | LVPI   | ВҮТЕ  | ROW        | ERASE | EELAT       | EEPGM    |
|                                                                             | See page 91.                                                                | Reset:          | 0     | 0          | 0      | 0     | 0          | 0     | 0           | 0        |
| \$003C                                                                      | Highest Priority I-Bit<br>Interrupt and Misc.<br>Register (HPRIO)           | Read:<br>Write: | RBOOT | SMOD       | MDA    | PSEL4 | PSEL3      | PSEL2 | PSEL1       | PSEL0    |
|                                                                             | See pages 80, 123                                                           | Reset:          | _     | _          | _      | 0     | 0          | 1     | 1           | 0        |
| \$003D                                                                      | RAM and I/O Mapping<br>Register (INIT) <sup>(1)</sup>                       | Read:<br>Write: | RAM3  | RAM2       | RAM1   | RAM0  | REG3       | REG2  | REG1        | REG0     |
|                                                                             | See page 84.                                                                | Reset:          | 0     | 0          | 0      | 0     | 0          | 0     | 0           | 0        |
| 1. Can only be written once in first 64 cycles out of reset in normal modes |                                                                             |                 |       |            |        |       |            |       |             |          |
|                                                                             |                                                                             | Dood.           |       |            |        |       |            |       |             |          |
| \$003E                                                                      | Test 1 Register<br>(TEST1)                                                  | Read:<br>Write: | TILOP | 0          | OCCR   | СВҮР  | DISR       | FCM   | FCOP        | 0        |
|                                                                             |                                                                             | Reset:          | 0     | 0          | 0      | 0     | 0          | 0     | 0           | 0        |
| \$003F                                                                      | System Configuration<br>Register (CONFIG)<br>See pages 88, 101,<br>108, 147 | Read:<br>Write: | ROMAD | 1          | CLKX   | PAREN | NOSEC      | NOCOP | ROMON       | EEON     |
|                                                                             |                                                                             | Reset:          | _     | 1          | _      | _     | 1          | _     | _           | _        |
| \$0040                                                                      | Reserved                                                                    |                 | R     | R          | R      | R     | R          | R     | R           | R        |
| to                                                                          |                                                                             | •               |       |            |        |       |            |       |             | <u> </u> |
| \$0055                                                                      | Reserved                                                                    |                 | R     | R          | R      | R     | R          | R     | R           | R        |
|                                                                             |                                                                             |                 |       |            |        |       |            |       |             |          |
| \$0056                                                                      | Memory Mapping Size<br>Register (MMSIZ) <sup>(2)</sup>                      | Read:<br>Write: | MXGS2 | MXGS1      | W2SZ1  | W2SZ0 | 0          | 0     | W1SZ1       | W1SZ0    |
|                                                                             | See pages 235, 243                                                          | Reset:          | 0     | 0          | 0      | 0     | 0          | 0     | 0           | 0        |
| \$0057                                                                      | Memory Mapping<br>Window Base Register<br>(MMWBR) <sup>(2)</sup>            | Read:<br>Write: | W2A15 | W2A14      | W2A13  | 0     | W1A15      | W1A14 | W1A13       | 0        |
|                                                                             | See page 236.                                                               | Reset:          | 0     | 0          | 0      | 0     | 0          | 0     | 0           | 0        |
| 2. Not a                                                                    | vailable on M68HC11KS                                                       | devices         |       |            |        |       |            |       |             |          |
|                                                                             |                                                                             | ı               |       | 1          |        |       | 1 _        |       |             |          |
|                                                                             |                                                                             |                 |       | = Unimplem | nented | R     | = Reserved |       | U = Undefin | ied      |

Figure 4-1. Register and Control Bit Assignments (Sheet 7 of 11)

# **Operating Modes and On-Chip Memory**

| Addr.    | Register Name                                                                                 |                 | Bit 7 | 6               | 5     | 4     | 3            | 2     | 1             | Bit 0 |  |
|----------|-----------------------------------------------------------------------------------------------|-----------------|-------|-----------------|-------|-------|--------------|-------|---------------|-------|--|
| \$0058   | Memory Mapping<br>Window 1 Control<br>Register (MM1CR) <sup>(1)</sup>                         | Read:<br>Write: | 0     | X1A18           | X1A17 | X1A16 | X1A15        | X1A14 | X1A13         | 0     |  |
|          | See page 237.                                                                                 | Reset:          | 0     | 0               | 0     | 0     | 0            | 0     | 0             | 0     |  |
| \$0059   | Memory Mapping<br>Window 2 Control                                                            | Read:<br>Write: | 0     | X2A18           | X2A17 | X2A16 | X2A15        | X2A14 | X2A13         | 0     |  |
|          | Register (MM2CR) <sup>(1)</sup><br>See page 237.                                              | Reset:          | 0     | 0               | 0     | 0     | 0            | 0     | 0             | 0     |  |
| \$005A   | Chip Select Clock<br>Stretch Register<br>(CSCSTR) <sup>(1)</sup>                              | Read:<br>Write: | IOSA  | IOSB            | GP1SA | GP1SB | GP2SA        | GP2SB | PCSA          | PCSB  |  |
|          | See page 249.                                                                                 | Reset:          | 0     | 0               | 0     | 0     | 0            | 0     | 0             | 0     |  |
| \$005B   | Chip Select Control<br>Register (CSCTL) <sup>(1)</sup>                                        | Read:<br>Write: | IOEN  | IOPL            | IOCSA | IOSZ  | GCSPR        | PCSEN | PCSZA         | PCSZB |  |
|          | See pages 240, 241                                                                            | Reset:          | 0     | 0               | 0     | 0     | 0            | 1     | 0             | 0     |  |
| \$005C   | General-Purpose Chip<br>Select 1 Address<br>Register (GPCS1A) <sup>(1)</sup><br>See page 243. | Read:<br>Write: | G1A18 | G1A17           | G1A16 | G1A15 | G1A14        | G1A13 | G1A12         | G1A11 |  |
|          |                                                                                               | Reset:          | 0     | 0               | 0     | 0     | 0            | 0     | 0             | 0     |  |
| \$005D   | General-Purpose Chip<br>Select 1 Control<br>Register (GPCS1C) <sup>(1)</sup>                  | Read:<br>Write: | G1DG2 | G1DPC           | G1POL | G1AV  | G1SZA        | G1SZB | G1SZC         | G1SZD |  |
|          | See pages 244, 247                                                                            | Reset:          | 0     | 0               | 0     | 0     | 0            | 0     | 0             | 0     |  |
| \$005E   | General-Purpose Chip<br>Select 2 Address<br>Register (GPCS2A) <sup>(1)</sup><br>See page 245. | Read:<br>Write: | G2A18 | G2A17           | G2A16 | G2A15 | G2A14        | G2A13 | G2A12         | G2A11 |  |
|          |                                                                                               | Reset:          | 0     | 0               | 0     | 0     | 0            | 0     | 0             | 0     |  |
| \$005F   | General-Purpose Chip<br>Select 2 Control<br>Register (GPCS2C) <sup>(1)</sup>                  | Read:<br>Write: | 0     | G2DPC           | G2POL | G2AV  | G2SZA        | G2SZB | G2SZC         | G2SZD |  |
|          | See pages 245, 247                                                                            | Reset:          | 0     | 0               | 0     | 0     | 0            | 0     | 0             | 0     |  |
| 1. Not a | vailable on M68HC11KS (                                                                       | devices         |       |                 |       |       |              |       |               |       |  |
| \$0060   | Pulse Width Modulation<br>Timer Clock Select<br>Register (PWCLK)                              | Read:<br>Write: | CON34 | CON12           | PCKA2 | PCKA1 | 0            | PCKB3 | PCKB2         | PCKB1 |  |
|          | See page 213.                                                                                 | Reset:          | 0     | 0               | 0     | 0     | 0            | 0     | 0             | 0     |  |
| \$0061   | Pulse Width Modulation<br>Timer Polarity Register<br>(PWPOL)                                  | Read:<br>Write: | PCLK4 | PCLK3           | PCLK2 | PCLK1 | PPOL4        | PPOL3 | PPOL2         | PPOL1 |  |
|          | See page 215.                                                                                 | Reset:          | 0     | 0               | 0     | 0     | 0            | 0     | 0             | 0     |  |
|          |                                                                                               |                 |       | = Unimplemented |       | R     | R = Reserved |       | U = Undefined |       |  |

Figure 4-1. Register and Control Bit Assignments (Sheet 8 of 11)

| Addr.  | Register Name                                                  |                 | Bit 7 | 6          | 5     | 4     | 3          | 2     | 1           | Bit 0 |
|--------|----------------------------------------------------------------|-----------------|-------|------------|-------|-------|------------|-------|-------------|-------|
| \$0062 | Pulse Width Modulation<br>Timer Prescaler<br>Register (PWSCAL) | Read:<br>Write: | Bit 7 | Bit 6      | Bit 5 | Bit 4 | Bit 3      | Bit 2 | Bit 1       | Bit 0 |
|        | See page 215.                                                  | Reset:          | 0     | 0          | 0     | 0     | 0          | 0     | 0           | 0     |
| \$0063 | Pulse Width Modulation<br>Timer Enable Register<br>(PWEN)      | Read:<br>Write: | TPWSL | DISCP      | 0     | 0     | PWEN4      | PWEN3 | PWEN2       | PWEN1 |
|        | See page 216.                                                  | Reset:          | 0     | 0          | 0     | 0     | 0          | 0     | 0           | 0     |
| \$0064 | Pulse Width Modulation<br>Timer Counter 1<br>Register (PWCNT1) | Read:<br>Write: | Bit 7 | Bit 6      | Bit 5 | Bit 4 | Bit 3      | Bit 2 | Bit 1       | Bit 0 |
|        | See page 217.                                                  | Reset:          | 0     | 0          | 0     | 0     | 0          | 0     | 0           | 0     |
| \$0065 | Pulse Width Modulation<br>Timer Counter 2<br>Register (PWCNT2) | Read:<br>Write: | Bit 7 | Bit 6      | Bit 5 | Bit 4 | Bit 3      | Bit 2 | Bit 1       | Bit 0 |
|        | See page 217.                                                  | Reset:          | 0     | 0          | 0     | 0     | 0          | 0     | 0           | 0     |
| \$0066 | Pulse Width Modulation Timer Counter 3 \$0066                  | Read:<br>Write: | Bit 7 | Bit 6      | Bit 5 | Bit 4 | Bit 3      | Bit 2 | Bit 1       | Bit 0 |
|        | Register (PWCNT3) See page 217.                                | Reset:          | 0     | 0          | 0     | 0     | 0          | 0     | 0           | 0     |
| \$0067 | Pulse Width Modulation<br>Timer Counter 4<br>Register (PWCNT4) | Read:<br>Write: | Bit 7 | Bit 6      | Bit 5 | Bit 4 | Bit 3      | Bit 2 | Bit 1       | Bit 0 |
|        | See page 217.                                                  | Reset:          | 0     | 0          | 0     | 0     | 0          | 0     | 0           | 0     |
| \$0068 | Pulse Width Modulation<br>Timer Period 1 Register<br>(PWPER1)  | Read:<br>Write: | Bit 7 | Bit 6      | Bit 5 | Bit 4 | Bit 3      | Bit 2 | Bit 1       | Bit 0 |
|        | See page 218.                                                  | Reset:          | 0     | 0          | 0     | 0     | 0          | 0     | 0           | 0     |
| \$0069 | Pulse Width Modulation<br>Timer Period 2 Register<br>(PWPER2)  | Read:<br>Write: | Bit 7 | Bit 6      | Bit 5 | Bit 4 | Bit 3      | Bit 2 | Bit 1       | Bit 0 |
|        | See page 218.                                                  | Reset:          | 0     | 0          | 0     | 0     | 0          | 0     | 0           | 0     |
| \$006A | Pulse Width Modulation<br>Timer Period 3 Register<br>(PWPER3)  | Read:<br>Write: | Bit 7 | Bit 6      | Bit 5 | Bit 4 | Bit 3      | Bit 2 | Bit 1       | Bit 0 |
|        | See page 218.                                                  | Reset:          | 0     | 0          | 0     | 0     | 0          | 0     | 0           | 0     |
| \$006B | Pulse Width Modulation<br>Timer Period 4 Register<br>(PWPER4)  | Read:<br>Write: | Bit 7 | Bit 6      | Bit 5 | Bit 4 | Bit 3      | Bit 2 | Bit 1       | Bit 0 |
|        | See page 218.                                                  | Reset:          | 0     | 0          | 0     | 0     | 0          | 0     | 0           | 0     |
|        |                                                                |                 |       | = Unimplem | ented | R     | = Reserved |       | U = Undefir | ned   |

Figure 4-1. Register and Control Bit Assignments (Sheet 9 of 11)

| Addr.  | Register Name                                                     |                 | Bit 7 | 6          | 5      | 4     | 3           | 2     | 1           | Bit 0 |
|--------|-------------------------------------------------------------------|-----------------|-------|------------|--------|-------|-------------|-------|-------------|-------|
| \$006C | Pulse Width Modulation Timer Duty Cycle 1                         | Read:<br>Write: | Bit 7 | Bit 6      | Bit 5  | Bit 4 | Bit 3       | Bit 2 | Bit 1       | Bit 0 |
|        | Register (PWDTY1) See page 219.                                   | Reset:          | 0     | 0          | 0      | 0     | 0           | 0     | 0           | 0     |
| \$006D | Pulse Width Modulation<br>Timer Duty Cycle 2<br>Register (PWDTY2) | Read:<br>Write: | Bit 7 | Bit 6      | Bit 5  | Bit 4 | Bit 3       | Bit 2 | Bit 1       | Bit 0 |
|        | See page 219.                                                     | Reset:          | 0     | 0          | 0      | 0     | 0           | 0     | 0           | 0     |
| \$006E | Pulse Width Modulation<br>Timer Duty Cycle 3<br>Register (PWDTY3) | Read:<br>Write: | Bit 7 | Bit 6      | Bit 5  | Bit 4 | Bit 3       | Bit 2 | Bit 1       | Bit 0 |
|        | See page 219.                                                     | Reset:          | 0     | 0          | 0      | 0     | 0           | 0     | 0           | 0     |
| \$006F | Pulse Width Modulation<br>Timer Duty Cycle 4<br>Register (PWDTY4) | Read:<br>Write: | Bit 7 | Bit 6      | Bit 5  | Bit 4 | Bit 3       | Bit 2 | Bit 1       | Bit 0 |
|        | See page 219.                                                     | Reset:          | 0     | 0          | 0      | 0     | 0           | 0     | 0           | 0     |
| \$0070 | SCI Baud Rate Control<br>Register High (SCBDH)                    | Read:<br>Write: | BTST  | BSPL       | 0      | SBR12 | SBR11       | SBR10 | SBR9        | SBR8  |
|        | See page 158.                                                     | Reset:          | 0     | 0          | 0      | 0     | 0           | 0     | 0           | 0     |
| \$0071 | SCI Baud Rate Control<br>Register Low (SCBDL)                     | Read:<br>Write: | SBR7  | SBR6       | SBR5   | SBR4  | SBR3        | SBR2  | SBR1        | SBR0  |
|        | See page 158.                                                     | Reset:          | 0     | 0          | 0      | 0     | 0           | 1     | 0           | 0     |
| \$0072 | SCI Control Register 1<br>(SCCR1)                                 | Read:<br>Write: | LOOPS | WOMS       | 0      | M     | WAKE        | ILT   | PE          | PT    |
|        | See page 160.                                                     | Reset:          | U     | U          | 0      | 0     | 0           | 0     | 0           | 0     |
| \$0073 | SCI Control Register 2<br>(SCCR2)                                 | Read:<br>Write: | TIE   | TCIE       | RIE    | ILIE  | TE          | RE    | RWU         | SBK   |
|        | See page 161.                                                     | Reset:          | 0     | 0          | 0      | 0     | 0           | 0     | 0           | 0     |
| \$0074 | SCI Status Register 1<br>(SCSR1)                                  | Read:<br>Write: | TDRE  | TC         | RDRF   | IDLE  | OR          | NF    | FE          | PF    |
|        | See page 162.                                                     | Reset:          | 0     | 0          | 0      | 0     | 0           | 0     | 0           | 0     |
| \$0075 | SCI Status Register 2<br>(SCSR2)                                  | Read:<br>Write: | 0     | 0          | 0      | 0     | 0           | 0     | 0           | RAF   |
|        | See page 164.                                                     | Reset:          | 1     | 1          | 0      | 0     | 0           | 0     | 0           | 0     |
| \$0076 | SCI Data Register<br>(SCDR)                                       | Read:<br>Write: | R8    | Т8         | 0      | 0     | 0           | 0     | 0           | 0     |
|        | See page 165.                                                     | Reset:          |       |            |        |       | after reset |       |             |       |
|        |                                                                   |                 |       | = Unimplen | nented | R     | = Reserved  |       | U = Undefir | ned   |

Figure 4-1. Register and Control Bit Assignments (Sheet 10 of 11)

| Addr.                                 | Register Name                            | _               | Bit 7                     | 6                   | 5                   | 4                   | 3                   | 2                   | 1                   | Bit 0               |
|---------------------------------------|------------------------------------------|-----------------|---------------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|---------------------|
| \$0077                                | SCI Data Register<br>(SCDR)              | Read:<br>Write: | R7/T7                     | R6/T6               | R5/T5               | R4/T4               | R3/T3               | R2/T2               | R1/T1               | R0/T0               |
|                                       | See page 165.                            | Reset:          |                           |                     |                     | Undefined           | after reset         |                     |                     |                     |
| \$0078                                | Reserved                                 |                 | R                         | R                   | R                   | R                   | R                   | R                   | R                   | R                   |
| to                                    |                                          | •               |                           |                     |                     |                     |                     |                     |                     |                     |
| \$007B                                | Reserved                                 |                 | R                         | R                   | R                   | R                   | R                   | R                   | R                   | R                   |
|                                       |                                          | •               |                           |                     |                     |                     |                     |                     |                     |                     |
| \$007C                                | Port H Data Register<br>(PORTH)          | Read:<br>Write: | PH7 <sup>(1)</sup>        | PH6 <sup>(1)</sup>  | PH5 <sup>(1)</sup>  | PH4 <sup>(1)</sup>  | PH3                 | PH2                 | PH1                 | PH0                 |
|                                       | See page 146.                            | Reset:          | et: Undefined after reset |                     |                     |                     |                     |                     |                     |                     |
| \$007D                                | Port H Data Direction<br>Register (DDRH) | Read:<br>Write: | DDH7 <sup>(1)</sup>       | DDH6 <sup>(1)</sup> | DDH5 <sup>(1)</sup> | DDH4 <sup>(1)</sup> | DDH3                | DDH2                | DDH1                | DDH0                |
|                                       | See page 146.                            | Reset:          | 0                         | 0                   | 0                   | 0                   | 0                   | 0                   | 0                   | 0                   |
| \$007E                                | Port G Data Register<br>(PORTG)          | Read:<br>Write: | PG7                       | PG6 <sup>(1)</sup>  | PG5 <sup>(1)</sup>  | PG4 <sup>(1)</sup>  | PG3 <sup>(1)</sup>  | PG2 <sup>(1)</sup>  | PG1 <sup>(1)</sup>  | PG0 <sup>(1)</sup>  |
|                                       | See page 145.                            | Reset:          |                           |                     |                     | Undefined           | after reset         |                     |                     |                     |
| \$007F                                | Port G Data Direction<br>Register (DDRG) | Read:<br>Write: | DDG7                      | DDG6 <sup>(1)</sup> | DDG5 <sup>(1)</sup> | DDG4 <sup>(1)</sup> | DDG3 <sup>(1)</sup> | DDG2 <sup>(1)</sup> | DDG1 <sup>(1)</sup> | DDG0 <sup>(1)</sup> |
|                                       | See page 145.                            | Reset:          | 0                         | 0                   | 0                   | 0                   | 0                   | 0                   | 0                   | 0                   |
| 1. Not available on M68HC11KS devices |                                          |                 |                           |                     |                     |                     |                     |                     |                     |                     |
|                                       |                                          |                 |                           | = Unimplen          | nented              | R                   | = Reserved          |                     | U = Undefir         | ned                 |

Figure 4-1. Register and Control Bit Assignments (Sheet 11 of 11)

# 4.4 System Initialization

Registers and bits that control initialization and the basic operation of the MCU are protected against writes except under special circumstances. **Table 4-1** lists registers that can be written only once after reset or that must be written within the first 64 cycles after reset.

**Table 4-1. Registers with Limited Write Access** 

| Operating<br>Mode | Register<br>Address | Register Name                                              | Must be Written in First 64 Cycles   | Write<br>Anytime         |
|-------------------|---------------------|------------------------------------------------------------|--------------------------------------|--------------------------|
| SMOD = 0          | \$x024              | Timer interrupt mask 2 (TMSK2)                             | Bits [1:0], once only                | Bits [7:2]               |
|                   | \$x035              | Block protect register (BPROT)                             | Clear bits, once only                | Set bits only            |
|                   | \$x037              | EEPROM mapping register (INIT2)                            | No, bits [7:4], once only            | _                        |
|                   | \$x038              | System configuration options 2 register (OPT2)             | No, bit 4, once only                 | See OPT2<br>description  |
|                   | \$x039              | System configuration options (OPTION)                      | Bits [5:4], bits [2:0],<br>once only | Bits [7:6], bit 3        |
|                   | \$x03C              | Highest priority I-bit interrupt and miscellaneous (HPRIO) | _                                    | See HPRIO description    |
|                   | \$x03D              | RAM and I/O map register (INIT)                            | Yes, once only                       | _                        |
| SMOD = 1          | \$x024              | Timer interrupt mask 2 (TMSK2)                             | _                                    | All, set or clear        |
|                   | \$x035              | Block protect register (BPROT)                             | _                                    | All, set or clear        |
|                   | \$x037              | EEPROM mapping register (INIT2)                            | _                                    | Bits [7:4]               |
|                   | \$x038              | System configuration options 2 register (OPT2)             | _                                    | See OPT2<br>description  |
|                   | \$x039              | System configuration options (OPTION)                      | _                                    | All, set or clear        |
|                   | \$x03C              | Highest priority I-bit interrupt and miscellaneous (HPRIO) | _                                    | See HPRIO<br>description |
|                   | \$x03D              | RAM and I/O map register (INIT)                            | _                                    | All, set or clear        |
|                   | \$x03F              | System configuration register (CONFIG)                     | _                                    | See CONFIG description   |

## 4.5 Operating Modes

The two normal modes of operation in the M68HC11K Family are:

- Single-chip mode All port pins available for input/output (I/O); only on-board memory accessible
- Expanded mode Access to internal and external memory; 25
   I/O pins used for interface

The two special modes of operation are:

- Bootstrap mode A variation of single-chip mode; executes a bootloader program in an internal bootstrap read-only memory (ROM)
- Test mode A variation of the expanded mode used in production testing; allows privileged access to internal resources

The logic levels applied at reset to input pins MODA and MODB determine the operating mode. See **4.5.5 Mode Selection**.

### 4.5.1 Single-Chip Mode

In single-chip mode, the MCU functions as a self-contained microcontroller. In this mode, all address and data activity occurs within the MCU. Ports B, C, F, G, and H are available for general-purpose I/O because the external address and data buses are not required.

### 4.5.2 Expanded Mode

In expanded mode, the MCU uses ports B, C, F, and G to access a 64-Kbyte address space. This includes:

- The same on-chip memory addresses used in single-chip mode
- External memory
- Peripheral devices

Port B provides the high-order address byte (Addr[15:8]), port F the low-order address byte (Addr[7:0]), port C the data bus (Data[7:0]), and port G pin 7 the read/write line (R/W) which controls direction of data flow.

Additionally, the E clock output can be used to synchronize external decoders for enable signals.

Expanded mode also enables these two special features available only on the K4 Family devices:

- 1. Memory expansion uses port G[5:0] to increase the available external address space to 1 Mbyte.
- 2. Four chip-select lines on port H[7:4] simplify selection of external memory devices.

Both of these features are described in **Section 11. Memory Expansion** and **Chip Selects**.

#### 4.5.3 Bootstrap Mode

Resetting the MCU in special bootstrap mode selects a reset vector to a special ROM bootloader program at addresses \$BE00–\$BFFF. The bootloader program is used to download code, such as programming algorithms, into on-chip RAM through the SCI. To do this:

- Send a synchronization character (see Table 4-2) to the SCI receiver at the specified baud rate.
- 2. Download up to 768 bytes (1 Kbyte for KS2) of program data, which the CPU places into RAM starting at \$0080 and also echoes back on the TxD signal. The bootloader program ends the download after the RAM is full or when the received data line is idle for at least four character times. See **Table 4-2**.

When loading is complete, the MCU jumps to location \$0080 and begins executing the code. Interrupt vectors are directed to RAM, which allows the use of interrupts through a jump table. The SCI transmitter requires an external pullup resistor since it is part of port D, which the bootloader configures for wired-OR operation.

**Table 4-2. Synchronization Character Selection** 

| Synchronization | Timeout        | Baud  | Rate at E Clocks |        |  |
|-----------------|----------------|-------|------------------|--------|--|
| Character       | Delay          | 2 MHz | 3 MHz            | 4 MHz  |  |
| \$FF            | 4 characters   | 7812  | 11,718           | 15,624 |  |
| \$FF            | 4 characters   | 1200  | 1800             | 2400   |  |
| \$F0            | 4.9 characters | 9600  | 14,400           | 19,200 |  |
| \$FD            | 13 characters  | 3906  | 5859             | 7812   |  |

For a detailed description of bootstrap mode, refer to the Motorola application note entitled *MC68HC11 Bootstrap Mode*, document order number AN1060/D.

#### 4.5.4 Special Test Mode

Special test mode, a variation of the expanded mode, is used primarily during Motorola's internal production testing. However, for those devices containing EPROM, it can be used to program the EPROM for program calibration data in EEPROM and support emulation and debugging during development.

For more detailed information, refer to **4.7.1 Programming the EPROM** with Downloaded Data.

#### 4.5.5 Mode Selection

The operating mode is selected by applying the appropriate logic states to the MODA and MODB pins during reset. MODA selects single-chip mode (0) or expanded mode (1). A logic high on MODB selects normal modes, and vectors are fetched from memory area \$FFC0-\$FFFF. A logic low on MODB selects special modes, and reset vectors are fetched from memory area \$BFC0-\$BFFF. Values reflecting the selected mode are latched into the RBOOT, SMOD, and MDA bits of the highest priority I-bit interrupt and miscellaneous register (HPRIO) on the rising edge of RESET.

**Table 4-3** summarizes the inputs, modes selected, and register bits latched. The HPRIO register is illustrated in **Figure 4-2**.

Table 4-3. Hardware Mode Select Summary

| Inputs |      | Mode              | Control Bits in HPRIO<br>Latched at Reset |      |     |  |
|--------|------|-------------------|-------------------------------------------|------|-----|--|
| MODB   | MODA |                   | RBOOT                                     | SMOD | MDA |  |
| 1      | 0    | Single-chip       | 0                                         | 0    | 0   |  |
| 1      | 1    | Expanded          | 0                                         | 0    | 1   |  |
| 0      | 0    | Special bootstrap | 1                                         | 1    | 0   |  |
| 0      | 1    | Special test      | 0                                         | 1    | 1   |  |



The values of the RBOOT, SMOD, and MDA bits at reset depend on the mode during initialization.

Figure 4-2. Highest Priority I-Bit Interrupt and Miscellaneous Register (HPRIO)

RBOOT — Read Bootstrap ROM Bit

In special modes, this bit enables the bootloader ROM

0 = Bootloader ROM disabled and not in map

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

In normal modes this bit is clear and cannot be written.

#### SMOD — Special Mode Select Bit

This bit reflects the inverse of the MODB input pin at the rising edge of RESET. If MODB is low during reset, SMOD is set; if MODB is high during reset, SMOD is cleared. Software can clear the SMOD bit, but cannot set it. Thus, it is possible for software to change the operating

mode from special to normal, but not vice versa. To switch from a special mode to a normal mode, write to the access-limited registers (see **Table 4-1**) before clearing SMOD.

- 0 = Normal mode operation in effect
- 1 = Special mode operation in effect

#### MDA — Mode Select A Bit

The mode select A bit reflects the status of the MODA input pin at the rising edge of RESET. Software can change the MDA bit only while the SMOD bit is set, effectively switching the operating mode between special bootstrap and special test modes. Once the SMOD bit is clear, the MODA bit is read-only and the operating mode cannot be changed without going through a reset sequence.

- 0 = Normal single-chip or special bootstrap mode in effect
- 1 = Normal expanded or special test mode in effect

After RESET is released, the mode select pins revert to their alternate functions, described in 2.9 Mode Selection, Instruction Cycle Reference, and Standby Power (MODA/LIR and MODB/VSTBY), and no longer influence the MCU operating mode.

# 4.6 Memory Map

The operating mode determines memory mapping and whether memory is addressed on-chip or off-chip. Figure 4-3 and Figure 4-4 illustrate the M68HC11K4 Family and M68HC11KS Family memory maps for each of the four modes of operation. Memory locations for on-chip resources are the same for both expanded and single-chip modes.



Note 1.EPROM can be enabled in special test mode by setting the ROMON bit in the CONFIG register after reset.

Figure 4-3. M68HC11K4 Family Memory Map



Note: 1.EPROM can be enabled in special test mode by setting the ROMON bit in the CONFIG register after reset.

Figure 4-4. M68HC11KS2 Family Memory Map

**Table 4-4** shows the default memory map addresses for the M68HC11K Family devices.

**Table 4-4. Default Memory Map Addresses** 

|           | [7]11K4       | [7]11KS2      |
|-----------|---------------|---------------|
| Registers | \$0000-\$007F | \$0000-\$007F |
| RAM       | \$0080-\$037F | \$0080-\$047F |
| EEPROM    | \$0D80-\$0FFF | \$0D80-\$0FFF |
| ROM/EPROM | \$A000-\$FFFF | \$8000-\$FFFF |

#### 4.6.1 Control Registers and RAM

Out of reset, the 128-byte register block is mapped to \$0000 and the 768-byte RAM (1 Kbyte on the [7]11KS2) is mapped to \$0080. Both the register block and the RAM can be placed at any other 4-Kbyte boundary (\$x000 and \$x080, respectively) by writing the appropriate value to the INIT register.



Figure 4-5. RAM and I/O Mapping Register (INIT)

**NOTE:** INIT is writable once in normal modes and writable at any time in special modes.

RAM[3:0] — RAM Map Position Bits

These four bits determine the position of RAM in the memory map by specifying the upper hexadecimal digit of the RAM address. Refer to **Table 4-5**.

REG[3:0] — Register Block Position Bits

These four bits determine the position of the register block in memory by specifying the upper hexadecimal digit of the block address. Refer to **Table 4-6**.

Table 4-5. RAM Mapping

| RAM[3:0] | Address <sup>(1)</sup>       | Address <sup>(2)</sup> |  |  |
|----------|------------------------------|------------------------|--|--|
| 0000     | \$0080-\$037F <sup>(3)</sup> | \$0000-\$02FF          |  |  |
| 0001     | \$1080–\$137F                | \$1000-\$12FF          |  |  |
| 0010     | \$2080-\$237F                | \$2000-\$22FF          |  |  |
| 0011     | \$3080-\$337F                | \$3000-\$32FF          |  |  |
| 0100     | \$4080-\$437F                | \$4000-\$42FF          |  |  |
| 0101     | \$5080-\$537F                | \$5000-\$52FF          |  |  |
| 0110     | \$6080-\$637F                | \$6000-\$62FF          |  |  |
| 0111     | \$7080-\$737F                | \$7000–\$72FF          |  |  |
| 1000     | \$8080-\$837F                | \$8000-\$82FF          |  |  |
| 1001     | \$9080-\$937F                | \$9000-\$92FF          |  |  |
| 1010     | \$A080-\$A37F                | \$A000-\$A2FF          |  |  |
| 1011     | \$B080-\$B37F                | \$B000-\$B2FF          |  |  |
| 1100     | \$C080-\$C37F                | \$C000-\$C2FF          |  |  |
| 1101     | \$D080-\$D37F                | \$D000-\$D2FF          |  |  |
| 1110     | \$E080-\$E37F                | \$E000-\$E2FF          |  |  |
| 1111     | \$F080-\$F37F                | \$F000-\$F2FF          |  |  |

<sup>1.</sup> RAM[3:0] = REG[3:0]: On the [7]11KS2, RAM address range is \$x080–\$x47F.

<sup>2.</sup>  $RAM[3:0] \neq REG[3:0]$ : On the [7]11KS2, RAM address range is \$x000-\$x37F.

<sup>3.</sup> Default locations out of reset

**Table 4-6. Register Mapping** 

| REG[3:0] | Address                      |
|----------|------------------------------|
| 0000     | \$0000-\$007F <sup>(1)</sup> |
| 0001     | \$1000-\$107F                |
| 0010     | \$2000-\$207F                |
| 0011     | \$3000-\$307F                |
| 0100     | \$4000-\$407F                |
| 0101     | \$5000-\$507F                |
| 0110     | \$6000-\$607F                |
| 0111     | \$7000-\$707F                |
| 1000     | \$8000-\$807F                |
| 1001     | \$9000-\$907F                |
| 1010     | \$A000-\$A07F                |
| 1011     | \$B000-\$B07F                |
| 1100     | \$C000-\$C07F                |
| 1101     | \$D000-\$D07F                |
| 1110     | \$E000-\$E07F                |
| 1111     | \$F000-\$F07F                |

<sup>1.</sup> Default locations out of reset.

Since the direct addressing mode accesses RAM more quickly and efficiently than other addressing modes, many applications will find the default locations of registers and on-board RAM at the bottom of memory to be the most advantageous.

When RAM and the registers are both mapped to different 4-K boundaries, the registers are mapped at \$x000–\$x07F, and RAM is moved to \$x000–\$x2FF (\$x000–x3FF for the [7]11KS2).

#### 4.6.2 ROM or EPROM

The presence and location of the 24-Kbyte (EP)ROM on the [7]11K4 is determined by two bits in the system configuration register (CONFIG). The CONFIG register is a special EEPROM register (see Figure 4-6).

(EP)ROM is present in the memory map when the ROMON bit is set and removed from the memory map when the bit is cleared. The default location of this memory is \$A000–\$FFFF, but it can be moved to \$2000–\$7FFF in expanded mode by clearing the ROMAD bit. Both bits are set out of reset in single-chip mode.

 On the [7]11KS2, (EP)ROM is 32 K, mapped to \$8000–\$FFFF by default, and moved to \$0000–\$7FFF by clearing the ROMAD bit.

In special test mode, the ROMON bit is forced to 0, removing (EP)ROM from the memory map.

#### **4.6.3 EEPROM**

The M68HC11K Family devices contain 640 bytes of EEPROM. It is initially located at \$0D80 after reset if it is enabled by the EEON bit in the CONFIG register (see **Figure 4-6**). It can be relocated to any 4-K boundary (\$xD80) by writing to the EEPROM mapping register (INIT2) (see **Figure 4-7**).

NOTE:

On the M68HC11K devices, the EEPROM can be mapped to where it will contain the vector space.

Address: \$003F Bit 7 6 5 4 3 2 1 Bit 0 Read: CLKX **PAREN NOSEC NOCOP ROMON EEON ROMAD** 1 Write: Reset:

Figure 4-6. System Configuration Register (CONFIG)

**NOTE:** CONFIG is writable once in normal modes and writable at any time in special modes.

ROMAD — ROM Address Mapping Control Bit

Set out of reset in single-chip mode

0 = (EP)ROM set at \$2000-\$7FFF;

\$0000-\$7FFF in [7]11KS2;

\$0000-\$BFFF in [7]11KS8

(expanded mode only)

1 = (EP)ROM set at \$A000-\$FFFF;

\$8000-\$FFFF in [7]11KS2;

\$4000-\$FFFF in [7]11KS8

ROMON — ROM/PROM Enable Bit

Set by reset in single-chip mode; cleared by reset in special test mode

0 = (EP)ROM removed from the memory map

1 = (EP)ROM present in the memory map

EEON — EEPROM Enable Bit

0 = 640-byte EEPROM disabled

1 = 640-byte EEPROM enabled



Figure 4-7. EEPROM Mapping Register (INIT2)

**NOTE:** INIT2 is writable once in normal modes and writable at any time in special modes.

EE[3:0] — EEPROM Map Position Bits

These four bits determine the most-significant hexadecimal digit in the address range of the EEPROM, as shown in **Table 4-7**.

**EE[3:0]** Location 0000 \$0D80-\$0FFF 0001 \$1D80-\$1FFF \$2D80-\$2FFF 0010 0011 \$3D80-\$3FFF \$4D80-\$4FFF 0100 0101 \$5D80-\$5FFF 0110 \$6D80-\$6FFF 0111 \$7D80-\$7FFF 1000 \$8D80-\$8FFF 1001 \$9D80-\$9FFF \$AD80-\$AFFF 1010 1011 \$BD80-\$BFFF 1100 \$CD80-\$CFFF 1101 \$DD80-\$DFFF 1110 \$ED80-\$EFFF 1111 \$FD80-\$FFFF

Table 4-7. EEPROM Map

#### 4.6.4 Bootloader ROM

The bootloader program occupies 512 bytes of bootstrap ROM at addresses \$BE00–\$BFFF. It is active only in special modes when the RBOOT bit in the HPRIO register is set.

# 4.7 EPROM/OTPROM (M68HC711K4 and M68HC711KS2)

The M68HC711K4 devices include 24 Kbytes of on-chip EPROM (OTPROM in non-windowed packages). The M68HC711KS2 has 32 Kbytes of EPROM.

The two methods available to program the EPROM are:

- Downloading data through the serial communication interface (SCI) in bootstrap or special test mode
- Programming individual bytes from memory

Before proceeding with programming:

- Ensure that the CONFIG register ROMON bit is set.
- Ensure that the  $\overline{IRQ}$  pin is pulled to a high level.
- Apply 12 volts to the XIRQ/V<sub>PP</sub> pin.

Program the EPROM only at room temperature. Place an opaque label over the quartz window on windowed parts after programming.

## 4.7.1 Programming the EPROM with Downloaded Data

The MCU can download EPROM data through the SCI while in the special test or bootstrap modes. This can be done either with custom software, also downloaded through the SCI, or with a built-in utility program in bootstrap ROM. In either case, the  $\frac{12\text{-volt}}{\text{NIRQ}/\text{V}_{PP}}$  pin.

To use the bootstrap ROM utility, download a 3-byte program consisting of a single jump instruction to \$BF00, the starting address of the resident EPROM programming utility. The utility program sets the X and Y index

registers to default values, then receives data from an external host and programs it into the EPROM. The value in the X index register determines programming delay time. The value in the Y index register is a pointer to the first address in EPROM to be programmed. The default starting address is \$8000 for the M68HC11KS2.

When the utility program is ready to receive programming data, it sends the host a \$FF character and waits for a reply. When the host sees the \$FF character, it sends the EPROM programming data, starting with the first location in the EPROM array. After the MCU receives the last byte to be programmed and returns the corresponding verification data, it terminates the programming operation by initiating a reset. Refer to the Motorola application note entitled *MC68HC11 Bootstrap Mode*, document order number AN1060/D.

### 4.7.2 Programming the EPROM from Memory

In this method, software programs the EPROM one byte at a time. Each byte is read from memory, then latched and programmed into the EPROM using the EPROM programming control register (EPROG). This procedure can be done in any operating mode.



Figure 4-8. EPROM Programming Control Register (EPROG)

MBE — Multiple-Byte Program Enable Bit

MBE is for factory use only and is accessible only in special test mode. When MBE is set, the MCU ignores address bit 5, so that bytes with ADDR5 = 0 and ADDR5 = 1 both get programmed with the same data.

0 = Normal programming

1 = Multiple-byte programming enabled

#### ELAT — EPROM Latch Control Bit

Setting ELAT latches the address and data of writes to the EPROM. The EPROM cannot be read. ELAT can be read at any time. ELAT can be written any time except when PGM = 1, which disables writes to ELAT.

- 0 = EPROM address and data bus configured for normal reads. EPROM cannot be programmed.
- 1 = EPROM address and data bus are configured for programming. Address and data of writes to EPROM are latched. EPROM cannot be read.

#### EXCOL — Select Extra Columns Bit

EXCOL is for factory use only and is accessible only in special test mode. When EXCOL equals 1, extra columns can be accessed at bit 7 and bit 0. Addresses use bits [11:5]. Bits [4:1] are ignored.

- 0 = User array selected
- 1 = Extra columns selected and user array disabled

#### EXROW — Select Extra Rows Bit

EXROW is for factory use only and is only accessible in special test mode. When EXROW equals 1, two extra rows are available. Addresses use bits [5:0]. Bits [11:6] are ignored.

- 0 = User array selected
- 1 = Extra rows selected and user array is disabled

#### EPGM — EPROM Programming Enable Bit

EPGM applies programming voltage ( $V_{PP}$ ) to the EPROM. EPGM can be read at any time. EPGM can be written only when ELAT = 1.

- 0 = Programming voltage to EPROM array is disconnected
- 1 = Programming voltage to EPROM array is connected; ELAT cannot be changed.

This procedure programs one byte into EPROM. On entry, accumulator A contains the byte of data to be programmed and X contains the target EPROM address.

```
EPROG LDAB #$20
STAB $002B Set ELAT bit to enable EPROM latches.

(EPGM must be 0.)
STAA $0,X Store data to EPROM address
LDAB #$21
STAB $002B Set EPGM bit with ELAT=1
to enable EPROM programming voltage
JSR DLYEP Delay 1-2 ms
CLR $002B Turn off programming voltage and set to
READ mode
```

### 4.8 EEPROM and the CONFIG Register

The 640-byte on-board EEPROM is enabled by the EEON bit in the CONFIG register and located on a 4-K boundary determined by the INIT2 register (4.6.3 EEPROM). An internal charge pump supplies the programming voltage for the EEPROM, eliminating the need for an external high-voltage supply.

When appropriate bits in the BPROT register are cleared, the PPROG register controls programming and erasing the EEPROM. The PPROG register can be read or written at any time, but logic enforces defined programming and erasing sequences to prevent unintentional changes to EEPROM data. When the EELAT bit in the PPROG register is cleared, the EEPROM can be read as if it were a ROM.

The clock source driving the charge pump is software selectable. When the clock select (CSEL) bit in the OPTION register is 0, the E clock is used; when CSEL is 1, an on-chip resistor-capacitor (RC) oscillator is used.

The EEPROM programming voltage power supply voltage to the EEPROM array is not enabled until there has been a write to PPROG with EELAT set and PGM cleared. This must be followed by a write to a valid EEPROM location or to the CONFIG address, and then a write to PPROG with both the EELAT and EPGM bits set. Any attempt to set

both EELAT and EPGM during the same write operation results in neither bit being set.

#### 4.8.1 EEPROM Registers

This section describes the EEPROM registers:

- Block protect register (BPROT)
- EEPROM programming control register (PPROG)
- System configuration options register (OPTION)

The EEPROM programming control register (PPROG) controls programming and erasing. The block protect register (BPROT) can prevent inadvertent writes to (or erases of) blocks of EEPROM and the CONFIG register. The CSEL bit in the system configuration options register (OPTION) selects an on-chip oscillator clock for programming and erasing when operating at frequencies below 1 MHz.

#### 4.8.1.1 EEPROM Programming Control Register



Figure 4-9. EEPROM Programming Control Register (PPROG)

ODD — Program Odd Rows in Half of EEPROM Bit This bit is accessible only in test mode.

EVEN — Program Even Rows in Half of EEPROM Bit
This bit is accessible only in test mode.

LVPI — Low-Voltage Programming Inhibit Bit

LVPI is a read-only bit which always reads as 0. The functionality of this status bit was changed from early versions of the M68HC11K Family. The low-voltage programming inhibit function is disabled on all recent devices.

BYTE — Byte/Other EEPROM Erase Mode Bit

0 = Row or bulk erase mode used

1 = Erase only one byte of EEPROM

ROW — Row/All EEPROM Erase Mode Bit

0 = All 640 bytes of EEPROM erased

1 = Erase only one 16-byte row of EEPROM

**NOTE:** ROW is valid only when BYTE = 0.

The BYTE and ROW bits work together to determine the scope of erasing, as shown in **Table 4-8**.

Table 4-8. Scope of EEPROM Erase

| BYTE | ROW | Action                    |
|------|-----|---------------------------|
| 0    | 0   | Bulk erase; all 640 bytes |
| 0    | 1   | Row erase; 16 bytes       |
| 1    | 0   | Byte erase                |
| 1    | 1   | Byte erase                |

ERASE — Erase/Normal Control for EEPROM Bit

0 = Normal read or program mode

1 = Erase mode

EELAT — EEPROM Latch Control Bit

0 = EEPROM address and data bus configured for normal reads

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

EEPGM — EEPROM Program Command Bit

0 = Program or erase voltage switched off to EEPROM array

1 = Program or erase voltage switched on to EEPROM array

#### 4.8.1.2 Block Protect Register

This register prevents inadvertent writes to both the CONFIG register and EEPROM. The active bits in this register are initialized to 1 out of reset and can be cleared only during the first 64 E-clock cycles after reset in the normal modes. When these bits are cleared, the associated EEPROM section and the CONFIG register can be programmed or erased. EEPROM is only visible if the EEON bit in the CONFIG register is set. The bits in the BPROT register can be written to 1 at any time to protect EEPROM and the CONFIG register. In test or bootstrap modes, write protection is inhibited and BPROT can be written repeatedly.



Figure 4-10. Block Protect Register (BPROT)

BULKP — Bulk Erase of EEPROM Protect Bit

0 = EEPROM can be bulk erased normally.

1 = EEPROM cannot be bulk or row erased.

LVPEN — Low-Voltage Programming Protect Enable Bit

The functionality of LVPEN/LVPI was changed from earlier versions of the M68HC11K Family. Setting this bit has no effect on the LVPI bit in the PPROG register.

0 = Low-voltage programming inhibit (LVPI) for EEPROM disabled

1 = Low-voltage programming inhibit (LVPI) for EEPROM disabled

BPRT[4:0] — Block Protect Bits for EEPROM Bits, see Table 4-9

0 = Protection disabled for associated block

1 = Protection enabled for associated block

**Table 4-9. EEPROM Block Protect** 

| Bit Name | Block Protected | Block Size |
|----------|-----------------|------------|
| BPRT0    | \$xD80-\$xD9F   | 32 bytes   |
| BPRT1    | \$xDA0-\$xDDF   | 64 bytes   |
| BPRT2    | \$xDE0-\$xE5F   | 128 bytes  |
| BPRT3    | \$xE60-\$xF7F   | 288 bytes  |
| BPRT4    | \$xF80-\$xFFF   | 128 bytes  |

#### 4.8.1.3 System Configuration Options Register

Address: \$0039 Bit 7 6 5 3 2 1 Bit 0 4 Read: CR1<sup>(1)</sup> CR0<sup>(1)</sup>  $DIY^{(1)}$ FCME<sup>(1)</sup> **ADPU CSEL IROF** CMF Write: 0 0 0 1 0 0 0 0 Reset:

Figure 4-11. System Configuration Options Register (OPTION)

CSEL — Clock Select Bit

Selects the built-in RC clock source for on-chip EEPROM and A/D charge pumps. This clock should be used when the E clock falls below 1 MHz.

0 = A/D and EEPROM use system E clock.

1 = A/D and EEPROM use internal RC clock.

### 4.8.2 EEPROM Programming

To write to any EEPROM byte, it must first be erased, for instance, all of its bits must be set. A single byte, a row, or the entire EEPROM in a single procedure can be erased by adjusting the BYTE and ROW bits in PPROG. Once the targeted area has been erased, each byte can be individually written.

<sup>1.</sup> Can be written only once in first 64 cycles out of reset in normal modes or at any time in special modes.

The procedures for both writing and erasing involve these five steps:

- 1. **Set the EELAT bit in PPROG**. If erasing, also set the ERASE bit and the appropriate BYTE and ROW bits.
- Write data to the appropriate EEPROM address. If erasing, any data will work. To erase a row, write to any location in the row. To erase the entire EEPROM, write to any location in the array. This step is done before applying the programming voltage because setting the EEPGM bit inhibits writes to EEPROM addresses.
- 3. **Set the EEPGM bit in PPROG**, keeping EELAT set. If erasing, also set the ERASE bit and the appropriate BYTE and ROW bits.
- 4. Delay for 10 ms.
- 5. Clear the PPROG register to turn off the high voltage and reconfigure the EEPROM address and data buses for normal operation.

The following examples demonstrate programming a single EEPROM byte, erasing the entire EEPROM, erasing a row (16 bytes), and erasing a single byte.

#### 4.8.2.1 EEPROM Programming

On entry, accumulator A contains the data to be written and X points to the address to be programmed.

| EEPROG | LDAB | #\$02  |                                      |
|--------|------|--------|--------------------------------------|
| FFFROG | TDAD | #\$02  |                                      |
|        | STAB | \$003B | Set EELAT bit to enable EEPROM       |
|        |      |        | latches.                             |
|        | STAA | \$0,X  | Store data to EPROM address          |
|        | LDAB | #\$03  |                                      |
|        | STAB | \$002B | Set EPGM bit with ELAT=1             |
|        |      |        | to enable EEPROM programming voltage |
|        | JSR  | DLY10  | Delay 10 ms                          |
|        | CLR  | \$003B | Turn off programming voltage and set |
|        |      |        | to READ mode                         |

### 4.8.2.2 EEPROM Bulk Erase

| BULKE | LDAB | #\$06  |                                      |
|-------|------|--------|--------------------------------------|
|       | STAB | \$003B | Set EELAT and ERASE.                 |
|       | STAA | \$0,X  | Store any data to any EEPROM address |
|       | LDAB | #\$07  |                                      |
|       | STAB | \$002B | Set EEPGM bit as well                |
|       |      |        | to enable EEPROM programming voltage |
|       | JSR  | DLY10  | Delay 10 ms                          |
|       | CLR  | \$003B | Turn off programming voltage and set |
|       |      |        | to READ mode                         |

### 4.8.2.3 EEPROM Row Erase

| ROWE | LDAB | #\$07  |                                             |
|------|------|--------|---------------------------------------------|
|      | STAB | \$003B | Set EELAT, ERASE and ROW.                   |
|      | STAA | \$0,X  | Store any data to any EEPROM address in row |
|      | LDAB | #\$07  | 111 1011                                    |
|      | STAB | \$002B | Set EEPGM bit as well                       |
|      |      |        | to enable EEPROM programming voltage        |
|      | JSR  | DLY10  | Delay 10 ms                                 |
|      | CLR  | \$003B | Turn off programming voltage and set        |
|      |      |        | to READ mode                                |

### 4.8.2.4 EEPROM Byte Erase

| BYTEE | LDAB | #\$16  |                                           |
|-------|------|--------|-------------------------------------------|
|       | STAB | \$003B | Set EELAT, ERASE and BYTE.                |
|       | STAA | \$0,X  | Store any data to targeted EEPROM address |
|       | LDAB | #\$17  |                                           |
|       | STAB | \$002B | Set EEPGM bit as well                     |
|       |      |        | to enable EEPROM programming voltage      |
|       | JSR  | DLY10  | Delay 10 ms                               |
|       | CLR  | \$003B | Turn off programming voltage and set      |
|       |      |        | to READ mode                              |

#### 4.8.3 CONFIG Register Programming

The CONFIG register is implemented with EEPROM cells, so EEPROM procedures are required to change it. CONFIG can be programmed or erased (including byte erase) while the MCU is operating in any mode, provided that PTCON in BPROT is clear.



Figure 4-12. Block Protect Register (BPROT)

PTCON — Protect for CONFIG Bit

0 = CONFIG register can be programmed or erased normally.

1 = CONFIG register cannot be programmed or erased.

To change the value in the CONFIG register, complete this procedure. Do not initiate a reset until the procedure is complete.

- Erase the CONFIG register.
- Program the new value to the CONFIG address.
- Initiate reset.

### 4.8.4 RAM and EEPROM Security

The NOSEC bit in the CONFIG register enables and disables an optional security feature which protects the contents of EEPROM and RAM from unauthorized access. This is done by restricting operation to single-chip modes, preventing the memory locations from being monitored externally. Single-chip modes do not allow visibility of the internal address and data buses. Resident programs, however, have unlimited access to the internal EEPROM and RAM and can read, write, or transfer the contents of these memories.



Figure 4-13. System Configuration Register (CONFIG)

**NOTE:** CONFIG is writable once in normal modes and writable at any time in special modes.

NOSEC — RAM and EPROM Security Disabled Bit

0 = Enable security

1 = Disable security

M68HC11K Family devices are normally manufactured with NOSEC set and the security option unavailable. However, on special request, a mask option is selected during fabrication that enables the security mode. The secure mode can be invoked on these parts by clearing NOSEC. Contact a Motorola representative for information on the availability of this feature.

The bootstrap program performs this sequence when the security feature is present, enabled, and bootstrap mode is selected:

- 1. Output \$FF, all 1s, on the SCI.
- 2. Clear the BPROT register by turning block protect off.
- 3. If the EEPROM is enabled, erase the EEPROM.
- 4. Verify that the EEPROM is erased. If EEPROM is not erased, begin sequence again.
- 5. Write \$FF, all 1s, to the entire block of RAM.
- Erase the CONFIG register.

If all of the operations are successful, the bootload process continues as if the device was never secured.

#### 4.9 XOUT Pin Control

The XOUT pin provides a buffered XTAL signal to synchronize external devices with the MCU. It is enabled by the CLKX bit in the system configuration (CONFIG) register. The frequency of XOUT can be divided by one-of-four divisors selected by the XDV[1:0] bits in the system configuration options 2 (OPT2) register. The XOUT pin is not configured on all packages. Refer to the pin assignments in **Section 2. Pin Description**.

#### 4.9.1 System Configuration Register



Figure 4-14. System Configuration Register (CONFIG)

Writable once in normal modes and writable at any time in special modes

CLKX — XOUT Clock Enable Bit

The CLKX bit is a switch that enables a buffered clock running at the same frequency as a referenced crystal. This buffered clock is intended to synchronize external devices with the MCU.

0 = The XOUT pin is disabled.

1 = The X clock is driven out on the XOUT pin.

### 4.9.2 System Configuration Options 2 Register



Figure 4-15. System Configuration Options 2 Register (OPT2)

XDV[1:0] — XOUT Clock Divide Select Bits

These two bits select the divisor for the XOUT clock frequency, as shown in **Table 4-10**. The divisor is set to 1 out of reset (XOUT = XTAL). It takes a maximum of 16 cycles after writing these bits for XOUT to stabilize. The phase relationship between XOUT and XTAL cannot be predicted.

**Table 4-10. XOUT Frequencies** 

| XDV | V[1:0] | EXTAL<br>Divided By | Frequency at EXTAL = 8 MHz | Frequency at EXTAL = 12 MHz | Frequency at EXTAL = 16 MHz | Frequency at<br>EXTAL = 16 MHz |
|-----|--------|---------------------|----------------------------|-----------------------------|-----------------------------|--------------------------------|
| 0   | 0      | 1                   | 8 MHz                      | 12 MHz                      | 16 MHz                      | 20 MHz                         |
| 0   | 1      | 4                   | 2 MHz                      | 3 MHz                       | 4 MHz                       | 5 MHz                          |
| 1   | 0      | 6                   | 1.33 MHz                   | 2 MHz                       | 2.67 MHz                    | 3.33 MHz                       |
| 1   | 1      | 8                   | 1 MHz                      | 1.5 MHz                     | 2 MHz                       | 2.5 MHz                        |

# **Section 5. Resets and Interrupts**

### 5.1 Contents

| 5.2                                                                        | Introduction                                               |
|----------------------------------------------------------------------------|------------------------------------------------------------|
| 5.3<br>5.3.1<br>5.3.2<br>5.3.3<br>5.3.3.2<br>5.3.3.3<br>5.3.4.5<br>5.3.4.5 | System Configuration Options Register                      |
| 5.4                                                                        | Effects of Reset                                           |
| 5.5<br>5.5.1<br>5.5.1.2<br>5.5.1.3<br>5.5.2                                | 2 Illegal Opcode Trap120                                   |
| 5.6                                                                        | Reset and Interrupt Priority122                            |
| 5.7                                                                        | Reset and Interrupt Processing                             |
| 5.8<br>5.8.1<br>5.8.2<br>5.8.3                                             | Low-Power Operation129Wait Mode130Stop Mode130Slow Mode132 |

#### 5.2 Introduction

When a reset or interrupt occurs, the microcontroller (MCU) retrieves the starting address of a program or interrupt routine from a vector table in memory and loads it in the program counter. A reset immediately stops execution of the current instruction and reinitializes the control registers. An interrupt preserves the current program status, performs an interrupt service routine, and resumes operation as if there had been no interruption.

### 5.3 Sources of Resets

The four sources of reset are:

- Power-on reset (POR)
- External reset (RESET)
- Computer operating properly (COP) system
- Clock monitor

**NOTE:** Power-on reset and external reset share the same interrupt vectors.

The CPU fetches a restart vector during the first three clock cycles after reset and begins executing instructions. Vector selection is based on the type of reset and operating mode, as shown in **Table 5-1**.

Table 5-1. Reset Vectors

| Operating<br>Mode | POR or RESET      | Clock Monitor     | COP Watchdog      |
|-------------------|-------------------|-------------------|-------------------|
| Normal            | \$FFFE and \$FFFF | \$FFFC and \$FFFD | \$FFFA and \$FFFB |
| Test or bootstrap | \$BFFE and \$BFFF | \$BFFC and \$BFFD | \$BFFA and \$BFFB |

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

A positive transition on  $V_{DD}$  generates a POR, which is used only for power-up conditions. POR cannot be used to detect drops in power supply voltages. The CPU delays 4064 internal clock cycles after the oscillator becomes active to allow the clock generator to stabilize, then checks the  $\overline{\text{RESET}}$  pin. If  $\overline{\text{RESET}}$  is at logical 0, the CPU remains in the reset condition until the  $\overline{\text{RESET}}$  pin goes to logical 1.

### 5.3.2 External Reset (RESET)

The CPU distinguishes between internal and external reset conditions by sensing whether the reset pin rises to a logic 1 in less than two E-clock cycles after an internal device releases reset. When a reset condition is sensed, the RESET pin is driven low by an internal device for four E-clock cycles, then released. Two E-clock cycles later, it is sampled. If the pin is still held low, the CPU assumes that an external reset has occurred. If the pin is high, it indicates that the reset was initiated internally by either the COP system or the clock monitor.

#### **NOTE:**

It is not advisable to connect an external resistor capacitor (RC) power-up delay circuit to the reset pin of M68HC11 devices because the circuit charge time constant can cause the device to misinterpret the type of reset that occurred.

#### 5.3.3 Computer Operating Properly (COP) System

The MCU includes a COP system to help protect against software failures. When the COP is enabled, software periodically reinitializes a free-running watchdog timer before it times out and resets the system. Such a system reset indicates that a software error has occurred.

Three registers are involved in COP operation:

- The CONFIG register contains a bit which determines whether the COP system is enabled or disabled.
- The OPTION register contains two bits which determine the COP timeout period.
- The COPRST register must be written by software to reset the watchdog timer.

**NOTE:** Throughout this manual, the registers are discussed by function. In the event that not all bits in a register are referenced, the bits that are not discussed are shaded.

#### 5.3.3.1 System Configuration Register

In normal modes, COP is enabled out of reset and does not depend on software action. To disable the COP system, set the NOCOP bit in the CONFIG register (see **Figure 5-1**). In special test and bootstrap operating modes, the COP system is initially inhibited by the disable resets (DISR) control bit in the TEST1 register. The DISR bit can subsequently be written to 0 to enable COP resets.



Figure 5-1. System Configuration Register (CONFIG)

**NOTE:** CONFIG is writable once in normal modes and writable at any time in special modes.

NOCOP — COP System Disable Bit 0 = COP enabled 1 = COP disabled

### 5.3.3.2 System Configuration Options Register

Two bits in the OPTION register select one of four values for the COP timer.



Figure 5-2. System Configuration Options Register (OPTION)

CR[1:0] — COP Timer Rate Select Bits

The MCU derives the counter for the COP timer by dividing the system E clock by 2<sup>15</sup> and applying a further scaling factor selected by CR[1:0] as shown in **Table 5-2**. After reset, these bits are 0, and that condition selects the fastest timeout period.

**NOTE:** In normal operating modes, these bits can be written only once within 64 bus cycles after reset.

**EXTAL Frequencies EXTAL Freq.** 8.0 MHz 12.0 MHz 16.0 MHz 20.0 MHz 24.0 MHz Other EXTAL E Clock Freq. 2.0 MHz 3.0 MHz 4.0 MHz 5.0 MHz 6.0 MHz EXTAL ÷ 4 **COP Timeout Timeout Control Bits** SPR[2:0] 0/+16.384 ms 0/+10.923 ms 0/+8.192 ms 0/+6.544 ms 0/+5.461 ms  $0/+2^{15} \div E$ 00 8.192 ms 5.461 ms  $2^{15} \div E$ 16.384 ms 10.923 ms 6.554 ms 01 65.536 ms 43.691 ms 32.768 ms 26.214 ms 21.845 ms  $2^{17} \div E$ 262.144 ms 131.072 ms 104.858 ms 87.381 ms  $2^{19} \div E$ 10 174.763 ms 1 1 1.049 sec 699.051 ms 524.288 ms 419.430 ms 349.525 ms  $2^{21} \div E$ 

**Table 5-2. COP Timeout** 

### 5.3.3.3 Arm/Reset COP Timer Circuitry Register



Figure 5-3. Arm/Reset COP Timer Circuitry Register (COPRST)

To prevent a COP reset, this sequence must be completed:

- 1. Write \$55 to COPRST to arm the COP timer clearing mechanism.
- 2. Write \$AA to COPRST to clear the COP timer.

**NOTE:** Performing instructions between these two steps is possible as long as both steps are completed in the correct sequence before the timer times out.

### 5.3.4 Clock Monitor Reset

The clock monitor can serve as a backup for the COP system. Its circuit is based on an internal RC time delay. If no MCU clock edges are detected within this RC time delay, the clock monitor generates a system reset. Because the COP needs a clock to function, it is disabled when the clocks stop. Thus, the clock monitor system can detect clock failures not detected by the COP system.

### 5.3.4.1 System Configuration Options Register

The clock monitor function is enabled or disabled by the CME control bit in the OPTION register (see **Figure 5-4**). The FCME bit in OPTION overrides CME and enables the clock monitor until the next reset.



Figure 5-4. System Configuration Options Register (OPTION)

**NOTE:** In normal operating modes, these bits can be written only once within 64 bus cycles after reset.

#### CME — Clock Monitor Enable Bit

This control bit can be read or written at any time and controls whether or not the internal clock monitor circuit triggers a reset sequence when the system clock is slow or absent. When it is clear, the clock monitor circuit is disabled. When it is set, the clock monitor circuit is enabled. Reset clears the CME bit.

0 = Clock monitor disabled

1 = Clock monitor enabled

FCME — Force Clock Monitor Enable Bit

0 = Clock monitor follows the state of the CME bit.

1 = Clock monitor is enabled until the next reset.

Semiconductor wafer processing causes variations of the RC timeout values between individual devices. An E-clock frequency below 10 kHz generates a clock monitor error. An E-clock frequency of 200 kHz or more prevents clock monitor errors. Using the clock monitor function when the E clock is below 200 kHz is not recommended.

### 5.3.4.2 System Configuration Options Register 2



1. Not available on M68HC11K devices

Figure 5-5. System Configuration Options Register 2 (OPT2)

#### LIRDV — LIR Driven Bit

This bit allows power savings in expanded modes by turning off the  $\overline{\text{LIR}}$  output (it has no meaning in single-chip or bootstrap modes). The  $\overline{\text{LIR}}$  pin is driven low to indicate that execution of an instruction has begun. To detect consecutive instructions in a high-speed application, this signal drives high for a quarter of a cycle to prevent false triggering. An external pullup is required in expanded modes, while a hardwired  $V_{SS}$  connection is possible in single-chip modes. LIRDV is reset to 0 in single-chip modes and to 1 in expanded modes.

1 = Enable LIR push-pull drive

 $0 = \overline{LIR}$  not driven high on MODA/ $\overline{LIR}$  pin

#### CWOM — Port C Wired-OR Mode Bit

For detailed information, refer to **Section 6. Parallel Input/Output**.

1 = Port C outputs are open drain.

0 = Port C operates normally.

### STRCH — Stretch External Accesses Bit

When this bit is set, off-chip accesses of selected addresses are extended by one E-clock cycle to allow access to slow peripherals. The E clock stretches externally, but the internal clocks are not affected, so that timers and serial systems are not corrupted. The state of the ROMAD bit in the CONFIG register determines which address range is affected.

1 = Off-chip accesses are selectively extended by one E-clock cycle.

0 = Normal operation

**NOTE:** STRCH is cleared on reset; therefore, a program cannot execute out of reset in a slow external ROM.

To use the STRCH feature, ROMON must be set on reset so that the device starts with internal ROM included in the memory map. STRCH should then be set.

STRCH has no effect in single-chip and bootstrap modes.

**NOTE:** STRCH is not available on M68HC11K devices.

IRVNE — Internal Read Visibility/Not E Bit

IRVNE can be written once in any user mode. In expanded modes, IRVNE determines whether IRV is on or off (but has no meaning in user expanded secure mode, as IRV must be disabled). In special test mode, IRVNE is reset to 1. In normal modes, IRVNE is reset to 0.

- 1 = Data from internal reads is driven out of the external data bus.
- 0 = No visibility of internal reads on external bus

In single-chip modes, this bit determines whether the E clock drives out from the chip.

- 1 = E pin is driven low.
- 0 = E clock is driven out from the chip.

Refer to **Table 5-3** for a summary of the operation immediately following reset.

**Table 5-3. IRVNE Operation After Reset** 

| Mode         | IRVNE<br>after<br>Reset | E Clock<br>after<br>Reset | IRV<br>after<br>Reset | IRVNE<br>Affects<br>Only | IRVNE<br>Can Be<br>Written |
|--------------|-------------------------|---------------------------|-----------------------|--------------------------|----------------------------|
| Single-chip  | 0                       | On                        | Off                   | Е                        | Once                       |
| Expanded     | 0                       | On                        | Off                   | IRV                      | Once                       |
| Bootstrap    | 0                       | On                        | Off                   | Е                        | Unlimited                  |
| Special test | 1                       | On                        | On                    | IRV                      | Unlimited                  |

## **Resets and Interrupts**

LSBF — Least Significant Bit (LSB) First Enable Bit

For detailed information, refer to **Section 8. Serial Peripheral Interface (SPI)**.

- 1 = Data is transferred LSB first.
- 0 = Data is transferred MSB (most significant bit) first.

SPR2 — SPI Clock Rate Selected Bit

This bit adds a divide-by-four to the SPI clock chain. For detailed information, refer to **Section 8. Serial Peripheral Interface (SPI)**.

XDV[1:0] — XOUT Clock Divide Select Bits

These bits control the frequency of the clock driven out of the XOUT pin, if enabled by the CLKX bit on the CONFIG register. See **Table 5-4** 

Table 5-4. XOUT Clock Divide Select

| XDV<br>[1:0] | XOUT = EXTAL<br>Divided By | Frequency at EXTAL = 8 MHz | Frequency at<br>EXTAL =<br>12 MHz | Frequency at<br>EXTAL =<br>16 MHz |
|--------------|----------------------------|----------------------------|-----------------------------------|-----------------------------------|
| 0 0          | 1                          | 8 MHz                      | 12 MHz                            | 16 MHz                            |
| 0 1          | 4                          | 2 MHz                      | 3 MHz                             | 4 MHz                             |
| 1 0          | 6                          | 1.3 MHz                    | 2 MHz                             | 2.7 MHz                           |
| 1 1          | 8                          | 1 MHz                      | 1.5 MHz                           | 2 MHz                             |

### 5.4 Effects of Reset

When the MCU recognizes a reset condition, it forces the CPU registers and control bits to established initial states. These in turn force the on-chip peripheral systems to known startup states, as described here.

- Central processor unit (CPU)
  - The stack pointer and other CPU registers are indeterminate immediately after reset, except for three bits in the condition code register (CCR).
  - The X and I interrupt mask bits are set to mask any interrupt requests, and the S bit in the CCR is set to inhibit the stop mode.

### Memory map

- The INIT register is initialized to \$00, putting the control registers at locations \$0000–\$007F.
- The 1.5 Kbytes of RAM are at locations \$0080–\$067F except for the M68HC11KS Family, which has 1 Kbytes of RAM at locations \$0080–\$047F.
- The INIT2 register is \$00, locating the EEPROM at \$0D80-\$0FFF.

#### Timer

- The timing 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 input/output (I/O) pins. The other four output compares are configured so that they do not affect any I/O pins on successful compares.
- All 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.

### **Resets and Interrupts**

- All nine timer interrupts are disabled because their mask bits have been cleared.
- The I4/O5 bit in the PACTL register is cleared to configure the I4/O5 function as OC5; however, the OM5:OL5 control bits in the TCTL1 register are clear so OC5 does not control the PA3 pin.
- Real-time interrupt (RTI)
  - The RTI enable bit in TMSK2 is cleared, masking automatic hardware interrupts.
  - The rate control bits are cleared after reset and can be initialized by software before the RTI system is enabled.
- Pulse accumulator
  - The pulse accumulator system is disabled at reset.
  - The PAI input pin defaults to a general-purpose input pin (PA7).
- Computer operating properly (COP) watchdog system
  - The COP watchdog system is enabled if the NOCOP control bit in the CONFIG register is clear and disabled if NOCOP is set.
  - The OPTION register's CR[1:0] bits are cleared, setting the COP rate for the shortest duration timeout.
- Serial communications interface (SCI)
  - At reset, the SCI baud rate control register (7.9.1 SCI Baud Rate Control Register) is initialized to \$0004.
  - 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 SCI 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 SCI 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, FE, PF, and RAF receive-related status bits are cleared.
- Serial peripheral interface (SPI)
  - The SPI system is disabled by reset.
  - The port pins associated with this function default to being general-purpose I/O lines.
- Analog-to-digital (A/D) converter
  - The ADPU bit in the OPTION register is cleared, disabling the A/D system.
  - The conversion complete flag in the ADCTL register is also cleared.

### System

- The external IRQ pin has the highest I-bit interrupt priority because PSEL[4:0] in the HPRIO register are initialized with the value %00110 (where % indicates a binary value).
- 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 IRQ pin is configured for level-sensitive operation for wired-OR systems.
- The DLY control bit in the OPTION register is set, enabling oscillator startup delay after recovery from stop mode.
- The clock monitor system is disabled because the CME and FCME bits in the OPTION register are cleared.

# 5.5 Interrupts

The MCU has 18 interrupt vectors that support 22 interrupt sources. The 19 maskable interrupts are generated by on-chip peripheral systems. They are recognized when the I bit in the CCR is clear. The three non-maskable interrupt sources are illegal opcode trap, software interrupt, and  $\overline{\text{XIRQ}}$  pin. Table 5-5 lists the interrupt sources and vector assignments for each source.

**Table 5-5. Interrupt and Reset Vector Assignments** 

| Vector Address      | Interrupt Source                       | CC Register<br>Mask | Local<br>Mask                     |
|---------------------|----------------------------------------|---------------------|-----------------------------------|
| FFC0, C1 — FFD4, D5 | Reserved                               | _                   | _                                 |
| FFD6, D7            | SCI serial system:                     | I bit               | TCIE<br>TIE<br>ILIE<br>RIE<br>RIE |
| FFD8, D9            | SPI serial transfer complete           | l bit               | SPIE                              |
| FFDA, DB            | Pulse accumulator input edge           | I bit               | PAII                              |
| FFDC, DD            | Pulse accumulator overflow             | I bit               | PAOVI                             |
| FFDE, DF            | Timer overflow                         | l bit               | TOI                               |
| FFE0, E1            | Timer input capture 4/output compare 5 | I bit               | I4/O5I                            |
| FFE2, E3            | Timer output compare 4                 | l bit               | OC4I                              |
| FFE4, E5            | Timer output compare 3                 | l bit               | OC3I                              |
| FFE6, E7            | Timer output compare 2                 | l bit               | OC2I                              |
| FFE8, E9            | Timer output compare 1                 | l bit               | OC1I                              |
| FFEA, EB            | Timer input capture 3                  | I bit               | IC3I                              |
| FFEC, ED            | Timer input capture 2                  | I bit               | IC2I                              |
| FFEE, EF            | Timer input capture 1                  | I bit               | IC1I                              |
| FFF0, F1            | Real-time interrupt                    | l bit               | RTII                              |
| FFF2, F3            | IRQ (external pin)                     | l bit               | None                              |
| FFF4, F5            | XIRQ pin                               | X bit               | None                              |
| FFF6, F7            | Software interrupt                     | None                | None                              |
| FFF8, F9            | Illegal opcode trap                    | None                | None                              |
| FFFA, FB            | COP failure                            | None                | NOCOP                             |
| FFFC, FD            | Clock monitor fail                     | None                | CME                               |
| FFFE, FF            | RESET                                  | None                | None                              |

Many interrupt sources set associated flag bits when interrupts occur. These flags are usually cleared during the course of normal interrupt service. For example, the normal response to an RDRF interrupt request in the SCI is to read the SCI status register to check for receive errors, then read the received data from the SCI data register. It is precisely these two steps which clear RDRF, so no extra steps are required.

An interrupt can be recognized at any time after it is enabled by its local mask, if any, and by the global mask bit in the CCR. The CPU responds to an interrupt at the completion of the instruction being executed. Since the number of clock cycles in the instruction varies, so does interrupt latency. The CPU pushes the contents of its registers onto the stack in the order shown in Table 5-6. After the CCR value is stacked, the I bit is set (and the X bit as well if XIRQ is pending) to inhibit further interrupts. The CPU fetches the interrupt vector for the highest priority pending source, and execution continues at the address specified by the vector. The interrupt service routine ends with the return-from-interrupt (RTI) instruction, which tells the CPU to pull the saved registers from the stack in reverse order so that normal program execution can resume.

Table 5-6. Stacking Order on Entry to Interrupts

| Memory Location | CPU Registers |
|-----------------|---------------|
| SP              | PCL           |
| SP – 1          | PCH           |
| SP –2           | IYL           |
| SP - 3          | IYH           |
| SP – 4          | IXL           |
| SP - 5          | IXH           |
| SP - 6          | ACCA          |
| SP - 7          | ACCB          |
| SP – 8          | CCR           |

### 5.5.1 Non-Maskable Interrupts

Non-maskable interrupts can interrupt CPU operations at any time. The most common use for such an interrupt is for serious system problems, such as program runaway or power failure. The three sources of non-maskable interrupt are:

- XIRQ pin
- Illegal opcode trap
- Software interrupt instruction (SWI)

## 5.5.1.1 Non-Maskable Interrupt Request (XIRQ)

The XIRQ input is an updated version of the non-maskable NMI input of earlier MCUs. Upon reset, both the X bit and I bit of the CCR are set to inhibit all maskable interrupts and XIRQ. After minimum system initialization, software can clear the X bit by a transfer from accumulator A to condition code register (TAP) instruction, enabling XIRQ interrupts. Thereafter, software cannot set the X bit and the XIRQ interrupt becomes non-maskable.

I bit-related interrupts do not affect the X bit, which has a higher priority than they do in the interrupt priority logic. When an I bit-related interrupt occurs, the CPU sets the I bit after stacking the CCR byte, but the X bit remains unaffected. When an X bit-related interrupt occurs, the CPU sets both the X and I bits after stacking the CCR. The RTI instruction restores the X and I bits to their pre-interrupt request state when it pulls the CCR from the stack.

### 5.5.1.2 Illegal Opcode Trap

The MCU includes an illegal opcode detection circuit to avoid attempting to process undefined opcodes or opcode sequences. This mechanism works for all unimplemented opcodes on all four opcode map pages. When the circuit detects an illegal opcode, it generates an interrupt. The CPU responds by pushing the current value of the program counter, which is actually the address of the first byte of the illegal opcode, on the stack. The illegal opcode service routine can use this stacked address as a pointer to the illegal opcode to correct it. To avoid repeated

execution of the illegal opcode, which can lead to stack overflow, the service routine should reinitialize the stack pointer.

### 5.5.1.3 Software Interrupt (SWI)

SWI cannot be masked by virtue of the fact that it is a software instruction. It is not inhibited by the global mask bits in the CCR. Execution of SWI sets the I mask bit, so other interrupts are inhibited until user software clears the I bit or SWI terminates with an RTI instruction.

### 5.5.2 Maskable Interrupts

All maskable interrupts are generated by on-chip peripherals, with the exception of the  $\overline{\text{IRQ}}$  pin. This input can be connected through a wired-OR network to external devices. When one of these devices pulls  $\overline{\text{IRQ}}$  low, a software accessible interrupt flag is set. When enabled, this flag causes a constant request for interrupt service. After the flag is cleared, the service request is released.  $\overline{\text{IRQ}}$  is low-level sensitive by default, but can be set for falling-edge sensitivity by the IRQE bit in the OPTION register (see Figure 5-6).



Can be written only once in first 64 cycles out of reset in normal modes or at any time in special modes

Figure 5-6. System Configuration Options Register (OPTION)

IRQE — Configure IRQ for Edge-Sensitive Operation Bit

This bit can be written only once during the first 64 E-clock cycles after reset in normal modes.

0 = Low-level recognition

1 = Falling-edge recognition

# 5.6 Reset and Interrupt Priority

A hardware priority scheme determines which reset or interrupt is serviced first when simultaneous requests occur.

The six highest-priority interrupt sources are not maskable. The priority arrangement for these sources is:

- 1. POR or RESET pin
- 2. Clock monitor reset
- 3. COP watchdog reset
- 4. XIRQ interrupt
- 5. Illegal opcode interrupt
- 6. Software interrupt (SWI)

The maskable interrupt sources have this priority arrangement:

- 1. IRQ
- 2. Real-time interrupt
- 3. Timer input capture 1
- Timer input capture 2
- 5. Timer input capture 3
- 6. Timer output compare 1
- Timer output compare 2
- Timer output compare 3
- 9. Timer output compare 4
- 10. Timer input capture 4/output compare 5
- 11. Timer overflow
- 12. Pulse accumulator overflow
- 13. Pulse accumulator input edge
- 14. SPI transfer complete
- 15. SCI system

Any single maskable interrupt can be given priority over other maskable interrupts by writing the appropriate value to the PSEL bits in the HPRIO register (see **Figure 5-7**). An interrupt that is assigned highest priority is still subject to global masking by the I bit in the CCR or by any associated local bits. Interrupt vectors are not affected by priority assignment.



Figure 5-7. Highest Priority I-Bit Interrupt and Miscellaneous Register (HPRIO)

**NOTE:** To avoid race conditions, HPRIO is designed so that bits PSEL[4:0] can be written only while the I-bit is set (interrupts are inhibited).

PSEL[4:0] — Priority Select Bits

These bits select one interrupt source to have the highest priority, as explained in **Table 5-7**.

# 5.7 Reset and Interrupt Processing

This section presents flow diagrams of the reset and interrupt processes. Figure 5-8 illustrates how the CPU begins from a reset and how interrupt detection relates to normal opcode fetches. Figure 5-9 is an expansion of a block in Figure 5-8 and illustrates interrupt priorities. Figure 5-10 shows the resolution of interrupt sources within the SCI subsystem.

**Table 5-7. Highest Priority Interrupt Selection** 

| PSELx |   |   | Intervient Course Brometed |   |                                         |
|-------|---|---|----------------------------|---|-----------------------------------------|
| 4     | 3 | 2 | 1                          | 0 | Interrupt Source Promoted               |
| 0     | 0 | 0 | Х                          | Х | Reserved (default to IRQ)               |
| 0     | 0 | 1 | 0                          | 0 | Reserved (default to IRQ)               |
| 0     | 0 | 1 | 0                          | 1 | Reserved (default to IRQ)               |
| 0     | 0 | 1 | 1                          | 0 | ĪRQ                                     |
| 0     | 0 | 1 | 1                          | 1 | Real-time interrupt                     |
| 0     | 1 | 0 | 0                          | 0 | Timer input capture 1                   |
| 0     | 1 | 0 | 0                          | 1 | Timer input capture 2                   |
| 0     | 1 | 0 | 1                          | 0 | Timer input capture 3                   |
| 0     | 1 | 0 | 1                          | 1 | Timer output compare 1                  |
| 0     | 1 | 1 | 0                          | 0 | Timer output compare 2                  |
| 0     | 1 | 1 | 0                          | 1 | Timer output compare 3                  |
| 0     | 1 | 1 | 1                          | 0 | Timer output compare 4                  |
| 0     | 1 | 1 | 1                          | 1 | Timer output compare 5/input capture 4  |
| 1     | 0 | 0 | 0                          | 0 | Timer overflow                          |
| 1     | 0 | 0 | 0                          | 1 | Pulse accumulator overflow              |
| 1     | 0 | 0 | 1                          | 0 | Pulse accumulator input edge            |
| 1     | 0 | 0 | 1                          | 1 | SPI serial transfer complete            |
| 1     | 0 | 1 | 0                          | 0 | SCI serial system                       |
| 1     | 0 | 1 | 0                          | 1 | Reserved (default to $\overline{IRQ}$ ) |
| 1     | 0 | 1 | 1                          | 0 | Reserved (default to $\overline{IRQ}$ ) |
| 1     | 0 | 1 | 1                          | 1 | Reserved (default to $\overline{IRQ}$ ) |
| 1     | 1 | Х | Х                          | Х | Reserved (default to $\overline{IRQ}$ ) |



Figure 5-8. Processing Flow Out of Reset (Sheet 1 of 2)



Figure 5-8. Processing Flow Out of Reset (Sheet 2 of 2)



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



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



Figure 5-10. Interrupt Priority Resolution Within SCI System

# 5.8 Low-Power Operation

The MCU contains two software instructions, WAIT and STOP, to reduce power consumption when processing is not required. Both instructions suspend operation until a reset or interrupt occurs while retaining register and RAM contents. The wait condition suspends processing, reducing power consumption to an intermediate level. The stop condition turns off all on-chip clocks as well and reduces power consumption to an absolute minimum.

## **Resets and Interrupts**

#### 5.8.1 Wait Mode

The WAI opcode places the MCU in the wait condition, during which the CPU registers are stacked and CPU processing is suspended until a qualified interrupt is detected. The interrupt can be an external  $\overline{IRQ}$ , an  $\overline{XIRQ}$ , or any of the internally generated interrupts, such as the timer or serial interrupts. The on-chip crystal oscillator remains active throughout the wait standby period.

The reduction of power in the wait condition depends on how many internal clock signals driving on-chip peripheral functions can be shut down. The CPU is always shut down during WAIT. While in the wait state, the address/data bus repeatedly runs read cycles to the address where the CCR contents were stacked. The MCU leaves the wait state when it senses any interrupt that has not been masked.

The free-running timer system is shut down only if maskable interrupts are disabled (I bit is set) and the COP system is disabled (NOCOP is set). Other systems can be shut down through the software-controlled configuration control bits, including the SPI system (SPE control bit), the SCI transmitter (TE bit), and the SCI receiver (RE bit). Net power reduction in WAIT depends on which of these features is disabled.

### 5.8.2 Stop Mode

The STOP instruction halts all system clocks, including the crystal oscillator, thereby minimizing power consumption. The S bit in the CCR must be cleared to place the MCU in the stop condition; otherwise, the stop opcode is treated as a no-operation (NOP). To exit STOP and resume normal processing, a logic low level must be applied to one of the external interrupt pins (IRQ or XIRQ) or to the RESET pin. A pending edge-triggered IRQ can also bring the CPU out of stop.

Because all clocks are stopped in this mode, all internal peripheral functions also stop. RAM and register contents are preserved as long as  $V_{DD}$  power is maintained. The CPU state and I/O pin levels are static and are not altered by STOP, so the MCU resumes processing seamlessly after the system is reactivated by an interrupt. However, if a reset is used

to restart the system, a normal reset sequence results and all pins and registers are reinitialized.

To use the IRQ pin as a means of recovering from STOP, the I bit in the CCR must be clear (IRQ not masked). The XIRQ pin can be used to wake up the MCU from STOP regardless of the state of the X bit in the CCR, although the state of this bit does affect the recovery sequence. If X is clear (XIRQ not masked), the MCU executes a normal XIRQ service routine. If X is set (XIRQ masked or inhibited), then processing continues with the instruction that immediately follows the STOP instruction, and no XIRQ interrupt service is requested or pending.

Executing a STOP instruction requires special consideration when the clock monitor is enabled. Because the stop function halts all clocks, the clock monitor function will generate a reset sequence if it is enabled at the time the stop mode was initiated. To prevent this, clear the CME and FCME bits in the OPTION register before executing a STOP instruction to disable the clock monitor. After recovery from STOP, set the CME bit to enable the clock monitor.

Systems using the internal oscillator require a delay after restart upon leaving STOP to allow the oscillator to stabilize. If a stable external oscillator is used, the DLY control bit in the OPTION register can be used to bypass this startup delay (see Figure 5-11). Reset sets the DLY control bit; it can be cleared during initialization. Do not use reset to recover from STOP if the DLY is to be bypassed, since reset sets the DLY bit again, causing the restart delay. This same delay will follow a power-on reset, regardless of the state of the DLY control bit, but does not apply to a reset while the clocks are running.



1. Can be written only once in first 64 cycles out of reset in normal modes or at any time in special modes

Figure 5-11. System Configuration Options Register (OPTION)

### DLY — Enable Oscillator Startup Delay Bit

This bit is set during reset and can be written only once during the first 64 E-clock cycles after reset in normal modes. This bit can be used to inhibit the oscillator startup delay after reset when using an external clock source.

- 0 = No stabilization delay on exit from STOP
- 1 = Stabilization delay enabled on exit from STOP

#### 5.8.3 Slow Mode

Slow mode is a software selectable feature on M68HC(7)11KS devices that allows the user to connect, under software control, an extra divide-by-16 between the oscillator and the internal clock. This feature permits a slow down of all the internal operations reducing power consumption.

When WAI is used for power reduction, the slow mode helps further reduce the power. Control of slow mode is performed in the system configuration options 3 register (OPT3). See Figure 5-12.



Figure 5-12. System Configuration Options 3 Register (OPT3)

SM — Slow-Mode Enable Bit

Read and write at any time

- 1 = When the SM bit is asserted, a 16-clock divider is connected between the oscillator and the internal clock. This causes the system clock to run 16 times slower than normal. All modules of the MCU slow down, including the timer, SCI, SPI, and A/D. It is also cleared in hardware when entering stop mode or when reset, including POR, is asserted low.
- 0 = When the SM bit is negated, the divider is disconnected and the system runs at normal bus speed.

**NOTE:** The slow mode function should not be enabled while using the A/D converter or during an erase/program operation of the EEPROM, unless the internal RC oscillator is turned on.

The clock monitor function should not be used if the resultant E clock will be slower than 200 kHz.



Figure 5-13. Slow Mode Example for M68HC(7)11KS Devices Only

# Resets and Interrupts

# Section 6. Parallel Input/Output

### 6.1 Contents

| 6.2  | Introduction                 |
|------|------------------------------|
| 6.3  | Port A                       |
| 6.4  | Port B                       |
| 6.5  | Port C                       |
| 6.6  | Port D                       |
| 6.7  | Port E                       |
| 6.8  | Port F                       |
| 6.9  | Port G                       |
| 6.10 | Port H                       |
| 6.11 | Internal Pullup Resistors147 |

### 6.2 Introduction

The M68HC11K series MCUs contain eight input/output (I/O) ports, A through H. All ports can provide general-purpose I/O (GPIO) as well as their specialized functions, as explained in **2.11 Port Signals** and summarized in **Table 6-1**.

| Port   | Input<br>Pins | Output<br>Pins | Bidirectional<br>Pins | Shared Functions     |
|--------|---------------|----------------|-----------------------|----------------------|
| Port A | _             | _              | 8                     | Timer                |
| Port B | _             | _              | 8                     | High-order address   |
| Port C | _             | _              | 8                     | Data bus             |
| Port D | _             | _              | 6                     | SCI and SPI          |
| Port E | 8             | _              | _                     | A/D converter        |
| Port F | _             | _              | 8                     | Low-order address    |
| Port G | _             | _              | 8 <sup>(1)</sup>      | Memory expansion     |
| Port H | _             | _              | 8 <sup>(2)</sup>      | Chip selects and PWM |

**Table 6-1. Port Configuration** 

Each of the ports has an associated data register (PORTx). Each port, except port E, also has an associated data direction register (DDRx). When a port is configured for GPIO, its DDR determines whether port pins function as inputs or outputs. A port's special functions override the DDR when they are enabled.

Writes to any port, except port E, are stored in internal latches. The latches drive the port pins only when they are configured as general-purpose outputs.

When software reads a port pin configured for GPIO, the MCU returns the physical pin level, not the port register value. This applies to both inputs and outputs. The only exception applies to ports C and D in wired-OR mode. When they are configured as outputs, a read returns the pin driver levels.

<sup>1.</sup> KS devices do not contain port G[6:0], so they have only one bidirectional pin on this port.

<sup>2.</sup> KS devices do not contain port H[7:4], so they have only four bidirectional pins on this port.

Ports B, F, G, and H contain on-chip pullup devices which are enabled by the port pullup assignment register (PPAR) described in **6.11 Internal Pullup Resistors**.

At reset, the ports are configured as high-impedance GPIO inputs (except for ports B, C, F, and port G pin 7 in expanded modes). The contents of the data latches is undefined. If any of the bidirectional pins are changed to outputs before writing to the associated data registers, the undefined contents will be driven on the pins. This is indicated by the letter U in the register descriptions that follow.

NOTE:

Throughout this manual, the registers are discussed by function. In the event that not all bits in a register are referenced, the bits that are not discussed are shaded.

### 6.3 Port A

Port A provides the I/O lines for the timer functions and pulse accumulator. The eight port A bits (PA[7:0]) are configured as high-impedance general-purpose inputs out of reset. Writes to DDRA can change any of the bits to outputs. Writes to timer registers enable the various timer functions (see **Section 9. Timing System**).



Figure 6-1. Port A Data Register (PORTA)



Figure 6-2. Port A Data Direction Register (DDRA)

DDA[7:0] — Data Direction for Port A Bits
0 = Input
1 = Output

### 6.4 Port B

The state of port B (PB[7:0]) at reset is mode dependent. In single-chip or bootstrap modes, port B pins are high-impedance inputs with selectable internal pullup resistors (see **6.11 Internal Pullup Resistors**). Writes to DDRB can change any of the bits to outputs. In expanded or test modes, port B pins provide the high-order address lines ADDR[15:8] for external memory devices.



Figure 6-3. Port B Data Register (PORTB)



Figure 6-4. Port B Data Direction Register (DDRB)

DDB[7:0] — Data Direction for Port B Bits
0 = Input
1 = Output

### 6.5 Port C

The state of port C at reset is mode dependent. In single-chip or bootstrap modes, port C pins (PC[7:0]) are high-impedance inputs. Writes to DDRC can change any of the bits to outputs. In expanded or test modes, port C pins provide the data lines (DATA[7:0]) for external memory devices. The MCU's internal data bus can also be driven on port C by setting the IRVNE bit in the system configuration options register (OPT2). See **Figure 6-7**.

When port C functions as GPIO (single-chip mode), it can be configured for wired-OR operation by setting the CWOM bit in the OPT2 register. This disables port C's P-channel drivers, effectively generating open-drain-type outputs. To output a logic 0 on a wired-OR pin, the MCU turns on its N-channel driver. To generate a logic 1, both P- and N-channel drivers are turned off, presenting a high-impedance state which requires an external pullup resistor to apply the appropriate voltage level.



Figure 6-5. Port C Data Register (PORTC)



Figure 6-6. Port C Data Direction Register (DDRC)

DDC[7:0] — Data Direction for Port C Bits

0 = Input

1 = Output



1. Not available on KS devices

Figure 6-7. System Configuration Options 2 Register (OPT2)

CWOM — Port C Wired-OR Mode Bit

0 = Port C operates normally.

1 = Port C outputs are open drain.

IRVNE — Internal Read Visibility/Not E Bit

In expanded modes, setting this bit drives MCU's internal data bus on port C.

0 = No internal read visibility on external data bus

1 = Data from internal reads is driven on port C.

In single-chip modes, setting this bit inhibits the E clock driver, and the E pin is pulled low

0 = E clock drives the E pin.

1 = E pin is driven low.

**NOTE:** IRVNE can be written only once after reset. The default value of IRVNE after reset is low.

### 6.6 Port D

The six port D bits, PD[5:0] function as the serial communication interface (see Section 7. Serial Communications Interface (SCI)) and the serial peripheral interface (see Section 8. Serial Peripheral Interface (SPI)) when these functions are enabled by software. They are high-impedance general-purpose inputs out of reset; DDRD can be used to change any of the pins to outputs.



Figure 6-8. Port D Data Register (PORTD)



Figure 6-9. Port D Data Direction Register (DDRD)

DDD[5:0] — Data Direction for Port D Bits
0 = Input
1 = Output

### 6.7 Port E

Port E, PE[7:0], is the only port that functions as input only, and its pins are configured as high-impedance inputs out of reset. It also serves as the analog input for the analog-to-digital converter when this function is enabled by software (see **Section 10. Analog-to-Digital (A/D) Converter**).

**NOTE:** PORT E should not be read during the sample portion of an A/D conversion.



Figure 6-10. Port E Data Register (PORTE)

### 6.8 Port F

The state of port F (PF[7:0]) at reset is mode dependent. In single-chip or bootstrap modes, port F pins are high-impedance inputs with selectable internal pullup resistors (see **6.11 Internal Pullup Resistors**). Writes to DDRF can change any of the bits to outputs. In expanded or test modes, port F pins provide low-order address lines, ADDR[7:0], for external memory devices.



Figure 6-11. Port F Data Register (PORTF)



Figure 6-12. Port F Data Direction Register (DDRF)

DDF[7:0] — Data Direction for Port F Bits
0 = Input
1 = Output

### 6.9 Port G

The state of port G pin 7 (PG7) at reset is mode dependent. In single-chip or bootstrap modes, it is a high-impedance input; its data direction can be changed through DDRG. In expanded and special test modes, PG7 functions as the R/W line to control the direction of data flow between the MCU and external memory devices.

Port G pins (PG[6:0]) reset to high-impedance inputs in any mode. Data direction can be changed through DDRG. Port G bits [5:0] can serve as memory expansion address lines (see 11.3 Memory Expansion) in expanded and special test modes. M68HC11KS devices do not contain these pins.

All eight port G pins have selectable internal pullup resistors (see 6.11 Internal Pullup Resistors).



1. Not available on KS devices

Figure 6-13. Port G Data Register (PORTG)



1. Not available on KS devices

Figure 6-14. Port G Data Direction Register (DDRG)

DDG[7:0] — Data Direction for Port G Bits
0 = Input
1 = Output

### 6.10 Port H

The state of port H pin 7 (PH7) at reset is mode dependent. In single-chip or bootstrap modes, it is a high-impedance input; its data direction can be changed through DDRH. In expanded and special test modes PH7 is the program chip select line, CSPROG at reset, but can be reconfigured for GPIO (see 11.4 Chip Selects).

Port H pins (PH[6:0]) reset to high-impedance inputs in any mode. Data direction can be changed through DDRH. Except for the M68HC11KS devices, bits 6:4 can serve as chip select lines in expanded and special test modes (see 11.4 Chip Selects). Pins 3:0 can be configured as pulse-width modulator outputs (see 9.9 Pulse-Width Modulator (PWM)) in any mode.

All eight port H pins have selectable internal pullup resistors (see **6.11 Internal Pullup Resistors**).



1. Not available on KS devices

Figure 6-15. Port H Data Register (PORTH)



1. Not available on KS devices

Figure 6-16. Port H Data Direction Register (DDRH)

DDH[7:0] — Data Direction for Port H Bits 0 = Input 1 = Output

## 6.11 Internal Pullup Resistors

M68HC11KS series devices contain selectable internal pullup resistors for ports B, F, G, and H. The resistors for each port are enabled by setting the corresponding bit in the PPAR register. PPAR itself must be enabled by setting the PAREN bit in the system configuration register (CONFIG). Refer to Figure 6-17 and Figure 6-18.



Figure 6-17. Port Pullup Assignment Register (PPAR)

xPPUE — Port x Pin Pullup Enable Bits

Only active when enabled by the PAREN bit in the CONFIG register

0 = Port x pin on-chip pullup devices disabled

1 = Port x pin on-chip pullup devices enabled

**NOTE:** FPPUE and BPPUE do not apply in expanded mode because port F and B are address outputs.



Figure 6-18. System Configuration Register (CONFIG)

**NOTE:** CONFIG is writable once in normal modes and writable at any time in special modes.

PAREN — Pullup Assignment Register Enable Bit

0 = PPAR register disabled

1 = PPAR register enabled; pullups can be enabled through PPAR

# Parallel Input/Output

# **Section 7. Serial Communications Interface (SCI)**

### 7.1 Contents

| Introduction                             |
|------------------------------------------|
| Data Format                              |
| Transmit Operation                       |
| Receive Operation                        |
| Wakeup Feature                           |
| Short Mode Idle Line Detection157        |
| Baud Rate Selection157                   |
| SCI Registers                            |
| Serial Communications Control Register 1 |
| Serial Communications Control Register 2 |
| Serial Communication Status Register 1   |
| Serial Communication Status Register 2   |
| Serial Communications Data Register      |
|                                          |

### 7.2 Introduction

The serial communications interface (SCI) is a universal asynchronous receiver transmitter (UART) employing a standard non-return-to-zero (NRZ) format. Several baud rates are available. The SCI transmitter and receiver are independent, but they use the same data format and baud rate.

# **Serial Communications Interface (SCI)**

The M68HC11K series offers several enhancements to the basic MC68HC11 SCI, including:

- 13-bit modulus prescaler in the baud generator
- Receiver-active flag
- Transmitter and receiver hardware parity
- Accelerated idle line detection

### 7.3 Data Format

The SCI uses the standard non-return to zero mark/space data format illustrated in **Figure 7-1**.



Figure 7-1. SCI Data Formats

Data is transmitted in frames consisting of a start bit, a word of eight or nine data bits, and a stop bit. The step-by-step transmission procedure is:

- 1. The transmission line is idle before a message is transmitted. This means that the line is in a logic 1 state for at least one frame time.
- 2. A start bit, logic 0, is transmitted, indicating the start of a frame.
- 3. An 8-bit or 9-bit word is transmitted, least significant bit (LSB) first.
- 4. A stop bit, logic 1, is transmitted to indicate the end of a frame.
- 5. An optional number of breaks can be transmitted. A break is the transmission of a logic low state for one frame time. After the last break character is sent, the line goes high for at least one bit time.

- 6. Steps 2-5 are repeated until the entire message is sent.
- 7. The line returns to idle status.

# 7.4 Transmit Operation

Transmission starts by writing a data character to the 2-byte SCI data register (SCDRH and SCDRL). The MCU parallel-loads the character into a serial shift register which shifts the data out on the transmission pin. This double-buffered operation allows transmission of the current character while the MCU loads the next one. The output of the serial shift register drives the TxD pin as long as the transmit enable (TE) bit of serial communication control register 2 (SCCR2) is set.

Two flags in serial communication status register 1 (SCSR1) alert the MCU of transmission status. The TDRE (transmit data register empty) flag is set when the SCDR loads its contents into the shift register; this flag can generate an interrupt if the TIE (transmit interrupt enable) bit in SCCR2 is set. The TC (transmit complete) flag is set when transmission is complete (line idle); this can also generate an interrupt if the TCIE (transmit complete interrupt enable) bit in SCSR1 is set. The TDRE and TC flags are normally set when software sets the TE bit to enable the transmitter. See Figure 5-10. Interrupt Priority Resolution Within SCI System for a flow diagram of SCI interrupts.

If interrupts are not enabled, the status flags can be read by software (polled) to determine when the corresponding conditions exist. Status flags are set automatically by hardware logic conditions, but must be cleared by software. The software clearing sequence for these flags is automatic. Functions that are normally performed in response to the status flags also satisfy the conditions of the clearing sequence.

When software clears the TE bit, the TxD pin reverts to its general-purpose I/O function (PD1). The transmitter completes transmission of a character in progress before actually shutting down; other characters waiting in the transmit queue are lost. The TC and TDRE flags are set at the completion of this last character, even though TE has been disabled. Only an MCU reset can abort transmission in midcharacter.



Figure 7-2 is a block diagram of the SCI transmitter.

Figure 7-2. SCI Transmitter Block Diagram

# 7.5 Receive Operation

During receive operations, data from the TxD pin is shifted into the serial shift register. A completed word is parallel-loaded to a receive data register (RDR), which can be read through SCDRH/L. This double-buffered operation allows reception of the current character while the MCU reads the previous character.

The SCI receiver has seven status flags, summarized in Table 7-1.

Interrupt Set When Flag Name **Enable Bit** Receive data Character transferred from shift register **RDRF** RIE register full to RDR Idle-line IDLE ILIE Active transmit line goes idle detected Character ready for RDR while previous OR Overrun error RIE character unread NF Noise error Samples of data bit not unanimous FE Frame error 0 detected where stop bit expected Calculated parity does not match data PF Parity error parity bit RAF Receiver active A character is being received

Table 7-1. SCI Receiver Flags

Three of the flags can generate interrupt requests if the corresponding enable bits in SCCR2 are set. The status flags are set by the SCI logic in response to specific conditions in the receiver. These flags can be read (polled) at any time by software. Each bit except RAF is cleared by reading SCSR1 and SCDR sequentially.

- The receive data register full (RDRF) flag is set when the last bit
  of a character is received and data is transferred from the shift
  register to the RDR.
- The IDLE flag is set after a transition on the RxD line from an active state to an idle state. This prevents repeated interrupts during the time RxD remains idle.

# **Serial Communications Interface (SCI)**

- The overrun error (OR) flag is set instead of the RDRF bit when the next byte is ready to be transferred from the receive shift register to the RDR and the RDR is already full. The data in the shift register is lost and the data that was already in RDR is not disturbed.
- The noise flag (NF) is set if there is noise on any of the received bits, including the start and stop bits. The data recovery circuit takes three samples of each bit and indicates noise if any set of three samples is not unanimous. NF is not set until the entire character is received and transferred to the RDR, when RDRF is set.
- The framing error (FE) flag is set when no stop bit is detected in the received data character. FE is set at the same time as RDRF.
   If the byte received causes both framing and overrun errors, the processor only recognizes the overrun error. The framing error flag inhibits further data transfer into the RDR until the flag is cleared.
- The parity error (PE) flag indicates that the parity bit of a received character does not match the parity calculated by hardware.
- The receiver active flag (RAF) is a read-only bit that is set during data reception and cleared when the line goes idle. This is the only flag cleared by hardware.

Figure 7-3 is a block diagram of the SCI receiver.



Figure 7-3. SCI Receiver Block Diagram

# **Serial Communications Interface (SCI)**

## 7.6 Wakeup Feature

The wakeup feature reduces SCI service overhead in multiple receiver systems. If a system generates address information at the beginning of every message, each receiver can determine whether or not it is the intended recipient of a message by evaluating the first character(s) through software.

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. It does this by setting the RWU (receiver wakeup) bit in SCI control register 2 (SCCR2), which inhibits all receiver-related status flags (RDRF, IDLE, OR, NF, FE, PF, and RAF). A new message clears the receiver's RWU bit, enabling it to evaluate the new address information. Although RWU can be cleared by a software write to SCCR2, this is rarely done because hardware clears RWU automatically.

Two methods of wakeup are available:

- Idle line wakeup A sleeping receiver wakes up as soon as the RxD line becomes idle (for example, in a logic 1 state for at least one frame time). A system using this type of wakeup must provide at least one character time of idle between messages to wake up sleeping receivers and must not allow any idle time between characters within a message.
- Address mark wakeup Uses the most significant bit (MSB) to distinguish address characters (MSB = 1) from data characters (MSB = 0). A sleeping receiver wakes up whenever it receives an address character. Unlike the idle line method, address mark wakeup allows idle periods within messages and does not require idle time between messages. However, message processing is less efficient because the start bit of each character must be evaluated.

## 7.7 Short Mode Idle Line Detection

This feature can increase system communication speed by reducing the amount of time between messages. Setting the ILT bit in SCCR1 allows the SCI receiver to detect the consecutive 1s of an idle period before the stop bit of an incoming character is received. If the last few bits of the character are 1s, they are counted as the first high bits in the frame of 1s comprising the idle period following the character.

**NOTE:** Extra care may be needed to prevent premature detection of an idle line condition.

### 7.8 Baud Rate Selection

The baud rate generator for the SCI includes a 13-bit modulus prescaler driven by the system crystal clock (EXTAL). Writing to the SCI baud rate register (SCBDH/L) selects the prescaler value. See **Figure 7-4**.



Figure 7-4. SCI Baud Generator Circuit Diagram

## 7.9 SCI Registers

The six addressable registers in the SCI are:

- SCI baud rate control register (SCBDH and SCBDL)
- Serial communications control register 1 (SCCR1)
- Serial communications control register 2 (SCCR2)
- Serial communication status register 1 (SCSR1)
- Serial communication status register 2 (SCSR2)
- Serial communications data register (SCDRH and SCDRL)

### **NOTE:**

Throughout this manual, the registers are discussed by function. In the event that not all bits in a register are referenced, the bits that are not discussed are shaded.

### 7.9.1 SCI Baud Rate Control Register

This register selects the 13-bit divisor shown in **Figure 7-4** to generate the SCI baud rate. (See **Table 7-2**.) Normally, this register is written once during initialization, but it can be changed at any time.



Figure 7-5. SCI Baud Rate Control Register High (SCBDH)



Figure 7-6. SCI Baud Rate Control Register Low (SCBDL)

BTST — Baud Register Test Bit

BTST is for factory use only and is only accessible in special test mode.

BSPL — Baud Rate Counter Split Bit

BSOK is for factory use only and is only accessible in special test mode.

SBR[12:0] — SCI Baud Rate Select Bits

These bits represent the value BR in:

SCI baud rate control

register value = (EXTAL/32)/target baud rate

Table 7-2. SCI+ Baud Rates

| EXTAL Frequencies   |                                       |          |         |          |         |          |         |          |         |        |  |
|---------------------|---------------------------------------|----------|---------|----------|---------|----------|---------|----------|---------|--------|--|
| EXTAL Freq. 8.0 MHz |                                       | 12.0 MHz |         | 16.0 MHz |         | 20.0 MHz |         | 24.0 MHz |         |        |  |
| E Clock Freq.       | eq. 2.0 MHz                           |          | 3.0 MHz |          | 4.0 MHz |          | 5.0 MHz |          | 6.0 MHz |        |  |
| Target              | SCI Baud Rate Control Register Values |          |         |          |         |          |         |          |         |        |  |
| Baud Rate           | Decimal                               | Hex      | Decimal | Hex      | Decimal | Hex      | Decimal | Hex      | Decimal | Hex    |  |
| 110 baud            | 2273                                  | \$08E1   | 3409    | \$0D51   | 4545    | \$11C1   | 5682    | \$1632   | 6818    | \$1AA2 |  |
| 150 baud            | 1667                                  | \$0683   | 2500    | \$09C4   | 3333    | \$0D05   | 4167    | \$1047   | 5000    | \$1388 |  |
| 300 baud            | 833                                   | \$0341   | 1250    | \$04E2   | 1667    | \$0683   | 2083    | \$0823   | 2500    | \$09C4 |  |
| 600 baud            | 417                                   | \$01A1   | 625     | \$0271   | 833     | \$0341   | 1042    | \$0412   | 1250    | \$04E2 |  |
| 1200 baud           | 208                                   | \$00D0   | 313     | \$0139   | 417     | \$01A1   | 521     | \$0209   | 625     | \$0271 |  |
| 2400 baud           | 104                                   | \$0068   | 156     | \$009C   | 208     | \$00D0   | 260     | \$0104   | 313     | \$0139 |  |
| 4800 baud           | 52                                    | \$0034   | 78      | \$004E   | 104     | \$0068   | 130     | \$0082   | 156     | \$009C |  |
| 9600 baud           | 26                                    | \$001A   | 39      | \$0027   | 52      | \$0034   | 65      | \$0041   | 78      | \$004E |  |
| 19200 baud          | 13                                    | \$000D   | 20      | \$0014   | 26      | \$001A   | 33      | \$0021   | 39      | \$0027 |  |
| 38400 baud          | _                                     | _        | _       | _        | 13      | \$000D   | 16      | \$0010   | 20      | \$0014 |  |
| 76800 baud          | _                                     | _        | _       | _        | _       | _        | 8       | \$0008   | 10      | \$000A |  |

## 7.9.2 Serial Communications Control Register 1



Figure 7-7. SCI Control Register 1 (SCCR1)

## LOOPS — SCI Loop Mode Enable Bit

Both the transmitter and receiver must be enabled to use the loop mode. When the loop mode is enabled, the TxD pin is driven high (idle line state) if the transmitter is enabled.

- 0 = SCI transmit and receive operate normally.
- 1 = SCI transmit and receive are disconnected from TxD and RxD pins, and transmitter output is fed back into the receiver input.

### WOMS — Wired-OR Mode for SCI Pins PD[1:0] Bits

See also **8.6.1 Serial Peripheral Control Register** for a description of the DWOM (port D wired-OR mode) bit in the serial peripheral control register (SPCR).

- 0 = TxD and RxD operate normally.
- 1 = TxD and RxD are open drains if operating as outputs.

#### M — Mode (SCI Word Size) Bit

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

### WAKE — Wakeup Mode Bit

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

### ILT — Idle Line Type Bit

- 0 = Short (SCI counts consecutive 1s after start bit.)
- 1 = Long (SCI counts one only after stop bit.)

PE — Parity Enable Bit

0 = Parity disabled

1 = Parity enabled

### PT — Parity Type Bit

- 0 = Parity even (even number of 1s causes parity bit to be 0, odd number of 1s causes parity bit to be 1)
- 1 = Parity odd (odd number of 1s causes parity bit to be 0, even number of 1s causes parity bit to be 1)

## 7.9.3 Serial Communications Control Register 2



Figure 7-8. SCI Control Register 2 (SCCR2)

TIE — Transmit Interrupt Enable Bit

0 = TDRE interrupts disabled

1 = SCI interrupt is requested when the TDRE status flag is set.

TCIE — Transmit Complete Interrupt Enable Bit

0 = TC interrupts disabled

1 = SCI interrupt is requested when the TC status flag is set.

RIE — Receiver Interrupt Enable Bit

0 = RDRF and OR interrupts disabled

1 = SCI interrupt is requested when the RDRF flag or OR flag is set.

ILIE — Idle Line Interrupt Enable Bit

0 = IDLE interrupts disabled

1 = SCI interrupt is requested when the IDLE status flag is set.

# **Serial Communications Interface (SCI)**

### TE — Transmitter Enable Bit

When TE goes from 0 to 1, one unit of idle character time (logic 1) is queued as a preamble.

0 = Transmitter disabled

1 = Transmitter enabled

#### RE — Receiver Enable Bit

0 = Receiver disabled

1 = Receiver enabled

### RWU — Receiver Wakeup Control

0 = Normal SCI receiver operation

1 = Wakeup is enabled and receiver interrupts are inhibited.

#### SBK — Send Break Bit

At least one character time of break is queued and sent each time SBK is written to 1. Multiple breaks may be sent if the transmitter is idle at the time the SBK bit is toggled on and off, as the baud rate clock edge could occur between writing the 1 and writing the 0 to SBK.

0 = Break generator off

1 = Break codes generated as long as SBK = 1

## 7.9.4 Serial Communication Status Register 1

The SCSR provides flags for various SCI conditions which can be polled or used to generate SCI system interrupts. To clear any set flag, read SCSR while the flag is set and then write to SCDR.



Figure 7-9. SCI Status Register 1 (SCSR1)

## TDRE — Transmit Data Register Empty Flag

TDRE is set when the SCDR transfers its contents to the transmission shift register.

0 = SCDR is full.

1 = SCDR is empty.

## TC — Transmit Complete Flag

TC is set when the final character in a message has been sent (no data, preamble, or break transmissions pending).

0 = Transmitter busy

1 = Transmitter idle

## RDRF — Receive Data Register Full Flag

RDRF is set when the shift register has received a complete character and transferred it to the receive data register.

0 = RDR not full

1 = RDR full

## IDLE — Idle Line Detected Flag

IDLE is set when a frame of all 1s is received after a message.

0 = RxD line is active.

1 = RxD line is idle.

## OR — Overrun Error Flag

OR is set if a new character is received before a previously received character is read from SCDR.

0 = No overrun

1 = Overrun detected

### NF — Noise Error Flag

NF is set after the last bit in a frame is received if the samples in the receiver's data recovery circuit are not unanimous for any of the bits, including start and stop bits.

0 = No noise detected

1 = Noise detected

# **Serial Communications Interface (SCI)**

FE — Framing Error Flag

FE is set when a 0 is detected where a stop bit (logic 1) was expected.

0 = Stop bit detected

1 = Logic 0 detected at the end of a character

PF — Parity Error Flag

PF is set if received data has incorrect parity. Clear PF by reading SCSR1.

0 = Parity disabled

1 = Parity enabled

### 7.9.5 Serial Communication Status Register 2



Figure 7-10. SCI Status Register 2 (SCSR2)

RAF — Receiver Active Flag

RAF is a read-only bit.

0 = Receiver is inactive.

1 = A character is being received.

## 7.9.6 Serial Communications Data Register

The SCDR is a parallel register that performs two functions. Received data in the RDR is read from this address when the SCI is receiving, and data to be transmitted is written to this address when the SCI is transmitting.



Figure 7-11. SCI Data Register (SCDR)

R8 and T8 — Receiver Bit 8 and Transmitter Bit 8

Ninth data bit is received or transmitted when the system is configured for 8-bit data using mark address wakeup.

R/T[7:0] — Receiver/Transmitter Bits [7:0]

# **Serial Communications Interface (SCI)**

# Section 8. Serial Peripheral Interface (SPI)

### 8.1 Contents

| 8.2                                              | Introduction                                                                                                                                                                                                                      |
|--------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 8.3                                              | SPI Functional Description                                                                                                                                                                                                        |
| 8.4<br>8.4.1<br>8.4.2<br>8.4.3<br>8.4.4<br>8.4.5 | SPI Signal Descriptions       170         Master In Slave Out (MISO)       170         Master Out Slave In (MOSI)       170         Serial Clock (SCK)       170         Slave Select (SS)       171         SPI Timing       171 |
| 8.5<br>8.5.1<br>8.5.2                            | SPI System Errors.172Mode Fault Error.172Write Collision Error.173                                                                                                                                                                |
| 8.6<br>8.6.1                                     | SPI Registers                                                                                                                                                                                                                     |
| 8.6.2<br>8.6.3                                   | Serial Peripheral Status Register                                                                                                                                                                                                 |
| 8.6.4<br>8.6.5                                   | Port D Data Direction Register                                                                                                                                                                                                    |

## 8.2 Introduction

The serial peripheral interface (SPI) provides synchronous communication between the MCU and peripheral devices such as transistor-transistor logic (TTL) shift registers, liquid crystal display (LCD) drivers, analog-to-digital (A/D) converter subsystems, and other processors. Synchronous communication requires a clock and, in the M68HC11 series, a slave-select signal, but provides substantially faster communication than the asynchronous SCI, which does not require this

# **Serial Peripheral Interface (SPI)**

extra hardware. The SPI system can send data at up to one half of the E-clock rate when configured as master and the full E-clock rate when configured as a slave.

# 8.3 SPI Functional Description

The SPI is a 4-wire, full-duplex communication system. Characters are eight bits, transmitted most significant bit (MSB) first. One master device exchanges data with one or more slave devices. Each device selects its mode by writing either a 1 (master) or 0 (slave) to the MSTR bit in the serial peripheral control register (SPCR). As a master device transmits data to a slave device via the MOSI (master out slave in) line, the slave transmits data to the master via the MISO (master in slave out) line. The master produces a common synchronization clock signal and drives it on its SCK (serial clock) pin, which is configured as an output. The slave SCK pin is configured as an input to receive the clock. An external logic low signal is applied to the slave select pin (SS) of each slave device for which a particular message is intended. Devices not selected (SS high) ignore the transmission.

Received characters are double-buffered. Serial input bits are fed into a shift register; when the last bit is received, the completed character is parallel-loaded to a read data buffer. This allows the next message to be received while the current message is being read. As long as the buffer is read before the next received character is ready to be transferred to the buffer, no overrun condition occurs.

Transmitted characters are not double-buffered, they are written directly to the output shift register. This means that new data for transmission cannot be written to the shift register until the previous transmission is complete. An attempt to write during data transmission will not go through; the transmission in progress will proceed undisturbed, and the MCU will set the write collision (WCOL) status bit in the serial peripheral status register (SPSR). After the last bit of a character is shifted out, the SPI transfer complete flag (SPIF) of the SPSR is set. This will also generate an interrupt if the SPIE (SPI interrupt enable) bit in the SPCR is set.

A single MCU register, the serial peripheral data register (SPDR) is used both to read input data from the read buffer and to write output data to the transmit shift register.

Figure 8-1 shows the SPI block diagram.



Figure 8-1. SPI Block Diagram

# **Serial Peripheral Interface (SPI)**

## 8.4 SPI Signal Descriptions

The four basic SPI signals (MISO, MOSI, SCK, and SS) are discussed for both the master and slave modes in the following paragraphs.

Every SPI output line must have its corresponding port D data direction register (DDRD) bit set. If this bit is clear, the line is disconnected from the SPI logic and becomes a general-purpose input line. SPI input lines are not affected by the data direction register.

## 8.4.1 Master In Slave Out (MISO)

The MISO is one of two unidirectional serial data lines in the SPI. It functions as an input in a master device and as an output in a slave device. The MISO line of a slave device is placed in the high-impedance state if the slave is not selected.

### 8.4.2 Master Out Slave In (MOSI)

This unidirectional serial data line is an output in a master device and an input in a slave device.

## 8.4.3 Serial Clock (SCK)

The serial clock (SCK) synchronizes data movement both in and out of all devices. Master and slave devices exchange a byte of information simultaneously during a sequence of eight clock cycles. SCK is generated by the master device so its SCK pin functions as an output. Slave devices receive this signal through their SCK pins, which are configured as inputs.

The SPI clock rate select bits in the master device determine the SCK clock rate. These bits are SPR[1:0] in the serial peripheral control register (SPCR) and SPR2 in the system configuration options 2 register (OPT2). These bits have no effect in a slave device.

# 8.4.4 Slave Select (SS)

The slave select (SS) input is used to target specific devices in the SPI system. It must be pulled low on a targeted slave device prior to any communication with a master and must remain low for the duration of the transaction. SS must always be high on any device in master mode. Pulling SS low on a master mode device generates a mode fault error (see 8.5.1 Mode Fault Error).

### 8.4.5 SPI Timing

Four possible timing relationships are available through control bits CPOL (clock polarity) and CPHA (clock phase) in the SPCR. These bits must be the same in both master and slave devices. The master device always places data on the MOSI line approximately a half-cycle before the SCK clock edge. This enables the slave device to latch the data. See Figure 8-2.

A write collision is normally a slave error because a slave has no control over when a master initiates a transfer. A master knows when a transfer is in progress, so there is no reason for a master to generate a write-collision error, although the SPI logic can detect write collisions in both master and slave devices.



Figure 8-2. Data Clock Timing Diagram

# **Serial Peripheral Interface (SPI)**

CPOL selects an active high or low clock edge. CPHA selects one of two transfer formats. When CPHA is cleared, the shift clock is ORed with  $\overline{SS}$ . Each slave's  $\overline{SS}$  pin must be pulled high before it writes the next output byte to its data register. If a slave writes to its data register while  $\overline{SS}$  is low, a write collision error occurs. When CPHA is set,  $\overline{SS}$  may be left low for several SPI characters. When there is only one SPI slave MCU, its  $\overline{SS}$  line may be tied to  $V_{SS}$  if CPHA = 1 at all times.

The SPI configuration determines the characteristics of a transfer in progress. For a master, a transfer begins when data is written to SPDR and ends when SPIF is set. For a slave with CPHA cleared, a transfer starts when SS goes low and ends when SS returns high. In this case, SPIF is set at the middle of the eighth SCK cycle when data is transferred from the shifter to the parallel data register, but the transfer is still in progress until SS goes high. For a slave with CPHA set, transfer begins when the SCK line goes to its active level, which is the edge at the beginning of the first SCK cycle. The transfer ends when SPIF is set. SCK in a slave must be inactive for at least two E-clock cycles between byte transfers.

# 8.5 SPI System Errors

Two types of errors can be detected by the SPI system:

- A mode fault error can occur when multiple devices attempt to act in master mode simultaneously.
- A write collision error results from an attempt to write data to the SPDR while a transmission is in progress.

### 8.5.1 Mode Fault Error

A mode fault error occurs when the SS input line of an SPI system configured as a master goes to active low, usually because two devices have attempted to act as master at the same time. The resulting contention between push-pull CMOS pin drivers can cause them permanent damage. The mode fault disables the drivers in an attempt to protect them. The MSTR control bit in the SPCR and all four DDRD

control bits associated with the SPI are cleared, effectively forcing the pins to be high-impedance inputs. The mode fault error flag (MODF) is set in the serial peripheral status register (SPSR). An interrupt is generated, subject to masking by the SPIE control bit and the I bit in the CCR. To disable the mode fault circuit, write a 1 to DDRD bit 5. This configures port D bit 5 as a general-purpose output rather than SS.

Other precautions may be necessary to prevent driver damage. For instance, if two devices are made masters at the same time, mode fault does not help protect either one unless one of them selects the other as slave. The amount of damage possible depends on the length of time both devices attempt to act as master.

#### 8.5.2 Write Collision Error

A write collision error occurs when the SPDR is written while a transmission is in progress. The SPDR is not double buffered in the transmit direction, so writes to the SPDR go directly into the SPI shift register, which would corrupt any transfer in progress. The MCU protects against this by preventing the write and generating the write collision error. The transmission continues undisturbed.

A write collision is normally a slave error because a slave has no control over when a master initiates a transfer. A master knows when a transfer is in progress, so there is no reason for a master to generate a write-collision error, although the SPI logic can detect write collisions in both master and slave devices.

# 8.6 SPI Registers

The three SPI registers provide control, status, and data storage functions respectively:

- Serial peripheral control register (SPCR)
- Serial peripheral status register (SPSR)
- Serial peripheral data register (SPDR)

# **Serial Peripheral Interface (SPI)**

**NOTE:** Throughout this manual, the registers are discussed by function. In the event that not all bits in a register are referenced, the bits that are not discussed are shaded.

### 8.6.1 Serial Peripheral Control Register



Figure 8-3. Serial Peripheral Control Register (SPCR)

SPIE — Serial Peripheral Interrupt Enable Bit

0 = SPI interrupt disabled

1 = SPI interrupt is enabled each time the SPIF or MODF status flag in SPSR is set.

SPE — Serial Peripheral System Enable Bit

0 = SPI off

1 = SPI on — PD[5:2] function as SPI signals

DWOM - Port D Wired-OR Mode Bit

DWOM affects only the four SPI pins on port D, PD[5:2]. See also **7.9.2 Serial Communications Control Register 1** for a discussion of the WOMS (wired-OR Mode for SCI pins) bit in the serial communications control register 1 (SCCR1).

0 = Normal CMOS outputs

1 = Open-drain outputs

MSTR — Master Mode Select Bit

0 = Slave mode

1 = Master mode

### CPOL — Clock Polarity Bit

When the clock polarity bit is cleared and data is not being transferred, the SCK pin of the master device has a steady state low value. When CPOL is set, SCK idles high.

### CPHA — Clock Phase Bit

The clock phase bit, in conjunction with the CPOL bit, controls the clock-data relationship between master and slave. The CPHA bit selects one of two different clocking protocols.

### SPR[1:0] — SPI Clock Rate Select Bits

On a master device, these two bits in conjunction with SPR2 in the OPT2 register select the baud rate to be used as SCK. See **Table 8-1**. These bits have no effect in slave mode.

Table 8-1. SPI+ Baud Rates

| EXTAL Frequencies        |                                             |                      |             |           |           |           |  |  |
|--------------------------|---------------------------------------------|----------------------|-------------|-----------|-----------|-----------|--|--|
| EXTAL Freq.              | 8.0 MHz 12.0 MHz 16.0 MHz 20.0 MHz 24.0 MHz |                      | Other EXTAL |           |           |           |  |  |
| E Clock Freq.            | 2.0 MHz                                     | 3.0 MHz              | 4.0 MHz     | 5.0 MHz   | 6.0 MHz   | EXTAL ÷ 4 |  |  |
| Control Bits<br>SPR[2:0] |                                             | E Clock<br>Divide by |             |           |           |           |  |  |
| 0 0 0                    | 1.0 MHz                                     | 1.5 MHz              | 2.0 MHz     | 2.5 MHz   | 3.0 MHz   | 2         |  |  |
| 0 0 1                    | 500 kHz                                     | 750 kHz              | 1.0 MHz     | 1.3 kHz   | 1.5 MHz   | 4         |  |  |
| 0 1 0                    | 125 kHz                                     | 187.5 kHz            | 250 kHz     | 312.5 kHz | 375.0 kHz | 16        |  |  |
| 0 1 1                    | 62.5 kHz                                    | 93.8 kHz             | 125 kHz     | 156.3 kHz | 187.5 kHz | 32        |  |  |
| 1 0 0                    | 250 kHz                                     | 375 kHz              | 500 kHz     | 625 kHz   | 750.0 kHz | 8         |  |  |
| 1 0 1                    | 125 kHz                                     | 187.5 kHz            | 250 kHz     | 312.5 kHz | 375.0 kHz | 16        |  |  |
| 110                      | 31.3 kHz                                    | 46.9 kHz             | 62.5 kHz    | 78.1 kHz  | 93.8 kHz  | 64        |  |  |
| 111                      | 15.6 kHz                                    | 23.4 kHz             | 31.3 kHz    | 39.1 kHz  | 46.9 kHz  | 128       |  |  |

## 8.6.2 Serial Peripheral Status Register



Figure 8-4. Serial Peripheral Status Register (SPSR)

## SPIF — SPI Transfer Complete Flag

SPIF is set upon completion of data transfer between the processor and the external device. If SPIF goes high, and if SPIE is set, a serial peripheral interrupt is generated. To clear the SPIF bit, read the SPSR with SPIF set, then access the SPDR. Unless SPSR is read (with SPIF set) first, attempts to write SPDR are inhibited.

### WCOL — Write Collision Bit

Clearing the WCOL bit is accomplished by reading the SPSR (with WCOL set) followed by an access of SPDR.

0 = No write collision

1 = Write collision

### MODF — Mode Fault Bit

To clear the MODF bit, read the SPSR (with MODF set), then write to the SPCR.

0 = No mode fault

1 = Mode fault

## 8.6.3 Serial Peripheral Data Register

The SPDR is used when transmitting or receiving data on the serial bus. Only a write to this register initiates transmission or reception of a byte, and this only occurs in the master device. At the completion of transferring a byte of data, the SPIF status bit is set in both the master and slave devices.

A read of the SPDR is actually a read of a buffer. To prevent an overrun and the loss of the byte that caused the overrun, the first SPIF must be cleared by the time a second transfer of data from the shift register to the read buffer is initiated.



Figure 8-5. Serial Peripheral Data Register (SPDR)

A write to SPDR goes directly to the transmission shift register.

A read of the SPDR retrieves data from the read data buffer.

## 8.6.4 Port D Data Direction Register



Figure 8-6. Port D Data Direction Register (DDRD)

### DDD5 Bit

Bit 5 of the port D data register (PD5) is dedicated as the slave select (SS) input. In SPI slave mode, DDD5 has no meaning or effect. In SPI master mode, DDD5 affects PD5 as follows:

0 = PD5 is an error-detect input to the SPI.

1 = PD5 is configured as a general-purpose output line.

## DDD[4:2] Bits

When the SPI is enabled, SPI input pins remain functioning regardless of the state of the corresponding DDD[4:2] bits. For SPI output pins, however, the corresponding DDD[4:2] bits must be set or the pins will function as general-purpose inputs.

## 8.6.5 System Configuration Options 2



<sup>1.</sup> Not available on M68HC11K devices

Figure 8-7. System Configuration Options 2 Register (OPT2)

### LSBF — Least Significant Bit First Enable Bit

Setting LSBF causes data to be transmitted LSB first (the default is MSB first). LSBF does not affect bit positions in the data register; reads and writes always have MSB in bit 7.

### SPR2 — SPI Clock Rate Select Bit

SPR2 adds a divide-by-4 prescaler to the SPI clock chain. With the two bits in the SPCR, this specifies the SPI clock rate. See **Table 8-1**.

# Serial Peripheral Interface (SPI)

# **Section 9. Timing System**

# 9.1 Contents

| 9.2                                                                         | Introduction                                                                                                                                                                                                                                                                                              |
|-----------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9.3                                                                         | Timer Structure183                                                                                                                                                                                                                                                                                        |
| 9.4<br>9.4.1<br>9.4.2<br>9.4.3<br>9.4.4<br>9.4.5                            | Input Capture and Output Compare Overview185Timer Counter Register188Timer Interrupt Flag 2 Register189Timer Interrupt Mask 2 Register189Port A Data Direction Register190Pulse Accumulator Control Register191                                                                                           |
| 9.5<br>9.5.1<br>9.5.2<br>9.5.3<br>9.5.4<br>9.5.5                            | Input Capture (IC)                                                                                                                                                                                                                                                                                        |
| 9.6<br>9.6.1<br>9.6.2<br>9.6.3<br>9.6.4<br>9.6.5<br>9.6.6<br>9.6.7<br>9.6.8 | Output Compare (OC)196Timer Output Compare Registers197Timer Input Capture 4/Output Compare 5 Register199Timer Interrupt Flag 1 Register199Timer Interrupt Mask 1 Register200Timer Control 1 Register200Timer Compare Force Register201Output Compare 1 Mask Register202Output Compare 1 Data Register202 |
| 9.7<br>9.7.1<br>9.7.2<br>9.7.3                                              | Pulse Accumulator (PA)                                                                                                                                                                                                                                                                                    |

# **Timing System**

| 9.7.4   | Timer Interrupt Mask 2 Register207                  |
|---------|-----------------------------------------------------|
| 9.7.5   | Pulse Accumulator Count Register                    |
| 9.8     | Real-Time Interrupt (RTI)                           |
| 9.8.1   | Timer Interrupt Flag 2 Register209                  |
| 9.8.2   | Timer Interrupt Mask 2 Register209                  |
| 9.8.3   | Pulse Accumulator Control Register210               |
| 9.9     | Pulse-Width Modulator (PWM)                         |
| 9.9.1   | PWM System Description211                           |
| 9.9.2   | Pulse-Width Modulation Control Registers213         |
| 9.9.2.1 | Pulse-Width Modulation Timer                        |
|         | Clock Select Register                               |
| 9.9.2.2 | Pulse-Width Modulation Timer Polarity Register 215  |
| 9.9.2.3 | Pulse-Width Modulation Timer Prescaler Register 215 |
| 9.9.2.4 | Pulse-Width Modulation Timer Enable Register 216    |
| 9.9.2.5 | Pulse-Width Modulation Timer                        |
|         | Counters1 to 4 Registers217                         |
| 9.9.2.6 | Pulse-Width Modulation Timer                        |
|         | Periods 1 to 4 Registers                            |
| 9.9.2.7 | Pulse-Width Modulation Timer                        |
|         | Duty Cycle 1 to 4 Registers                         |

### 9.2 Introduction

M68HC11 microcontrollers contain an extensive timing system to support a wide variety of timer-related functions. This section discusses the nature of the timing system and presents details of timer-related functions including:

- Input capture/output compare (IC/OC)
- Real-time interrupt (RTI)
- Pulse accumulator (PA)
- Pulse width modulation (PWM)

### 9.3 Timer Structure

As **Figure 9-1** shows, the primary system clocks, including the E clock and the internal PH2 bus clock, are derived from the oscillator output divided by four.



Figure 9-1. Timer Clock Divider Chains

The PH2 bus clock feeds four primary divider chains. The functions supplied by each of these chains are:

- 1. Serial peripheral interface (SPI)
- Input capture/output compare (IC/OC)
- 3. Pulse accumulator (PA)
- 4. RTI and COP watchdog circuit

The SPI prescale factor is determined by bits SPR[2] in the system configuration options 2 (OPT2) register and SPR[1:0] in the serial peripheral control register (SPCR). See **8.6.1 Serial Peripheral Control Register** and **8.6.5 System Configuration Options 2**.

The input capture and output compare functions are based on a 16-bit free-running counter, which is driven by the PH2 clock divided by a programmable prescaler. Bits PR[1:0] of the timer interrupt mask 2 (TMSK2) register enable the user to select one of four divisors: 1, 4, 8, or 16. The output of this prescaler, referred to as the main timer, feeds the divider chains for the pulse accumulator, RTI, and COP circuits as well as the free-running counter. **Table 9-1** shows main timer frequencies and periods available from the most common crystal inputs.

**Table 9-1. Main Timer Rates** 

| EXTAL Frequencies |                          |           |           |           |                |                     |
|-------------------|--------------------------|-----------|-----------|-----------|----------------|---------------------|
| EXTAL Freq.       | 8.0 MHz                  | 12.0 MHz  | 16.0 MHz  | 20.0 MHz  | 20.0 MHz       | Other EXTAL         |
| E Clock Freq.     | 2.0 MHz                  | 3.0 MHz   | 4.0 MHz   | 5.0 MHz   | 5.0 MHz        | EXTAL/4             |
| E Clock Period    | 500 ns                   | 333 ns    | 250 ns    | 200 ns    | 200 ns         | 1/E                 |
| Control Bits      | Main Timer Period        |           |           |           | 1 Count        |                     |
| PR[1:0]           | (1 Count/Timer Overflow) |           |           |           | Timer Overflow |                     |
| 0 0               | 500 ns                   | 333 ns    | 250 ns    | 200 ns    | 167 ns         | 1 ÷ E               |
|                   | 32.768 ms                | 21.845 ms | 16.384 ms | 13.107 ms | 10.923 ms      | 2 <sup>16</sup> ÷ E |
| 0 1               | 2.0 μs                   | 1.3 μs    | 1.0 μs    | 800 ns    | 667 ns         | 4 ÷ E               |
|                   | 131.07 ms                | 87.381 ms | 85.536 ms | 52.429 ms | 43.961 ms      | 2 <sup>18</sup> ÷ E |
| 1 0               | 4.0 μs                   | 2.667 μs  | 2.0 μs    | 1.6 μs    | 1.333 μs       | 8 ÷ E               |
|                   | 262.14 ms                | 174.76 ms | 131.07 ms | 104.86 ms | 87.381 ms      | 2 <sup>19</sup> ÷ E |
| 1 1               | 8.0 μs                   | 5.333 μs  | 4.0 μs    | 3.2 μs    | 2.667 μs       | 16 ÷ E              |
|                   | 524.29 ms                | 349.53 ms | 262.14 ms | 209.72 ms | 174.76 ms      | 2 <sup>20</sup> ÷ E |

The free-running counter begins incrementing from \$0000 as the MCU comes out of reset and continues to the maximum count, \$FFF. At the maximum count, the counter rolls over to \$0000, sets the timer overflow flag (TOF) in the timer interrupt flag 2 (TFLG2) register, and continues to increment. The value in this counter can be read in the timer counter (TCNT) register, but cannot be written or changed except by reset.

The pulse accumulator, described in **9.7 Pulse Accumulator (PA)**, derives its clock by post-scaling the main timer so that the output frequency is always E clock divided by 64. This clock drives an 8-bit counter while the pulse accumulator is operating in event counting mode.

RTI is a programmable periodic interrupt circuit that can be used to pace the execution of software routines, as described in **9.8 Real-Time** Interrupt (RTI). The clock driving this function is also derived from the clock driving the free-running counter. The post-scaler output of this chain runs at a frequency of E clock divided by 2<sup>13</sup>.

The COP watchdog timer (5.3.3 Computer Operating Properly (COP) System) further divides the RTI clock by four to drive its circuitry at a frequency of E clock divided by 2<sup>15</sup>.

# 9.4 Input Capture and Output Compare Overview

The M68HC11K series features:

- Three input capture channels
- Four output compare channels
- One channel that can be selected to perform either input capture or output compare

Each of the three input capture functions has its own 16-bit input capture register (time capture latch) and each of the output compare functions has its own 16-bit compare register. All timer functions, including the timer overflow and RTI, have their own interrupt controls and separate interrupt vectors.

Figure 9-2 shows the capture/compare system block diagram. The port A pin control block includes logic for timer functions and for general-purpose I/O. This block contains the edge-detection logic for pins PA[2:0] as well as the control logic that enables edge selection for the input capture trigger.

- PA[2:0] can serve either as input capture pins IC[1:3] or as general-purpose input/output (GPIO).
- PA[6:4] can serve either as drivers for output compare functions OC[2:4] or GPIO.
- PA3 can be used for GPIO, input capture 4, output compare 5, or output compare 1.
- Output compare 1 (OC1) has extra control logic which gives it optional control of any combination of the PA[7:3] pins.
- The PA7 pin can be used as a GPIO pin, as an input to the pulse accumulator, or as an OC1 output pin.

Reading the port A register returns the actual pin level on any pin functioning as an input, and the logic level of the internal pin driver (NOT the pin level) on any pin functioning as an output. This is true whether the pins are configured for timer functions or GPIO. Writing to port A pins configured for timer functions has no visible effect; the writes are latched but do not drive the pins.

Registers common to both the input capture and output compare functions include:

- Timer counter register (TCNT)
- Timer interrupt flag 2 (TFLG2)
- Timer interrupt mask 2 (TMSK2)
- Data direction register A (DDRA)
- Pulse accumulator control register (PACTL)

**NOTE:** 

Throughout this manual, the registers are discussed by function. In the event that not all bits in a register are referenced, the bits that are not discussed are shaded.



Figure 9-2. Capture/Compare Block Diagram

# 9.4.1 Timer Counter Register



Figure 9-3. Timer Counter Register (TCNT)

TCNT reflects the current value in the free-running counter. Input capture functions use this number to mark the time of an external event, and output compare functions use it to determine the time at which to generate an event.

In normal modes, TCNT is a read-only register. Writes to TCNT in normal modes have no effect. TCNT can be read and written in special modes.

## 9.4.2 Timer Interrupt Flag 2 Register



Figure 9-4. Timer Interrupt Flag 2 (TFLG2)

Clear each flag by writing a 1 to the corresponding bit position.

TOF — Timer Overflow Flag

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

# 9.4.3 Timer Interrupt Mask 2 Register



Figure 9-5. Timer Interrupt Mask 2 (TMSK2)

Bits in TMSK2 correspond bit for bit with flag bits in TFLG2.

TOI — Timer Overflow Interrupt Enable Bit

0 = Timer overflow interrupt disabled

1 = An interrupt request is generated when TOF is set.

### PR[1:0] — Timer Prescaler Select Bits

These bits determine the main timer prescale divisor, as shown in **Table 9-2**. The system bus (E clock) frequency is divided by this number to produce the clock which drives the free-running counter. Refer to **Table 9-1** for specific timing values.

In normal modes, PR[1:0] can be written only once, and the write must be within 64 cycles after reset.

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

**Table 9-2. Timer Prescale** 

# 9.4.4 Port A Data Direction Register



Figure 9-6. Port A Data Direction Register (DDRA)

DDA3 — Data Direction Control for Port A, Bit 3

0 = PA3 configured as an input

1 = PA3 configured as an output

### 9.4.5 Pulse Accumulator Control Register



Figure 9-7. Pulse Accumulator Control Register (PACTL)

14/O5 — Input Capture 4/Output Compare 5 Bit

0 = Configure PA3 as OC5

1 = Configure PA3 as IC4

To configure PA3 as input compare 4, clear DDA3 and set I4/05. To configure PA3 as output compare 5, set DDA3 and clear I4/05. If the DDA3 bit is set (configuring PA3 as an output) and IC4 is enabled, writing a one to TI4/O5 causes an input capture. Writing to TI4/O5 has no effect when DDA3 is cleared and/or OC5 is enabled.

# 9.5 Input Capture (IC)

The input capture function records the time an external event occurs by latching the value of the free-running counter into one of the timer input capture (TIC) registers when a selected edge is detected at its associated timer input pin. Software can store latched values and use them to compute the period and duration of events. For example, by storing the times of successive edges of an incoming signal, software can determine the period and pulse width of a signal. To measure the period, two successive edges of the same polarity are captured. To measure pulse width, two alternate polarity edges are captured.

Capture requests are latched on the opposite half cycle of PH2 from when the timer counter is being incremented. This synchronization process introduces a delay between edge occurrence and counter value detection. Because these delays offset each other when the time between two edges is measured, they can be ignored. There is a similar delay for output compare between the actual compare point and when the output pin changes state.

# 9.5.1 Timer Input Capture Registers



Figure 9-8. Timer Input Capture Registers (TIC1-TIC3)

## 9.5.2 Timer Input Capture 4/Output Compare 5 Register



Figure 9-9. Timer Input Capture 4/Output Compare 5 Register (TI4/O5)

TI4/05 functions as the input capture register for IC4 when PA3 is configured for input capture 4.

When an edge on an input capture pin has been detected and synchronized, the 16-bit free-running counter value is latched in the associated input capture register pair in a single 16-bit parallel transfer. The latch occurs on the opposite half-cycle of the phase two clock from when the timer counter is incremented. This ensures a stable count value whenever a capture occurs.

Input capture values can be retrieved from a TIC register with two successive 8-bit reads. Reading the high-order byte inhibits a new capture transfer for one bus cycle to ensure that the successive low-order byte read corresponds with it. If a new input capture occurs immediately after a high-order byte read, transfer is delayed for an additional cycle, but the new value is not lost. To assure coherency between the two bytes, use a double-byte read instruction such as LDD.

## 9.5.3 Timer Interrupt Flag 1 Register



Figure 9-10. Timer Interrupt Flag 1 Register (TFLG1)

Clear each flag by writing a 1 to the corresponding bit position.

ICxF — Input Capture x Flag

Set each time a selected active edge is detected on the corresponding input capture line.

I4/O5F — Input Capture 4/Output Compare 5 Flag

Set each time a selected active edge is detected on the IC4 line if IC4 is enabled.

### 9.5.4 Timer Interrupt Mask 1 Register



Figure 9-11. Timer Interrupt Mask 1 Register (TMSK1)

Bits in TMSK1 correspond bit for bit with flag bits in TFLG1.

ICxI — Input Capture Interrupt Enable Bit

If the ICxI enable bit is set when the ICxF flag bit is set, a hardware interrupt sequence is requested.

I4/O5I — Input Capture 4 or Output Compare 5 Interrupt Enable Bit
If I4/O5I is set when IC4 is enabled and the I4/O5F flag bit is set, a hardware interrupt sequence is requested.

### 9.5.5 Timer Control 2 Register



Figure 9-12. Timer Control 2 Register (TCTL2)

### EDGx[B:A] — Input Capture Edge Control Bits

These bit pairs determine the edge polarities on the input capture pins that trigger the corresponding input capture functions. Each of the input capture functions can be independently configured to detect rising edges only, falling edges only, any edge (rising or falling), or to disable the input capture function. The input capture functions operate independently of each other and can capture the same TCNT value if the input edges are detected within the same timer count cycle.

Each EDGx bit pair is cleared (IC function disabled) by reset and must be encoded according to the values in **Table 9-3** to configure the corresponding input capture edge detector circuit. IC4 functions only if the I4/O5 bit in the PACTL register is set.

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

Table 9-3. Input Capture Edge Selection

# 9.6 Output Compare (OC)

The output compare (OC) function generates a programmed action when the 16-bit counter reaches a specified value. Each of the five output compare functions contains a separate 16-bit timer output compare (TOC) register and a dedicated 16-bit comparator. Each TOC register is set to \$FFFF on reset. When an OC channel is enabled, the value in its TOC register is compared to the free-running counter value during each E-clock cycle. When the values match, the channel's output compare flag is set in timer interrupt flag 1 (TFLG1). If the channel's interrupt is enabled in the timer interrupt mask register 1 (TMSK1), an interrupt is generated. Also, the corresponding timer output pin is toggled or driven to a specified logic level. This pin activity occurs on each successful compare, whether or not the OCxF flag in the TFLG1 register was previously cleared.

The pin action for each of the OC channels [5:2] is controlled by a pair of bits (OMx and OLx) in the TCTL1 register and affects only the channel's associated pin. A successful OC1 compare can affect any or all five of the OC pins. The action taken when a match is found for OC1 is controlled by two 8-bit registers:

- Output compare 1 mask register (OC1M)
- Output compare 1 data register (OC1D)

OC1M specifies which port A outputs are to be used, and OC1D specifies the data placed on these port pins.

Although the M68HC11K series devices have four built-in pulse-width modulation (PWM) channels (9.9 Pulse-Width Modulator (PWM)), the output compare function can be used to produce an additional pulse-width modulated waveform. To produce a pulse of a specific duration:

- Write a value to the output compare register that represents the time the leading edge of the pulse is to occur.
- Use OC1D to select either a high or low output, depending on the polarity of the pulse being produced.

 After a match occurs, change the appropriate OC1D bit to the opposite polarity, then add a value representing the width of the pulse to the original value and write it to the output compare register.

Because the pin state changes occur at specific values of the free-running counter, the pulse width can be controlled accurately to the resolution of the free-running counter, independent of software latencies. To generate an output signal of a specific frequency and duty cycle, repeat this pulse-generating procedure.

## 9.6.1 Timer Output Compare Registers



Figure 9-13. Timer Output Compare Registers (TOC1–TOC4)



Figure 9-13. Timer Output Compare Registers (TOC1–TOC4) (Continued)

All output compare registers are 16-bit read-write. Any of these registers can be used as a storage location if it is not used for output compare or input capture.

### 9.6.2 Timer Input Capture 4/Output Compare 5 Register



Figure 9-14. Timer Input Capture 4/Output Compare 5 Register (TI4/O5)

Functions as the output compare register for OC5 when PA3 is configured for output compare 5. This register is 16-bit read-write. It can be used as a storage location if it is not used for output compare or input capture.

#### 9.6.3 Timer Interrupt Flag 1 Register



Figure 9-15. Timer Interrupt Flag 1 Register (TFLG1)

Clear each flag by writing a 1 to the corresponding bit position.

OCxF — Output Compare x Flag

Set each time the counter matches output compare x value.

14/O5F — Input Capture 4/Output Compare 5 Flag

Set each time the counter matches output compare 5 value if OC5 is enabled.

## 9.6.4 Timer Interrupt Mask 1 Register



Figure 9-16. Timer Interrupt Mask 1 Register (TMSK1)

Bits in TMSK1 correspond bit for bit with flag bits in TFLG1.

OC1I–OC4I — Output Compare x Interrupt Enable Bits

If the OCxI enable bit is set when the OCxF flag bit is set, a hardware interrupt sequence is requested.

I4/O5I — Input Capture 4 or Output Compare 5 Interrupt Enable Bit
If I4/O5I is set when OC5 is enabled and the I4/O5F flag bit is set, a hardware interrupt sequence is requested.

#### 9.6.5 Timer Control 1 Register



Figure 9-17. Timer Control Register 1 (TCTL1)

OM[2:5] and OL[2:5] — Output Mode and Output Level Bits

Use these bit pairs as indicated in **Table 9-4** to specify the action taken after a successful OCx compare.

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

**Table 9-4. Timer Output Compare Actions** 

# 9.6.6 Timer Compare Force Register



Figure 9-18. Timer Compare Force Register (CFORC)

The CFORC register allows forced early compares. Writing a 1 to any bit of FOC[1:5] forces the programmed pin actions for the corresponding OC channel to occur at the next timer count transition after the write to CFORC. The action taken as a result of a forced compare is identical to the action taken when a match between the OCx register and the free-running counter occurs, except that the corresponding interrupt and status flag bits are not set.

CFORC should not be applied to an output compare function that is programmed to toggle its output on a successful compare because a normal compare that occurs immediately before or after the force can result in an undesirable operation.

FOC[1:5] — Force Output Comparison Bits

0 = No action taken

1 = Output x action occurs at the next timer count transition

## 9.6.7 Output Compare 1 Mask Register



Figure 9-19. Output Compare 1 Mask Register (OC1M)

OC1M specifies which bits of port A will respond to a successful compare for output capture 1. The bits of the OC1M[7:3] register correspond to PA[7:3].

OC1M[7:3] — Output Compare 1 Masks

0 = OC1 is disabled at the corresponding PA pin.

1 = OC1 is enabled at the corresponding PA pin.

# 9.6.8 Output Compare 1 Data Register



Figure 9-20. Output Compare 1 Data Register (OC1D)

Use this register in conjunction with OC1M to specify the data that is to drive the affected pin of port A after a successful OC1 compare. When a successful OC1 compare occurs, a data bit in OC1D is stored in the corresponding bit of port A for each bit that is set in OC1M.

### OC1D[7:3] — Output Compare Data Bits

- 0 = Corresponding port A pin is cleared on successful OC1 compare if the corresponding OC1M bit is set.
- 1 = Corresponding port A pin is set on successful OC1 compare if the corresponding OC1M bit is set.

# 9.7 Pulse Accumulator (PA)

The pulse accumulator can be used either to count events or measure the duration of a particular event. In event counting mode, the pulse accumulator's 8-bit counter increments each time a specified edge is detected on the pulse accumulator input pin, PA7. The maximum clocking rate for this mode is E clock divided by two. In gated time accumulation mode, an internal clock increments the 8-bit counter at a rate of E clock divided by 64 while the input at PA7 remains at a predetermined logic level. **Table 9-5** shows pulse accumulator clock periods for three common crystal frequencies.

Figure 9-21 is a block diagram of the pulse accumulator.

| EXTAL Frequencies                |          |          |          |          |          |                     |
|----------------------------------|----------|----------|----------|----------|----------|---------------------|
| EXTAL Freq.                      | 8.0 MHz  | 12.0 MHz | 16.0 MHz | 20.0 MHz | 24.0 MHz | Other<br>EXTAL      |
| E Clock Freq.                    | 2.0 MHz  | 3.0 MHz  | 4.0 MHz  | 5.0 MHz  | 6.0 MHz  | EXTAL ÷             |
| Maximum event counting frequency | 1.0 MHz  | 1.5 MHz  | 2.0 MHz  | 2.5 MHz  | 3.0 MHz  | E ÷ 2               |
| Gated mode count resolution      | 32.0 μs  | 21.3 μs  | 16.0 μs  | 12.8 μs  | 10.7 μs  | 2 <sup>6</sup> ÷ E  |
| Gated mode count overflow        | 8.192 μs | 5.461 μs | 4.096 μs | 3.277 μs | 2.731 μs | 2 <sup>14</sup> ÷ E |

**Table 9-5. Pulse Accumulator Timing** 



Figure 9-21. Pulse Accumulator

Registers involved in pulse accumulator operation include:

- Data direction register A (DDRA)
- Pulse accumulator control register (PACTL)
- Timer interrupt mask 2 register (TMSK2)
- Timer interrupt flag 2 (TFLG2)
- Pulse accumulator count register (PACNT)

### 9.7.1 Port A Data Direction Register



Figure 9-22. Port A Data Direction Register (DDRA)

The pulse accumulator uses port A, bit 7 as the PAI input, but the pin can also be used as general-purpose I/O or as an output compare.

**NOTE:** Even when port A, bit 7 is configured as an output, the pin still drives the input to the pulse accumulator.

DDA7 — Data Direction Control for Port A, Bit 7

0 = PA7 configured as an input

1 = PA7 configured as an output

# 9.7.2 Pulse Accumulator Control Register



Figure 9-23. Pulse Accumulator Control Register (PACTL)

PAEN — Pulse Accumulator System Enable Bit

0 = Pulse accumulator disabled

1 = Pulse accumulator enabled

PAMOD — Pulse Accumulator Mode Bit

0 = Event counter

1 = Gated time accumulation

### PEDGE — Pulse Accumulator Edge Control Bit

In event counting mode, PEDGE selects either the rising or falling edge of the input at PA7 to increment the pulse accumulator counter. In gated accumulation mode, PEDGE determines which input level at PA7 inhibits counter increments from the internal clock. **Table 9-6** shows the relationship between PEDGE and PAMOD.

 PAMOD
 PEDGE
 Action on Clock

 0
 0
 PAI falling edge increments the counter.

 0
 1
 PAI rising edge increments the counter.

 1
 0
 A 0 on PAI inhibits counting.

 1
 1
 A 1 on PAI inhibits counting.

Table 9-6. Pulse Accumulator Edge Control

# 9.7.3 Timer Interrupt Flag 2 Register



Figure 9-24. Timer Interrupt Flag 2 (TFLG2)

Clear each flag by writing a 1 to the corresponding bit position.

### 9.7.4 Timer Interrupt Mask 2 Register



Figure 9-25. Timer Interrupt Mask 2 (TMSK2)

Bits in TMSK2 correspond bit for bit with flag bits in TFLG2.

#### PAOVF — Pulse Accumulator Overflow Flag

The PAOVF status bit is set each time the pulse accumulator count rolls over from \$FF to \$00.

#### PAOVI — Interrupt Enable Bit

If PAOVI is set, an interrupt request is also generated. If PAOVI is cleared, pulse accumulator overflow interrupts are inhibited, and PAOVF must be polled by user software to determine when an overflow has occurred. In either case, software must clear PAOVF by writing a 1 to bit 5 in the TFLG2 register.

#### PAIF — Pulse Accumulator Input Edge Flag

The PAIF status bit is automatically set each time a selected edge is detected at the PA7 pin.

#### PAII — Interrupt Enable Bit

If PAII is set, an interrupt request is also generated. If PAII is cleared, pulse accumulator input interrupts are inhibited, and PAIF must be polled by user software to determine when an input edge has been detected. In either case, software must clear PAIF by writing a 1 to bit 5 in the TFLG2 register.

## 9.7.5 Pulse Accumulator Count Register



Figure 9-26. Pulse Accumulator Count Register (PACNT)

In event counting mode, PACNT contains the count of external input events at the PAI input. In gated accumulation mode, PACNT is incremented by the pulse accumulator's  $E \div 64$  clock when the PAI input is at the selected level. Counting is synchronized to the internal PH2 clock so that incrementing and reading occur during opposite half cycles. The counter is not affected by reset and can be read or written to at any time.

# 9.8 Real-Time Interrupt (RTI)

The real-time interrupt (RTI) feature generates hardware interrupts at a fixed periodic rate. The rate is determined by bits RTR[1:0] in the PACTL register, which further divide a clock running at  $E \div 2^{13}$  by 1, 2, 4 or 8. The resulting periods for various common crystal frequencies are shown in **Table 9-7**.

Every cycle of the RTI clock sets the RTIF bit in timer interrupt flag 2 (TFLG2) register. This flag can be polled to determine when RTI timeouts occur, or an interrupt can be generated if the RTII bit in the timer interrupt mask 2 (TMSK2) register is set. After reset, one entire real-time interrupt period elapses before the RTIF flag is set for the first time.

The clock source for the RTI function is a free-running clock that cannot be stopped or interrupted except by reset. The time between successive RTI timeouts is a constant that is independent of software latencies

associated with flag clearing and service. For this reason, an RTI period starts from the previous timeout, not from when RTIF is cleared.

# 9.8.1 Timer Interrupt Flag 2 Register



Figure 9-27. Timer Interrupt Flag 2 Register (TFLG2)

Clear each flag by writing a 1 to the corresponding bit position.

RTIF — Real-Time Interrupt Flag

The RTIF status bit is automatically set to 1 at the end of every RTI period.

### 9.8.2 Timer Interrupt Mask 2 Register



Figure 9-28. Timer Interrupt Mask 2 Register (TMSK2)

Bits in TMSK2 correspond bit for bit with flag bits in TFLG2.

RTII — Real-time Interrupt Enable Bit

0 = RTIF interrupts disabled

1 = Interrupt requested when RTIF is set to 1

# 9.8.3 Pulse Accumulator Control Register



Figure 9-29. Pulse Accumulator Control Register (PACTL)

RTR[1:0] — Real-Time Interrupt Rate Select Bits

These two bits select a divisor (1, 2, 4, or 8) for the E  $\div$  2<sup>13</sup> RTI clock. Refer to **Table 9-7**.

Table 9-7. Real-Time Interrupt Rate versus RTR[1:0]

| RTR[1:0] | Rate                | XTAL =<br>12.0 MHz | $XTAL = 2^{23}$ | XTAL =<br>8.0 MHz | XTAL =<br>4.9152 MHz | XTAL =<br>4.0 MHz | XTAL =<br>3.6864 MHz |
|----------|---------------------|--------------------|-----------------|-------------------|----------------------|-------------------|----------------------|
| 0 0      | 2 <sup>13</sup> ÷ E | 2.730 ms           | 3.91 ms         | 4.10 ms           | 6.67 ms              | 8.19 ms           | 8.89 ms              |
| 0 1      | 2 <sup>14</sup> ÷ E | 5.461 ms           | 7.81 ms         | 8.19 ms           | 13.33 ms             | 16.38 ms          | 17.78 ms             |
| 1 0      | 2 <sup>15</sup> ÷ E | 10.92 ms           | 15.62 ms        | 16.38 ms          | 26.67 ms             | 32.77 ms          | 35.56 ms             |
| 1 1      | 2 <sup>16</sup> ÷ E | 21.84 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            |

# 9.9 Pulse-Width Modulator (PWM)

Four 8-bit pulse-width modulation channels are available in the M68HC11K Family devices. They are output on port H pins 3–0. Pairs of channels can be concatenated to produce 16-bit outputs. Three programmable clocks and a flexible clock selection scheme provide a wide range of frequencies.

The 8-bit mode with E = 4 MHz can produce waveforms from 40 kHz at 1 percent duty cycle resolution to less than 10 Hz at 0.4 percent duty cycle resolution. In 16-bit mode, a duty cycle resolution down to 15 parts per million can be achieved (at a frequency of 60 Hz). At 1 kHz, the duty cycle resolution is 250 ppm.

### 9.9.1 PWM System Description

Figure 9-30 shows a block diagram of the PWM system. Each of four channels is enabled by bit PWENx in the PWEN register. Each channel has an 8-bit counter (PWCNTx), a period register (PWPERx), and a duty cycle register (PWDTYx). The counter is driven by one of three user-scaled clock sources — clock A, B, or S — selected by the pulse-width channel select (PCLKx) bit in the pulse-width modulation timer polarity (PWPOL) register.

A pulse-width modulation period begins when the counter matches the value stored in the period register. When this happens, a logic value determined by the polarity bit (PPOLx) in the PWPOL register is driven on the associated port H output pin, and the counter is reset to 0. When the counter matches the number stored in the duty cycle register, the output reverses polarity. The period and duty cycle registers are double buffered so they can be changed without disturbing the current waveform. A new period or duty cycle can be forced by writing to the period (PWPERx) or duty cycle register (PWDTYx) and then to the counter (PWCNTx). Writing to the counter always resets it to 0.



Figure 9-30. Pulse-Width Modulation Timer Block Diagram

The three clocks are derived from the E clock by writing to registers which determine their scaling factors. The clock A frequency is equal to E divided by 1, 2, 4, or 8, depending on which bits (PCKA[2:1]) in the PWCLK register are set. The clock B frequency is equal to the E clock divided by a power of two determined by bits PCKB[3:1] in the PWCLK register. Clock S is derived by dividing clock A by the integer (1 to 256) stored in the PWSCAL register, then by two.

Two channels can be concatenated by setting the appropriate bit (CON34 or CON12) in the PWCLK register. In this mode, the clock source is determined by the low-order channel, which is channel two in CON12 and channel four in CON34. The output is also placed on the pin associated with the low-order channels, so when two channels are concatenated the pin associated with the high-order channel (PH0 and/or PH2) can be used for GPIO. A read of the high-order byte causes the low-order byte to be latched for one cycle to guarantee that double-byte reads are accurate. A write to the low-order byte of the counter causes reset of the entire counter. A write to the high-order byte of the counter has no effect.

# 9.9.2 Pulse-Width Modulation Control Registers

The PWM control registers are described here.

#### 9.9.2.1 Pulse-Width Modulation Timer Clock Select Register



Figure 9-31. Pulse-Width Modulation Timer Clock Select (PWCLK)

CON34 — Concatenate Channels 3 and 4 Bit

Channel 3 is the high-order byte, and channel 4 (port H, bit 3) is output.

- 0 = Channels 3 and 4 are separate 8-bit PWMs.
- 1 = Channels 3 and 4 are concatenated to create one 16-bit PWM.

#### CON12 — Concatenate Channels 1 and 2 Bit

Channel 1 is the high-order byte, and channel 2 (port H, bit 1) is output.

- 0 = Channels 1 and 2 are separate 8-bit PWMs.
- 1 = Channels 1 and 2 are concatenated to create one 16-bit PWM.

### PCKA[2:1] — Prescaler for Clock A Bits

These bits select the frequency for clock A as shown in **Table 9-8**.

PCKA[2:1] Clock A Frequency

0 0 E

0 1 E/2

E/4 E/8

Table 9-8. Clock A Prescaler

PCKB[3:1] — Prescaler for Clock B Bits

1 0

1 1

These bits select the frequency for clock B as shown in **Table 9-9**.

Table 9-9. Clock B Prescaler

| PCKB[3:1] | Clock B Frequency |
|-----------|-------------------|
| 0 0 0     | Е                 |
| 0 0 1     | E/2               |
| 0 1 0     | E/4               |
| 0 1 1     | E/8               |
| 1 0 0     | E/16              |
| 1 0 1     | E/32              |
| 1 1 0     | E/64              |
| 1 1 1     | E/128             |

### 9.9.2.2 Pulse-Width Modulation Timer Polarity Register



Figure 9-32. Pulse-Width Modulation Timer Polarity Register (PWPOL)

PCLK[4:3] — Pulse-Width Channel 4, 3 Clock Select Bits

0 = Clock B is source.

1 = Clock S is source.

PCLK[2:1] — Pulse-Width Channel 2, 1 Clock Select Bits

0 = Clock A is source.

1 = Clock S is source.

PPOL[4:1] — Pulse-Width Channel x Polarity Bits

- 0 = PWM channel x output is low at the beginning of the clock cycle and goes high when duty count is reached.
- 1 = PWM channel x output is high at the beginning of the clock cycle and goes low when duty count is reached.

#### 9.9.2.3 Pulse-Width Modulation Timer Prescaler Register



Figure 9-33. Pulse-Width Modulation Timer Prescaler Register (PWSCAL)

Scaled clock S is generated by dividing clock A by the value in PWSCAL, then dividing the result by two. If PWSCAL = \$00, the divisor is 256, then two.

## 9.9.2.4 Pulse-Width Modulation Timer Enable Register



Figure 9-34. Pulse-Width Modulation Timer Enable Register (PWEN)

TPWSL — PWM Scaled Clock Test Bit — factory use only; only accessible in special test mode

0 = Normal operation

1 = Clock S is output to PWSCAL register (test only)

DISCP — Disable Compare Scaled E-Clock Bit — factory use only; only accessible in special test mode

0 = Normal operation

1 = Match of period does not reset associated count register (test only)

PWEN[4:1] — Pulse-Width Enable for Channels [4:1] Bits

0 = Channel disabled

1 = Channel enabled at port H bits [3:0]

#### 9.9.2.5 Pulse-Width Modulation Timer Counters 1 to 4 Registers



Figure 9-35. Pulse-Width Modulation Timer Counters 1 to 4 (PWCNT1 to PWCNT4)

Each counter resets to 0 when it is written and can be read at any time.

#### 9.9.2.6 Pulse-Width Modulation Timer Periods 1 to 4 Registers



Figure 9-36. Pulse-Width Modulation Timer Periods 1 to 4 (PWPER1 to PWPER4)

Each period register can be read or written at any time. If it is written, the new period will not take effect until the associated counter is reset by a match or a write.

#### 9.9.2.7 Pulse-Width Modulation Timer Duty Cycle 1 to 4 Registers



Figure 9-37. Pulse-Width Modulation Timer Duty Cycle 1 to 4 (PWDTY1 to PWDTY4)

Each duty cycle register can be read or written at any time. If it is written, the new duty cycle will not take effect until the associated counter is reset by a match or a write.

# Timing System

# Section 10. Analog-to-Digital (A/D) Converter

#### 10.1 Contents

| 10.2   | Introduction                                 |
|--------|----------------------------------------------|
| 10.3   | Functional Description                       |
| 10.3.1 | Multiplexer                                  |
| 10.3.2 | Analog Converter                             |
| 10.3.3 | Result Registers                             |
| 10.3.4 | Digital Control224                           |
| 10.4   | A/D Control/Status Registers                 |
| 10.4.1 | System Configuration Options Register        |
| 10.4.2 | A/D Control/Status Register                  |
| 10.4.3 | Analog-to-Digital Converter Result Registers |
| 10.5   | Design Considerations                        |
| 10.5.1 | A/D Input Pins                               |
| 10.5.2 | Operation in Stop and Wait Modes             |

#### 10.2 Introduction

The analog-to-digital (A/D) system in M68HC11 microcontrollers is an 8-channel, 8-bit, multiplexed input converter. It employs a successive approximation technique with an all-capacitive charge redistribution system that does not require external sample-and-hold circuits. A/D converter timing can be synchronized either to the E clock or an internal resistor-capacitor (RC) oscillator. Separate power supply inputs, AV<sub>DD</sub> and AV<sub>SS</sub>, allow independent bypassing for noise immunity.

## **10.3 Functional Description**

The A/D converter system consists of four functional blocks as shown in Figure 10-1:

- Multiplexer
- Analog converter
- Result storage
- Digital control



Figure 10-1. A/D Converter Block Diagram

#### 10.3.1 Multiplexer

The multiplexer selects which of the eight analog inputs at port E will be converted. There are also three internal reference levels which can be multiplexed to the converter for system testing. Input selection is controlled by the value of bits CD:CA in the A/D control register (ADCTL).

The  $V_{RH}$  and  $V_{RL}$  pins provide inputs for the A/D system reference voltage. An input voltage equal to  $V_{RL}$  converts to \$00 and an input voltage equal to  $V_{RH}$  converts to \$FF (full scale), with no overflow indication. For ratiometric conversions of this type, the source of each analog input should use  $V_{RH}$  as the supply voltage and be referenced to  $V_{RI}$ .

#### 10.3.2 Analog Converter

The conversion block contains a digital-to-analog capacitor (DAC) array, a comparator, and a successive approximation register (SAR). When an analog input is sampled for conversion, an analog switch connects the input to the DAC array. This series of scaled capacitors retains the sample for the duration of the conversion.

A conversion consists of a sequence of eight comparison operations. Each comparison determines one bit of the result, starting with the most significant bit (MSB). During each comparison, analog switches connect different elements of the DAC array to the comparator. The output of the comparator is stored in the next bit in the successive approximation register. When a conversion sequence is complete, the contents of the SAR are transferred to the appropriate result register.

#### 10.3.3 Result Registers

The A/D conversion sequence begins one E-clock cycle after a write to the analog-to-digital control/status register (ADCTL). Converter operations are performed in sequences of four conversions each. Each conversion result in a sequence is stored in one of the four result registers, ADR[4:1]. The conversion complete flag (CCF) in the ADCTL

## Analog-to-Digital (A/D) Converter

register is set after the fourth conversion in a sequence to signal the availability of data in the result registers. The result registers are written during a portion of the system clock cycle when reads do not occur, so there is no conflict. A conversion sequence can repeat continuously or stop after one iteration. **Figure 10-2** shows the timing of a typical sequence. In this example, synchronization is referenced to the system E clock.



Figure 10-2. A/D Conversion Sequence

#### **10.3.4 Digital Control**

In addition to the conversion complete status flag, ADCTL bits select single or continuous conversions, whether conversions are performed on single or multiple channels, and the analog input(s) to be converted.

Single or continuous conversions are selected by the SCAN bit. Clearing the SCAN bit selects the single conversion option, in which results are written to each of the four result registers one time. The first result is stored in A/D result register 1 (ADR1), and the fourth result is stored in ADR4. All conversion activity is then halted until the ADCTL register is written again. In the continuous mode (SCAN =1), conversion activity does not stop. The fifth conversion is stored in register ADR1 (overwriting the first conversion result), the sixth conversion overwrites ADR2, and so on.

The MULT bit in ADCTL determines whether one or four channels are converted. When MULT = 0, one channel is converted. The selected channel is sampled and the conversion results are written to ADR1; the same channel is sampled again, and the conversion results are stored in ADR2, and so on. In continuous mode, the same channel continues to be sampled and converted. Setting the MULT bit converts four different channels; each result register contains the conversion result of a different channel. In continuous mode, the same four channels are converted in each sequence.

ADCTL bits [3:0] select the particular channel(s) to be converted. See **Table 10-1**.

Table 10-1. A/D Converter Channel Selection

| Channel Select Control Bits | Channel Signal                      | Result Location |  |
|-----------------------------|-------------------------------------|-----------------|--|
| CD:CC:CB:CA                 | - Channel Signal                    | When MULT = 1   |  |
| 0000                        | AN0                                 | ADR1            |  |
| 0001                        | AN1                                 | ADR2            |  |
| 0010                        | AN2                                 | ADR3            |  |
| 0011                        | AN3                                 | ADR4            |  |
| 0100                        | AN4                                 | ADR1            |  |
| 0101                        | AN5                                 | ADR2            |  |
| 0110                        | AN6                                 | ADR3            |  |
| 0111                        | AN7                                 | ADR4            |  |
| 10XX                        | Reserved                            | _               |  |
| 1100                        | V <sub>RH</sub> <sup>(1)</sup>      | ADR1            |  |
| 1101                        | V <sub>RL</sub> <sup>(1)</sup>      | ADR2            |  |
| 1110                        | (V <sub>RH</sub> )/2 <sup>(1)</sup> | ADR3            |  |
| 1111                        | Reserved <sup>(1)</sup>             | ADR4            |  |

<sup>1.</sup> Used for factory testing

## Analog-to-Digital (A/D) Converter

### 10.4 A/D Control/Status Registers

The registers involved in A/D operation include OPTION, ADCTL, and the four result registers ADR[1:4].

NOTE:

Throughout this manual, the registers are discussed by function. In the event that not all bits in a register are referenced, the bits that are not discussed are shaded.

#### 10.4.1 System Configuration Options Register

Bit 7 in the system configuration options register (OPTION), ADPU, enables the A/D converter system. Setting ADPU applies power to the A/D circuitry, including the charge pump that drives the analog switches. Clearing ADPU removes power from the A/D system.

The gates of analog switches in the multiplexer are driven by a charge pump that develops between seven and eight volts. The high gate voltage assures low source-to-drain impedance for the analog signals. Both the charge pump and the comparator circuits require up to 100  $\mu$ s to stabilize after setting the ADPU bit.

The CSEL bit (bit 6) determines whether the A/D converter uses the system E clock or an internal RC oscillator for synchronization. It is cleared out of reset, selecting the E clock. This is the preferred setting at normal operating frequencies because all switching and comparator operations are synchronized to the main MCU clocks. This allows the comparator output to be sampled at relatively quiet portions of the MCU clock cycles.

When the E clock frequency is less than 750 kHz, charge leakage in the capacitor array can cause errors. In this case, set the CSEL bit to select the internal oscillator, which usually runs at about 2 MHz. The additional error introduced by the asynchronous oscillator is about  $\pm$  1/2 LSB (least significant bit), which is usually less than that incurred by a slow clock.

Address: \$0039 Bit 7 6 5 4 3 2 1 Bit 0 Read: DLY<sup>(1)</sup> **ADPU CSEL IRQE** CME **FCME** CR1 CR0 Write: Reset: 0 0 0 1 0 0 0 0

1. DLY can be written only once in the first 64 cycles out of reset in normal modes or at any time in special modes.

Figure 10-3. System Configuration Options Register (OPTION)

ADPU — A/D Power-up

0 = A/D powered down

1 = A/D powered up

CSEL — Clock Select

0 = A/D and EEPROM use system E clock.

1 = A/D and EEPROM use internal RC clock.

#### 10.4.2 A/D Control/Status Register

All bits in this register can be read or written except bit 7, which is a read-only status indicator, and bit 6, which always reads as 0. Writing to ADCTL initiates a conversion, aborting any conversion in progress.



Figure 10-4. Analog-to-Digital Control/Status Register (ADCTL)

## Analog-to-Digital (A/D) Converter

#### CCF — Conversions Complete Flag

Set when all four A/D result registers contain valid conversion results. Cleared when the ADCTL register is overwritten, starting a new conversion sequence. In continuous mode, CCF is set at the end of the first conversion sequence.

#### SCAN — Continuous Scan Control Bit

- 0 = Conversion process stops after each of the four result registers is written.
- 1 = Conversions are performed continuously.

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

- 0 = A single channel specified by the four channel select bits CD:CA is sampled and converted four times.
- 1 = Each of four channels is converted and the results written to a different result register.

#### NOTE:

When the multiple-channel continuous scan mode is used, extra care is needed in the design of circuitry driving the A/D inputs. The charge on the capacitive DAC array before 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 µs 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 errors in accuracy. Refer to the M68HC11 Reference Manual, Motorola document order number M68HC11RM/AD, for further information.

#### CD:CA — Channel Selects D:A Bits

Refer to **Table 10-1**. In multiple channel mode (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 is to be converted.

#### 10.4.3 Analog-to-Digital Converter Result Registers

These read-only registers hold an 8-bit conversion result. Writes to these registers have no effect. Data in the A/D converter result registers is valid when the CCF flag in the ADCTL register is set, indicating a conversion sequence is complete. If conversion results are needed sooner, refer to Figure 10-2, which shows the A/D conversion sequence diagram.



Figure 10-5. Analog-to-Digital Result Registers (ADR1–ADR4))

#### 10.5 Design Considerations

This section discusses design considerations.

#### 10.5.1 A/D Input Pins

Port E pins can also be used as general-purpose digital inputs. Digital reads of port E pins are not recommended during the sample portion of an A/D conversion cycle, when the gate signal to the N-channel input is on. No P-channel devices are directly connected to either input pins or reference voltage pins, so voltages above  $V_{DD}$  do not cause a latchup problem, although current should be limited according to maximum ratings. Refer to **Figure 10-6**.



Note 1. This analog switch is closed only during the 12-cycle sample time.

Figure 10-6. Electrical Model of an A/D Input Pin (Sample Mode)

#### 10.5.2 Operation in Stop and Wait Modes

If a conversion sequence is in progress 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 is resampled and the conversion sequence is 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 is necessary to allow a stabilization period when leaving stop mode. If stop mode is exited with a delay (DLY = 1), there is enough time for these circuits to stabilize before the first conversion. If stop mode is exited with no delay (DLY bit in OPTION register = 0), allow 10 ms for the A/D circuitry to stabilize to avoid invalid results.

# **Section 11. Memory Expansion and Chip Selects**

#### 11.1 Contents

| 11.2 Introduction                                           |
|-------------------------------------------------------------|
| 11.3 Memory Expansion                                       |
| 11.3.1 Memory Size and Address Line Allocation232           |
| 11.3.2 Control Registers                                    |
| 11.3.2.1 Port G Assignment Register234                      |
| 11.3.2.2 Memory Mapping Size Register235                    |
| 11.3.2.3 Memory Mapping Window Base Register                |
| 11.3.2.4 Memory Mapping Window Control Registers            |
| 11.4 Chip Selects                                           |
| 11.4.1 Program Chip Select                                  |
| 11.4.2 Input/Output Chip Select247                          |
| 11.4.3 General-Purpose Chip Selects242                      |
| 11.4.3.1 Memory Mapping Size Register243                    |
| 11.4.3.2 General-Purpose Chip Select 1 Address Register 243 |
| 11.4.3.3 General-Purpose Chip Select 1 Control Register 244 |
| 11.4.3.4 General-Purpose Chip Select 2 Address Register 245 |
| 11.4.3.5 General-Purpose Chip Select 2 Control Register 245 |
| 11.4.4 One Chip Select Driving Another                      |
| 11.4.4.1 General-Purpose Chip Select 1 Control Register 247 |
| 11.4.4.2 General-Purpose Chip Select 2 Control Register 247 |
| 11.4.5 Clock Stretching                                     |
| 11.5 Memory Expansion Examples                              |

## 11.2 Introduction

This section provides descriptions of the expanded memory and the chip selects.

## 11.3 Memory Expansion

The M68HC11K Family devices employ a register-based paging scheme to extend their address range beyond the physical 64-Kbyte limit of the 16 CPU address lines. Pages are selected using the expansion address lines XA[18:13] available on port G. This selection can be facilitated by the chip-select lines on port H, discussed in 11.4 Chip Selects. The M68HC11KS devices do not provide these features since they lack the required port G and port H lines. Refer to Figure 1-2. M68HC11KS Family Block Diagram.

#### 11.3.1 Memory Size and Address Line Allocation

To access expanded memory, the user first allocates portion(s) of the 64 Kbyte address space, or window(s), through which the CPU will view external memory. One or two windows can be designated, and the size of each window can be 0 (disabled), 8, 16, or 32 Kbytes.

Expanded memory is addressed with a combination of the CPU's normal address lines ADDR[15:0] and the expansion address lines XA[18:13]. The expansion address lines select a memory bank, and the CPU's normal address lines select a particular location within the bank. The size of the window(s) and the number of memory banks determine exactly which expansion address lines are used. The port G assignment register (PGAR) controls which port G pins function as expanded address lines. Any port G pins not allocated for memory expansion can serve as general-purpose input/output (GPIO). When a configuration uses any of the lower three expansion address lines XA[15:13] they replace the CPU's equivalent address lines (ADDR[15:13]). Table 11-1 shows how address and expansion lines are allocated for various combinations of memory banks and window size.

Table 11-1. CPU Address and Address Expansion Signals

|                    | Window Size             |                         |            |                                          |  |
|--------------------|-------------------------|-------------------------|------------|------------------------------------------|--|
| Number<br>of Banks | 8 Kbytes                | 16 Kbytes               | 32 Kbytes  | 32 Kbytes<br>(Window Based<br>at \$4000) |  |
| 2                  | ADDR[12:0]              | ADDR[13:0]              | ADDR[14:0] | ADDR[13:0]                               |  |
|                    | XA13                    | XA14                    | XA15       | XA[15:14]                                |  |
| 4                  | ADDR[12:0]              | ADDR[13:0]              | ADDR[14:0] | ADDR[13:0]                               |  |
|                    | XA[14:13]               | XA[15:14]               | XA[16:15]  | XA[16:14]                                |  |
| 8                  | ADDR[12:0]              | ADDR[13:0]              | ADDR[14:0] | ADDR[13:0]                               |  |
|                    | XA[15:13]               | XA[16:14]               | XA[17:15]  | XA[17:14]                                |  |
| 16                 | ADDR[12:0]              | ADDR[13:0]              | ADDR[14:0] | ADDR[13:0]                               |  |
|                    | XA[16:13]               | XA[17:14]               | XA[18:15]  | XA[18:14]                                |  |
| 32                 | ADDR[12:0]<br>XA[17:13] | ADDR[13:0]<br>XA[18:14] |            |                                          |  |
| 64                 | ADDR[12:0]<br>XA[18:13] |                         |            |                                          |  |

The base address for each window must be an integer multiple of the window size, with one exception. When the window size is 32 Kbytes, the base address can be at \$4000 as well as the 32-Kbyte multiples \$0000 and \$8000.

This special case requires a modification in address line deployment. Normally, when the bank size is 32 Kbytes and the bank address is \$0000 or \$8000, CPU address lines ADDR[14:0] select individual bytes within the 32-Kbyte space and the ADDR[14:0] pins are connected to address lines A[14:0] of the memory device. When the base address is \$4000, the CPU address signal ADDR14 must be inverted to allow 32 Kbytes of contiguous memory. To do this, the CPU drives the inverted ADDR14 signal onto the XA14 pin when the window is active, and the non-inverted CPU ADDR14 signal onto the XA14 pin when the window is not active. Therefore, address 14 of the memory device must be connected to expansion line XA14 rather than normal address line ADDR14.

If the two memory windows overlap, window 1 has priority, and only the portion of window 2 that does not overlap window 1 remains active. If a

window overlaps any portion of internal registers, RAM, or EEPROM, that portion is repeated in all banks associated with that window. If a window overlaps (EP)ROM, the (EP)ROM is present in all banks with XA[18:16] = 0:0:0.

The reset vector most commonly resides in on-chip (EP)ROM at address \$FFFE-\$FFF. However, if the (EP)ROM is disabled or mapped at address \$2000-\$7FFF, the reset vector is fetched from external memory at \$FFFE-\$FFF. When expanded memory is enabled, the reset vector is fetched from external memory at \$7FFE-\$7FFF, regardless of the presence of on-chip (EP)ROM.

#### 11.3.2 Control Registers

Expansion address lines are enabled by the port G assignment register (PGAR). The size and position of memory windows are controlled by the memory mapping size (MMSIZ) and memory mapping window base (MMWBR) registers, respectively. The memory mapping window control registers, MM1CR and MM2CR, select the particular bank or page of expanded memory present in the window(s) at a given time.

**NOTE:** 

Throughout this manual, the registers are discussed by function. In the event that not all bits in a register are referenced, the bits that are not discussed are shaded.

#### 11.3.2.1 Port G Assignment Register

The port G assignment register (PGAR) sets each of port G pins 5:0 as either an input/output (I/O) pin or memory expansion address line. Clearing a bit configures the corresponding port G pin as GPIO; setting the bit configures the pin as an expansion address line. If neither bank uses a particular expansion address bit, the corresponding pin is available for GPIO.

NOTE:

A special case exists for the address lines that overlap the CPU address lines XA[15:13]. If these lines are selected as expansion address lines in PGAR, but are not used in either window, the corresponding CPU address line is still output on the appropriate pin.



Figure 11-1. Port G Assignment Register (PGAR)

PGAR[5:0] — Port G Pin Assignment Bits

0 = Corresponding port G pin is GPIO.

1 = Corresponding port G pin is expansion address line XA[18:13].

#### 11.3.2.2 Memory Mapping Size Register

The memory mapping size register (MMSIZ) sets the size of the windows in use.



Figure 11-2. Memory Mapping Size Register (MMSIZ)

W2SZ[1:0] — Window 2 Size Bit

W1SZ[1:0] — Window 1 Size Bit

These bits enable the memory windows and determine their size, as shown in **Table 11-2**.

**Table 11-2. Window Size Select** 

| WxSZ[1:0] | Window Size                                    |  |  |  |
|-----------|------------------------------------------------|--|--|--|
| 00        | Window disabled                                |  |  |  |
| 01        | 8 K — Window can have up to 64 8-Kbyte banks   |  |  |  |
| 10        | 16 K — Window can have up to 32 16-Kbyte banks |  |  |  |
| 11        | 32 K — Window can have up to 16 32-Kbyte banks |  |  |  |

#### 11.3.2.3 Memory Mapping Window Base Register

The memory mapping window base register (MMWBR) defines the starting address of each of the two windows within the CPU 64-Kbyte address range. The windows normally begin at a boundary related to their size (an 8-Kbyte window can begin on any 8-Kbyte boundary, beginning at \$0000).



Figure 11-3. Memory Mapping Window Base Register (MMWBR)

W2A[15:13] — Window 2 Base Address Bits

Selects the three most significant bits (MSB) of the base address for memory mapping window 2. Refer to **Table 11-3**.

W1A[15:13] — Window Base 1 Address Bits

Selects the three MSB of the base address for memory mapping window 1. Refer to **Table 11-3**.

Table 11-3. Memory Expansion Window Base Address

MSB Bits Window Base Address

| MSB Bits   | Window Base Address |           |           |
|------------|---------------------|-----------|-----------|
| WxA[15:13] | 8 Kbytes            | 16 Kbytes | 32 Kbytes |
| 000        | \$0000              | \$0000    | \$0000    |
| 001        | \$2000              | \$0000    | \$0000    |
| 010        | \$4000              | \$4000    | \$4000    |
| 011        | \$6000              | \$4000    | \$4000    |
| 100        | \$8000              | \$8000    | \$8000    |
| 101        | \$A000              | \$8000    | \$8000    |
| 110        | \$C000              | \$C000    | \$8000    |
| 111        | \$E000              | \$C000    | \$8000    |

#### 11.3.2.4 Memory Mapping Window Control Registers

Each of the memory mapping window control registers (MM1CR and MM2CR) determine the active memory bank for the corresponding window, containing the value to be output on the expansion address lines when the CPU selects addresses within its extended memory window. To change banks, write the address of the new bank into the appropriate window register.



Figure 11-4. Memory Mapping Window Control Registers (MM1CR and MM2CR)

X1A[18:13] — Memory Mapping Window 1 Expansion Address Line Select Bits

X2A[18:13] — Memory Mapping Window 2 Expansion Address Line Select Bits

Each bit value written to the MMxCR registers is driven on the corresponding port G expansion address line (if enabled by PGAR) to enable the specified bank in the window.

#### 11.4 Chip Selects

The M68HC11K Family microcontrollers contain a set of four software-configured chip select signals which can reduce the amount of external glue logic needed to interface the MCU to external devices in the memory map. Each chip select signal is asserted when the CPU accesses a memory location in its designated range, which is determined by writes to control registers. Polarity of most chip-select signals is programmable, as well as the segment of the address cycle during which the signal is asserted (high E clock or address valid). Some chip-select signals can be programmed to drive each other as well as their own designated sections of memory (see 11.4.4 One Chip Select Driving Another), and the bus cycle during which any chip-select signal is asserted can be "stretched" up to three clock cycles (see 11.4.5 Clock Stretching).

The four chip-select signals operate only in expanded modes. The program chip select (CSPROG) is used to enable external memory in the 64-Kbyte memory map that contains the reset vectors and program. The chip select for I/O (CSIO) operates only within the first eight Kbytes of the memory map. The two general-purpose chip selects, CSGP1 and CSGP2, can enable devices anywhere in the 1-Mbyte expanded memory space. Any port H pins 4-7 that are not used for chip-select functions can serve as GPIO pins.

The six chip select control registers are:

- CSCTL enables and controls most of the features in CSPROG and CSIO.
- GPCS1A, GPCS1C, GPCS2A, and GPCS2C define most of the operations of the two general-purpose chip selects.
- CSCSTR controls clock stretching for all four signals.

**Table 11-4** summarizes the controls for each of the chip-select signals.

**Table 11-4. Chip Select Control Parameter Summary** 

|        |               | -                     |                                                    |
|--------|---------------|-----------------------|----------------------------------------------------|
| CSIO   | Enable        | IOEN in CSCTL         | 1 = enabled, 0 = disabled <sup>(1)</sup>           |
|        | Valid         | IOCSA in CSCTL        | 1 = address valid, 0 <sup>(1)</sup> = E high       |
|        | Polarity      | IOPL in CSCTL         | 1 = active high, 0 = active low <sup>(1)</sup>     |
|        | 0:            | 1007 to 000TI         | 1 = 4 K (\$1000-\$1FFF)                            |
|        | Size          | IOSZ in CSCTL         | $0 = 8 \text{ K } (\$0000 - \$1 \text{FFF})^{(1)}$ |
|        | Start address | Fixed (see size)      |                                                    |
|        | Stretch       | IO1S[A:B] in CSCSTR   | 0 <sup>(1)</sup> , 1, 2, or 3 E clocks             |
| CSPROG | Enable        | PCSEN in CSCTL        | 1 = enabled <sup>(1)</sup> , 0 = disabled          |
|        | Valid         | Fixed (address valid) | i – enableu – , 0 – ulsableu                       |
|        |               | ' '                   |                                                    |

| CSPROG | Enable                  | PCSEN in CSCTL        | 1 = enabled <sup>(1)</sup> , 0 = disabled |
|--------|-------------------------|-----------------------|-------------------------------------------|
|        | Valid                   | Fixed (address valid) |                                           |
|        | Polarity                | Fixed (active low)    |                                           |
|        |                         |                       | 0:0 = 64 K (\$0000-\$FFFF) <sup>(1)</sup> |
|        | Size                    | PCSZ[A:B] in CSCTL    | 0:1 = 32 K (\$8000-\$FFFF)                |
|        | OIZO                    | 1 002[A.b] III 0001E  | 1:0 = 16 K (\$C000-\$FFFF)                |
|        |                         |                       | 1:1 = 8 K (\$E000-\$FFFF)                 |
|        | Start address           | Fixed (see size)      |                                           |
|        | Stretch                 | PCS[A:B] in CSCSTR    | 0 <sup>(1)</sup> , 1, 2, or 3 E clocks    |
|        | Priority GCSPR in CSCTL | GCSPR in CSCTL        | 1 = CSGPx above CSPROG                    |
|        | 1 HOTHY                 | OOGI IV III OOCI L    | 0 <sup>(1)</sup> = CSPROG above CSGPx     |

| CSGP1, | Enable        | Set size to 0K to disable                  |                                                                                                                |
|--------|---------------|--------------------------------------------|----------------------------------------------------------------------------------------------------------------|
| CSGP2  | Valid         | G1AV in GPCS1C<br>G2AV in GPCS2C           | 1 = address valid, 0 = E high <sup>(1)</sup>                                                                   |
|        | Polarity      | G1POL in GPS1C<br>G2POL in GPS2C           | 1 = active high, 0 = active low <sup>(1)</sup>                                                                 |
|        | Size          | G1SZ[A:D] in GPCS1C<br>G1SZ[A:D] in GPCS2C | 2 K to 512 K in nine steps  0K = disabled <sup>(1)</sup> can also follow memory expansion window 1 or window 2 |
|        | Start address | GPCS1A<br>GPCS2A                           |                                                                                                                |
|        | Stretch       | CSCSTR                                     | 0 <sup>(1)</sup> , 1, 2, or 3 E clocks                                                                         |
|        |               | G1DG2 in GPCS1C                            | Allows CSGP1 and CSGP2 to be logically ORed and driven out the CSGP2 pin                                       |
|        |               | G1DPC in GPCS1C                            | Allows CSGP1 and CSPROG to be logically ORed and driven out the CSPROG pin                                     |
|        | Other         | G2DPC in GPCS2C                            | Allows CSGP2 and CSPROG to be logically ORed and driven out the CSPROG pin.                                    |
|        |               | MXGS2 in MMSIZ                             | Allows CSGP2 to follow either 64 K CPU addresses or 512K expansion addresses                                   |
|        |               | MXGS1 in MMSIZ                             | Allows CSGP1 to follow either 64 K CPU addresses or 512K expansion addresses                                   |

<sup>1.</sup> Configuration at reset

#### 11.4.1 Program Chip Select

The program chip select signal accesses external memory in the main program area within the MCU's 64-Kbyte memory map. Program chip select validity is fixed at address valid timing and polarity is fixed at active low. The chip-select control register (CSCTL) contains bits to enable CSPROG, determine its priority over the general-purpose chip selects, and set its effective address range. Clock stretching can be set from zero to three cycles.



Figure 11-5. Chip-Select Control Register (CSCTL)

GCSPR — General-Purpose Chip Select Priority Bit

- 0 = Program chip select has priority over general-purpose chip selects
- 1 = General-purpose chip selects have priority over program chip select

PCSEN — Program Chip Select Enable Bit

- 0 = CSPROG disabled and port H bit 7 available as GPIO
- 1 = CSPROG enabled out of reset and uses port H bit 7 pin

PCSZA and PCSZB — Program Chip Select Size A Bit and Program Chip Select Size B Bit

These bits determine the address range of CSPROG, as shown in **Table 11-5**.

**PCSZA PCSZB** Size (Bytes) Address Range 0 0 64 K \$0000-\$FFFF 32 K \$8000-\$FFFF 0 1 1 0 16 K \$C000-\$FFFF 1 1 8 K \$E000-\$FFFF

Table 11-5. Program Chip Select Size

#### 11.4.2 Input/Output Chip Select

The I/O chip select (CSIO) is programmable for a 4-Kbyte size located at addresses \$1000–\$1FFF or 8-Kbyte size located at addresses \$0000–\$1FFF. The default active-low polarity can be changed to active high by setting the IOPL bit in CSCTL. Default validity during high E clock can be changed to address valid time by setting the IOCSA bit in CSCTL. Clock stretching can be set from zero to three cycles (See 11.4.5 Clock Stretching). CSIO is disabled out of reset.



Figure 11-6. Chip-Select Control Register (CSCTL)

IOEN — I/O Chip-Select Enable Bit

0 = CSIO is disabled and port H bit 4 is GPIO.

1 = CSIO is enabled and uses port H bit 4.

IOPL — I/O Chip-Select Polarity Select Bit

0 = CSIO active low

1 = CSIO active high

IOCSA — I/O Chip-Select Address Valid Bit

0 = CSIO is valid during E-clock high time.

1 = CSIO is valid during address valid time.

IOSZ — I/O Chip-Select Size Select Bit

0 = CSIO size is four Kbytes at \$1000-\$1FFF.

1 = CSIO size is eight Kbytes at \$0000-\$1FFF.

#### 11.4.3 General-Purpose Chip Selects

The general-purpose chip selects are the most flexible and programmable of the chip-select signals. They can access any memory in the expanded 1-Mbyte address space. Polarity of active state, E valid or address valid, size, and starting address are all programmable. Clock stretching can be set from zero to three cycles. Both signals can be programmed to drive CSPROG, and GPCS1 can be configured to drive GPCS2. In addition, each signal can follow a window; for instance, be asserted whenever the CPU address falls within a selected memory expansion window regardless of the state of the expanded address lines.

There are two registers for each of the general-purpose chip select signals:

- The control register, GPS1C or GPS2C, determines the GPCS's active signal polarity, its valid time, which of the other chip-select signals it can drive, and either the size of the memory it enables or which window it follows.
- The address register, GPS1A or GPS2A, programs the chip-select's starting address; valid bits in this register are determined by the size of the address range selected by the control register.

In addition, the MMSIZ register contains a bit for each GPCS which determines whether it is driven by the CPU's 64-Kbyte address lines or the expansion address lines.

#### 11.4.3.1 Memory Mapping Size Register



Figure 11-7. Memory Mapping Size Register (MMSIZ)

MXGS2 — Memory Expansion Select for GPCS 2 Bit

0 = GPCS 2 based on 64-Kbyte CPU address

1 = GPCS 2 based on expansion address

MXGS1 — Memory Expansion Select for GPCS 1 Bit

0 = GPCS 1 based on 64-Kbyte CPU address

1 = GPCS 1 based on expansion address

#### 11.4.3.2 General-Purpose Chip Select 1 Address Register



Figure 11-8. General-Purpose Chip Select 1
Address Register (GPCS1A)

G1A[18:11] — General-Purpose Chip Select 1 Address Bits

They select the starting address of GPCS1. Refer to Table 11-6.

#### 11.4.3.3 General-Purpose Chip Select 1 Control Register



Figure 11-9. General-Purpose Chip Select 1
Control Register (GPCS1C)

G1POL — General-Purpose Chip Select 1 Polarity Select Bit

0 = CSGP1 active low

1 = CSGP1 active high

G1AV — General-Purpose Chip Select 1 Address Valid Select Bit

0 = CSGP1 is valid during E high time.

1 = CSGP1 is valid during address valid time.

G1SZ[A:D] — General-Purpose Chip Select 1 Size Bits

They select the range of GPCS1. Refer to Table 11-6.

Table 11-6. General-Purpose Chip Select 1 Size Control

| G1SZ[A:D] | Size (Bytes)     | Valid Bits<br>(MXGS1 = 0) | Valid Bits<br>(MXGS1 = 1) |
|-----------|------------------|---------------------------|---------------------------|
| 0000      | Disabled         | None                      | None                      |
| 0 0 0 1   | 2 K              | G1A[15:11]                | G1A[18:11]                |
| 0010      | 4 K              | G1A[15:11]                | G1A[18:12]                |
| 0 0 1 1   | 8 K              | G1A[15:13]                | G1A[18:13]                |
| 0100      | 16 K             | G1A[15:14]                | G1A[18:14]                |
| 0 1 0 1   | 32 K             | G1A[15]                   | G1A[18:15]                |
| 0110      | 64 K             | None                      | G1A[18:16]                |
| 0111      | 128 K            | None                      | G1A[18:17]                |
| 1000      | 256 K            | None                      | G1A18                     |
| 1 0 0 1   | 512 K            | None                      | None                      |
| 1010      | Follow window 1  | None                      | None                      |
| 1011      | Follow window 2  | None                      | None                      |
| 1100–1111 | Default to 512 K | None                      | None                      |

#### 11.4.3.4 General-Purpose Chip Select 2 Address Register



Figure 11-10. General-Purpose Chip Select 2
Address Register (GPCS2A)

G2A[18:11] — General-Purpose Chip Select 2 Address Bits

They select the starting address of GPCS2. Refer to Table 11-7.

#### 11.4.3.5 General-Purpose Chip Select 2 Control Register



Figure 11-11. General-Purpose Chip Select 2
Control Register (GPCS2C)

G2POL — General-Purpose Chip Select 2 Polarity Select Bit

0 = CSGP2 active low

1 = CSGP2 active high

G2AV — General-Purpose Chip Select 2 Address Valid Select Bit

0 = CSGP2 is valid during E high time.

1 = CSGP2 is valid during address valid time.

G2SZ[A:D] — General-Purpose Chip Select 2 Size Bits

They select the range of GPCS2. Refer to **Table 11-7**.

Table 11-7. General-Purpose Chip Select 2 Size Control

| G2SZ[A:D] | Size<br>(Bytes)  | Valid Bits<br>(MXGS2 = 0) | Valid Bits<br>(MXGS2 = 1) |
|-----------|------------------|---------------------------|---------------------------|
| 0000      | Disabled         | None                      | None                      |
| 0 0 0 1   | 2 K              | G2A[15:11]                | G2A[18:11]                |
| 0 0 1 0   | 4 K              | G2A[15:11]                | G2A[18:12]                |
| 0 0 1 1   | 8 K              | G2A[15:13]                | G2A[18:13]                |
| 0100      | 16 K             | G2A[15:14]                | G2A[18:14]                |
| 0101      | 32 K             | G2A[15]                   | G2A[18:15]                |
| 0110      | 64 K             | None                      | G2A[18:16]                |
| 0111      | 128 K            | None                      | G2A[18:17]                |
| 1000      | 256 K            | None                      | G2A18                     |
| 1001      | 512 K            | None                      | None                      |
| 1010      | Follow window 1  | None                      | None                      |
| 1011      | Follow window 2  | None                      | None                      |
| 1100–1111 | Default to 512 K | None                      | None                      |

#### 11.4.4 One Chip Select Driving Another

The general-purpose chip selects can be programmed to drive other chip-select signals as well as their own memory areas. Although all of the eight possible combinations of the bits G1DG2, G1DPC, and G2DPC are allowed, some combinations cause operations which do not perform as one might expect. The results of all combinations are defined in **Table 11-8**. The priorities defined in the previous sections still apply. The table assumes that none of the chip-select ranges overlap.

#### 11.4.4.1 General-Purpose Chip Select 1 Control Register



Figure 11-12. General-Purpose Chip Select 1
Control Register (GPCS1C)

G1DG2 — GPCS 1 Drives GPCS 2 Bit

0 = CSGP1 does not affect CSGP2.

1 = CSGP1 and CSGP2 are ORed and driven out of the CSGP2.

G1DPC — General-Purpose Chip Select 1 Drives Program Chip Select Bit

0 = CSGP1 does not affect CSPROG.

1 = CSGP1 and CSPROG are ORed and driven out of the CSPROG.

#### 11.4.4.2 General-Purpose Chip Select 2 Control Register



Figure 11-13. General-Purpose Chip Select 2
Control Register (GPCS2C)

G2DPC — General-Purpose Chip Select 2 Drives Program Chip Select Bit

0 = Does not affect program chip select

1 = CSGP2 and CSPROG are ORed and driven out of the CSPROG pin.

Table 11-8. One Chip Select Driving Another

| G1DG2 | G1DPC | G2DPC | Program CS Pin<br>is Asserted<br>When Address is in: | General 2 CS Pin<br>is Asserted<br>When Address is in: | General 1 CS Pin<br>is Asserted<br>When Address is in: |
|-------|-------|-------|------------------------------------------------------|--------------------------------------------------------|--------------------------------------------------------|
| 0     | 0     | 0     | A valid program area                                 | A valid general 2 area                                 | A valid general 1 area                                 |
| 0     | 0     | 1     | A valid program or general 2 area                    | Never asserted                                         | A valid general 1 area                                 |
| 0     | 1     | 0     | A valid program or general 1 area                    | A valid general 2 area                                 | Never asserted                                         |
| 0     | 1     | 1     | A valid program or general 1 or 2 area               | Never asserted                                         | Never asserted                                         |
| 1     | 0     | 0     | A valid program area                                 | A valid general 2 or general 1 area                    | Never asserted                                         |
| 1     | 0     | 1     | A valid program or general 2 area                    | Never asserted                                         | A valid general 1 area                                 |
| 1     | 1     | 0     | A valid program or general 1 area                    | A valid general 2 area                                 | Never asserted                                         |
| 1     | 1     | 1     | A valid program or general 1 or 2 area               | Never asserted                                         | Never asserted                                         |

#### 11.4.5 Clock Stretching

Chip select and bus control signals are synchronized with the external E clock. To accommodate devices that are slower than the MCU, the E clock can be stretched when a chip select is asserted so that it remains high for one to three extra bus cycles. During this stretch, which can occur only during accesses to addresses in that chip select's address range, the other clocks continue running normally, maintaining the integrity of the timers and baud generators. Each chip select has two associated bits in the chip-select clock stretch (CSCSTR) register that set its clock stretching from zero (disabled) to three cycles.

Address: \$005A Bit 7 6 5 4 3 2 1 Bit 0 Read: **IOSA IOSB** GP1SA GP1SB GP2SA GP2SB **PCSA PCSB** Write: 0 0 0 0 Reset: 0 0 0 0

Figure 11-14. Chip Select Clock Stretch Register (CSCSTR)

IOS[A:B] — CSIO Stretch Select Bits

GP1S[A:B] — CSGP1 Stretch Select Bits

GP2S[A:B] — CSGP2 Stretch Select Bits

PCS[A:B] — CSPROG Stretch Select Bits

Each of these pairs of bits contain the binary number of cycles of clock stretch, as shown in **Table 11-9**.

| Bit [A:B] | Clock Stretch |
|-----------|---------------|
| 0 0       | None          |
| 0 1       | 1 cycle       |
| 1 0       | 2 cycles      |
| 11        | 3 cycles      |

Table 11-9. CSCSTR Bits Versus Clock Cycles

## 11.5 Memory Expansion Examples

The first example, shown in **Figure 11-15** contains a system with 64 Kbytes of external memory to be accessed through a single 8-Kbyte window. To access eight Kbytes, or 2<sup>13</sup> address locations, the CPU will need 13 address lines, ADDR[12:0]. The number of memory banks needed is the total memory, 64 Kbytes divided by the window size, eight Kbytes. This yields eight memory banks, or 2<sup>3</sup>. Thus, three expansion lines are required, so expansion address lines XA[15:13] replace CPU address lines ADDR[15:13]. **Figure 1-1** shows a memory map and schematic drawing of this system.



Figure 11-15. Memory Expansion Example 1 — Memory Map for a Single 8-Kbyte Window with Eight Banks of External Memory

The second example system shown in **Figure 11-16** contains two memory windows. The first window is organized as in the previous example, 8 banks of 8 Kbytes each. The second window accesses 256 Kbytes of memory in 16 banks of 16 Kbyte each. To access 16 Kbytes, or 2<sup>14</sup> address locations, the CPU will need 14 address lines, ADDR[13:0]. Since ADDR13 is driven on XA13 in this example, XA13 replaces ADDR13 to drive the A13 line in the 6226 devices, but ADDR13 could be used as well. 16 (2<sup>4</sup>) memory banks require four expansion address lines, A[17:14]. Refer to **Figure 11-16** for a memory map and schematic drawing of this system.



Figure 11-16. Memory Expansion Example 2 (Sheet 1 of 2) Memory Map for One 8-Kbyte Window with Eight Banks and One 16-Kbyte Window with 16 Banks of External Memory



Figure 11-16. Memory Expansion Example 2 (Sheet 2 of 2) Memory Map for One 8-Kbyte Window with Eight Banks and One 16-Kbyte Window with 16 Banks of External Memory

# **Section 12. Electrical Characteristics**

### 12.1 Contents

| 12.2  | Introduction                                |
|-------|---------------------------------------------|
| 12.3  | Maximum Ratings for Standard Devices254     |
| 12.4  | Functional Operating Range255               |
| 12.5  | Thermal Characteristics                     |
| 12.6  | Electrical Characteristics                  |
| 12.7  | Power Dissipation Characteristics           |
| 12.8  | Control Timing                              |
| 12.9  | Peripheral Port Timing                      |
| 12.10 | Analog-to-Digital Converter Characteristics |
| 12.11 | Expansion Bus Timing                        |
| 12.12 | Serial Peripheral Interface Timing269       |
| 12.13 | EEPROM Characteristics                      |

### 12.2 Introduction

This section contains electrical parameters for standard and extended voltage devices. When applicable, extended voltage parameters are shown separately. Diagrams apply to both standard and extended voltage devices.

### 12.3 Maximum Ratings for Standard Devices

Maximum ratings are the extreme limits to which the MCU can be exposed without permanently damaging it.

NOTE:

This device is not guaranteed to operate properly at the maximum ratings. Refer to **12.6 Electrical Characteristics** for guaranteed operating conditions.

| Rating                                                                                            | Symbol           | Value        | Unit |
|---------------------------------------------------------------------------------------------------|------------------|--------------|------|
| Supply voltage                                                                                    | $V_{DD}$         | -0.3 to +7.0 | V    |
| Input voltage                                                                                     | V <sub>In</sub>  | -0.3 to +7.0 | V    |
| Current drain per $pin^{(1)}$ excluding $V_{DD}$ , $V_{SS}$ , $AV_{DD}$ , $V_{RH}$ , and $V_{RL}$ | I <sub>D</sub>   | 25           | mA   |
| Storage temperature                                                                               | T <sub>STG</sub> | -55 to +150  | °C   |

<sup>1.</sup> One pin at a time, observing maximum power dissipation limits

### **NOTE:**

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

## 12.4 Functional Operating Range

| Rating                                                                         | Symbol          | Value                                                               | Unit |
|--------------------------------------------------------------------------------|-----------------|---------------------------------------------------------------------|------|
| Operating temperature range<br>MC68HC(7)11KC<br>MC68HC(7)11KV<br>MC68HC(7)11KM | T <sub>A</sub>  | T <sub>L</sub> to T <sub>H</sub> -40 to +85 -40 to +105 -40 to +125 | °C   |
| Operating voltage range                                                        | V <sub>DD</sub> | 5.0 ± 10%                                                           | V    |

### 12.5 Thermal Characteristics

| Characteristic                                                                                                                                                                                                                          | Symbol           | Value                                                                | Unit |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|----------------------------------------------------------------------|------|
| Average junction temperature                                                                                                                                                                                                            | T <sub>J</sub>   | $T_A + (P_D \times \Theta_{JA})$                                     | °C   |
| Ambient temperature                                                                                                                                                                                                                     | T <sub>A</sub>   | User-determined                                                      | °C   |
| Package thermal resistance (junction-to-ambient) 80-pin low-profile quad flat pack 68-pin plastic leaded chip carrier 68-pin windowed ceramic cerquad (EPROM) 84-pin plastic leaded chip carrier 80-pin quad flat pack 84-pin J-cerquad | $\Theta_{JA}$    | 80<br>50<br>60<br>50<br>85<br>50                                     | °C/W |
| Total power dissipation <sup>(1)</sup>                                                                                                                                                                                                  | P <sub>D</sub>   | P <sub>INT</sub> + P <sub>I/O</sub><br>K / T <sub>J</sub> + 273 °C   | W    |
| Device internal power dissipation                                                                                                                                                                                                       | P <sub>INT</sub> | $I_{DD} \times V_{DD}$                                               | W    |
| I/O pin power dissipation <sup>(2)</sup>                                                                                                                                                                                                | P <sub>I/O</sub> | User-determined                                                      | W    |
| A constant <sup>(3)</sup>                                                                                                                                                                                                               | К                | $P_{D} \times (T_{A} + 273^{\circ}C) + \Theta_{JA} \times P_{D}^{2}$ | W/°C |

<sup>1.</sup> This is an approximate value, neglecting  $P_{\text{I/O}}$ .

<sup>2.</sup> For most applications,  $P_{I/O} \leq P_{INT}$  and can be neglected.

<sup>3.</sup> 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$ .

### 12.6 Electrical Characteristics

| Characteristic <sup>(1)</sup>                                                                                                                                           | Symbol                             | Min                                            | Max                              | Unit |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------|------------------------------------------------|----------------------------------|------|
| Output voltage, $I_{Load} = \pm 10.0 \ \mu A^{(2)}$ ) All outputs except XTAL All outputs except XTAL, RESET, and MODA                                                  | V <sub>OL</sub><br>V <sub>OH</sub> | <br>V <sub>DD</sub> - 0.1                      | 0.1                              | V    |
| Output high voltage, $I_{Load} = -0.8 \text{ mA}$ , $V_{DD} = 4.5 \text{ V}^{(2)}$<br>All outputs except XTAL, RESET, and MODA                                          | V <sub>OH</sub>                    | V <sub>DD</sub> - 0.8                          | _                                | V    |
| Output low voltage, I <sub>Load</sub> = 1.6 mA All outputs except XTAL                                                                                                  | V <sub>OL</sub>                    | _                                              | 0.4                              | V    |
| Input high voltage All inputs except RESET RESET                                                                                                                        | V <sub>IH</sub>                    | 0.7 x V <sub>DD</sub><br>0.8 x V <sub>DD</sub> | $V_{DD} + 0.3$<br>$V_{DD} + 0.3$ | V    |
| Input low voltage All Inputs                                                                                                                                            | V <sub>IL</sub>                    | V <sub>SS</sub> - 0.3                          | 0.2 x V <sub>DD</sub>            | V    |
| I/O ports, three-state leakage, V <sub>In</sub> = V <sub>IH</sub> or V <sub>IL</sub> Ports A, B, C, D, F, G, H, MODA/LIR, RESET                                         | l <sub>oz</sub>                    | _                                              | ±10                              | μΑ   |
| Input leakage current, V <sub>In</sub> = V <sub>DD</sub> or V <sub>SS</sub> <sup>(3)</sup> IRQ, XIRQ on standard devices MODB/V <sub>STBY</sub> , XIRQ on EPROM devices | I <sub>In</sub>                    | _                                              | ±1<br>±10                        | μΑ   |
| Input current with pullup resistors, $V_{In} = V_{IL}$<br>Ports B, F, G, and H                                                                                          | I <sub>IPR</sub>                   | 100                                            | 500                              | μΑ   |
| RAM standby voltage, power down                                                                                                                                         | V <sub>SB</sub>                    | 2.0                                            | V <sub>DD</sub>                  | V    |
| RAM standby current, power down                                                                                                                                         | I <sub>SB</sub>                    | _                                              | 10                               | μΑ   |
| Input capacitance PE[7:0], IRQ, XIRQ, EXTAL Ports A, B, C, D, F, G, H, MODA/LIR, RESET                                                                                  | C <sub>In</sub>                    | _                                              | 8<br>12                          | pF   |
| Output load capacitance All outputs except PD[4:1], XOUT, XTAL, MODA/LIR PD[4:1] XOUT                                                                                   | CL                                 | _<br>_<br>_                                    | 90<br>200<br>30                  | pF   |

<sup>1.</sup>  $V_{DD}$  = 5.0 Vdc  $\pm$  10%,  $V_{SS}$  = 0 Vdc,  $T_A$  =  $T_L$  to  $T_H$ , unless otherwise noted 2.  $V_{OH}$  specification for RESET and MODA is not applicable because they are open-drain pins.  $V_{OH}$  specification not applicable to ports C and D in wired-OR mode.

<sup>3.</sup> Refer to 12.10 Analog-to-Digital Converter Characteristics for leakage current for port E.

# 12.7 Power Dissipation Characteristics

| Characteristic                              | Symbol           | 2 MHz | 3 MHz | 4 MHz | Unit |
|---------------------------------------------|------------------|-------|-------|-------|------|
| Maximum total supply current <sup>(1)</sup> |                  |       |       |       |      |
| RUN:                                        |                  |       |       |       |      |
| Single-chip mode                            | l <sub>DD</sub>  | 27    | 33    | 40    | mA   |
| Expanded mode                               |                  | 35    | 42    | 50    |      |
| Slow mode                                   |                  | 6.5   | 7.0   | 7.5   |      |
| WAIT: (All peripheral functions shut down)  |                  |       |       |       |      |
| Single-chip mode                            | 10/1             | 10    | 15    | 20    | ^    |
| Expanded mode                               | WI <sub>DD</sub> | 12    | 17    | 22    | mA   |
| Slow mode                                   |                  | 3.5   | 4.5   | 5.5   |      |
| STOP: (No clocks)                           | CI               | 50    | 50    | 50    | _    |
| Single-chip mode                            | SI <sub>DD</sub> | 50    | 50    | 50    | μΑ   |
| Maximum power dissipation                   |                  |       |       |       |      |
| Single-chip mode                            | P <sub>D</sub>   | 149   | 149   | 220   | mW   |
| Expanded mode                               |                  | 193   | 193   | 275   |      |

<sup>1.</sup> EXTAL is driven with a square wave;  $t_{cyc}$  = 500 ns for 2 MHz rating;  $t_{cyc}$  = 250 ns for 4 MHz rating;  $V_{IL} \le 0.2 \text{ V}$ ;  $V_{IH} \ge V_{DD}$  –0.2 V; no dc loads

### **Electrical Characteristics**





#### Notes:

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

Figure 12-1. Test Methods

### 12.8 Control Timing

| Characteristic <sup>(1)</sup>                                                                                  | Cumbal             | 1.0        | ИНz    | 2.0        | MHz      | 3.0 MHz    |      | 4.0 MHz |          | Unit             |
|----------------------------------------------------------------------------------------------------------------|--------------------|------------|--------|------------|----------|------------|------|---------|----------|------------------|
| Characteristic                                                                                                 | Symbol             | Min        | Max    | Min        | Max      | Min        | Max  | Min     | Max      | Unit             |
| Frequency of operation                                                                                         | f <sub>o</sub>     | dc         | 1.0    | dc         | 2.0      | dc         | 3.0  | dc      | 4.0      | MHz              |
| E-clock period                                                                                                 | t <sub>cyc</sub>   | 1000       | _      | 500        | _        | 333        | _    | 250     | _        | ns               |
| Crystal frequency                                                                                              | f <sub>XTAL</sub>  | _          | 4.0    | _          | 8.0      | _          | 12.0 | _       | 16.0     | MHz              |
| External oscillator frequency                                                                                  | 4 f <sub>o</sub>   | dc         | 4.0    | dc         | 8.0      | dc         | 12.0 | dc      | 16.0     | MHz              |
| Processor control setup time $t_{PCSU} = 1/4 t_{cyc} + 50 \text{ ns}$ $t_{PCSU} = 1/4 t_{cyc} + 75 \text{ ns}$ | t <sub>PCSU</sub>  | 300<br>325 | _      | 175<br>200 | _        | 133<br>158 | _    | 112     | _        | ns               |
| (extended voltage devices)                                                                                     |                    | 323        |        | 200        |          | 130        |      |         |          |                  |
| Reset input pulse width <sup>(2)</sup> To guarantee external reset vector Minimum input time <sup>(3)</sup>    | PW <sub>RSTL</sub> | 16<br>1    | _<br>_ | 16<br>1    | <u> </u> | 16<br>1    | _    | 16<br>1 | <u> </u> | t <sub>cyc</sub> |
| Mode programming setup time                                                                                    | t <sub>MPS</sub>   | 2          | _      | 2          | _        | 2          | _    | 2       | _        | t <sub>cyc</sub> |
| Mode programming hold time                                                                                     | t <sub>MPH</sub>   | 10         | _      | 10         | _        | 10         | _    | 10      | _        | ns               |
| Interrupt pulse width, IRQ edge-sensitive mode PW <sub>IRQ</sub> = t <sub>cyc</sub> + 20 ns                    | $PW_{IRQ}$         | 1020       | _      | 520        | _        | 353        | _    | 270     | _        | ns               |
| Wait recovery startup time                                                                                     | t <sub>WRS</sub>   | _          | 4      | _          | 4        | _          | 4    | _       | 4        | t <sub>cyc</sub> |
| Timer pulse width PW <sub>TIM</sub> = t <sub>cyc</sub> + 20 ns Input capture, pulse accumulator                | PW <sub>TIM</sub>  | 1020       | _      | 520        | _        | 353        | _    | 270     | _        | ns               |

- 1.  $V_{DD}$  = 4.5 to 5.5 Vdc for standard devices,  $V_{SS}$  = 0 Vdc,  $T_A$  =  $T_L$  to  $T_H$  All timing measurements refer to 20%  $V_{DD}$  and 70%  $V_{DD}$ , unless otherwise noted.
- 2. Reset is recognized during the first clock cycle it is held low. Internal circuitry then drives the pin low for eight clock cycles, releases the pin, and samples the pin level two cycles later to determine the source of the interrupt.
- 3. Can be pre-empted by internal reset



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

Figure 12-2. Timer Inputs

Technical Data

MOTOROLA



Figure 12-3. POR External Reset Timing Diagram

M68HC11K Family



#### Notes:

- 1. Edge-sensitive  $\overline{IRQ}$  pin (IRQE bit = 1)
- 2. Level-sensitive  $\overline{IRQ}$  pin (IRQE bit = 0)
- 3.  $\underline{t_{STOPDELAY}} = 4064 \, t_{cyc}$  if DLY bit = 1 or 4  $t_{cyc}$  if DLY = 0 4.  $\overline{XIRQ}$  with X bit in CCR = 1
- 5.  $\overline{IRQ}$  or  $\overline{XIRQ}$  with X bit in CCR = 0

Figure 12-4. STOP Recovery Timing Diagram

Technical Data

M68HC11K Family



Note: RESET also causes recovery from WAIT.

Figure 12-5. WAIT Recovery from Inerrupt Timing Diagram



- Notes:
  - 1. Edge-sensitive  $\overline{IRQ}$  pin (IRQE bit = 1)
  - 2. Level-sensitive  $\overline{IRQ}$  pin (IRQE bit = 0)

Figure 12-6. Interrupt Timing Diagram

## 12.9 Peripheral Port Timing

| 01(1)                                                                                                                                                                                                                                                                                                             | Symbol            | 1.0 MHz     |                          | 2.0 MHz     |                          | 3.0 MHz     |                          | 4.0 MHz     |                 | l lmi4 |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------|-------------|--------------------------|-------------|--------------------------|-------------|--------------------------|-------------|-----------------|--------|
| Characteristic <sup>(1)</sup>                                                                                                                                                                                                                                                                                     | Symbol            | Min         | Max                      | Min         | Max                      | Min         | Max                      | Min         | Max             | Unit   |
| Frequency of operation (E clock)                                                                                                                                                                                                                                                                                  | f <sub>o</sub>    | dc          | 1.0                      | dc          | 2.0                      | dc          | 3.0                      | dc          | 4.0             | MHz    |
| E-clock period                                                                                                                                                                                                                                                                                                    | t <sub>cyc</sub>  | 1000        | _                        | 500         |                          | 333         | _                        | 250         | _               | ns     |
| Peripheral data setup time <sup>(2)</sup> MCU read of ports A, B, C, D, E, F, G, and H                                                                                                                                                                                                                            | t <sub>PDSU</sub> | 100         |                          | 100         |                          | 100         |                          | 100         |                 | ns     |
| Peripheral data hold time MCU read of ports A, B, C, D, E, F, G, and H                                                                                                                                                                                                                                            | t <sub>PDH</sub>  | 50          | _                        | 50          | _                        | 50          | _                        | 50          | _               | ns     |
| Delay time, peripheral data write<br>Standard devices<br>MCU write to port A, B, G, and H<br>MCU write to ports C, D, and F<br>$(t_{PWD} = 1/4 t_{cyc} + 100 \text{ ns})$<br>Extended voltage<br>MCU write to port A, B, G, and H<br>MCU write to ports C, D, and F<br>$(t_{PWD} = 1/4 t_{cyc} + 150 \text{ ns})$ | t <sub>PWD</sub>  | _<br>_<br>_ | 200<br>350<br>250<br>400 | _<br>_<br>_ | 200<br>225<br>250<br>225 | _<br>_<br>_ | 200<br>183<br>250<br>233 | _<br>_<br>_ | 200<br>162<br>— | ns     |

V<sub>DD</sub> = 4.5 to 5.5 Vdc for standard devices, V<sub>SS</sub> = 0 Vdc, T<sub>A</sub> = T<sub>L</sub> to T<sub>H</sub>
 All timing measurements refer to 20% V<sub>DD</sub> and 70% V<sub>DD</sub>, unless otherwise noted.
 Ports C and D timing is valid only in active drive mode. (CWOM and DWOM bits are cleared in OPT2 and SPCR registers, respectively.)



Figure 12-7. Port Read Timing Diagram



Figure 12-8. Port Write Timing Diagram

# 12.10 Analog-to-Digital Converter Characteristics

|                               |                                                                                                                                          |                         |          | М                           | ax                                         |                        |
|-------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|-------------------------|----------|-----------------------------|--------------------------------------------|------------------------|
| Characteristic <sup>(1)</sup> | Parameter                                                                                                                                | Min                     | Absolute | f <sub>o</sub> ≤ 2.0<br>MHz | f <sub>o</sub> > 2.0<br>MHz <sup>(2)</sup> | Unit                   |
| Resolution                    | Number of bits resolved by A/D converter                                                                                                 | _                       | 8        | _                           | _                                          | Bits                   |
| Non-linearity                 | Maximum deviation from the ideal A/D transfer characteristics                                                                            | _                       | _        | ± 1/2                       | ± 1                                        | LSB                    |
| Zero error                    | Difference between the output of an ideal and an actual for zero input voltage                                                           | _                       | _        | ± 1/2                       | ± 1                                        | LSB                    |
| Full scale error              | Difference between the output of an ideal and an actual A/D for full-scale input voltage                                                 | _                       | _        | ± 1/2                       | ± 1                                        | LSB                    |
| Total unadjusted error        | Maximum sum of non-linearity, zero error, and full-scale error <sup>(3)</sup>                                                            | _                       | _        | ± 1/2                       | ± 1 1/2                                    | LSB                    |
| Quantization error            | Uncertainty because of converter resolution                                                                                              |                         | _        | ± 1/2                       | ± 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 | _                       | _        | ± 1                         | ± 2                                        | LSB                    |
| Conversion range              | Analog input voltage range                                                                                                               | V <sub>RL</sub>         | _        | $V_{RH}$                    | V <sub>RH</sub>                            | V                      |
| $V_{RH}$                      | Maximum analog reference voltage <sup>(3)</sup>                                                                                          | $V_{RL}$                | _        | $V_{DD} + 0.1$              | V <sub>DD</sub> + 0.1                      | V                      |
| V <sub>RL</sub>               | Minimum analog reference voltage <sup>(3)</sup>                                                                                          | V <sub>SS</sub><br>-0.1 | _        | $V_{RH}$                    | V <sub>RH</sub>                            | V                      |
| $\Delta V_R$                  | Minimum difference between $V_{RH}$ and $V_{RL}^{(3)}$                                                                                   | 3                       | _        | _                           | _                                          | V                      |
| Conversion time               | Total time to perform a single analog-to-digital conversion: E clock Internal RC oscillator                                              | _                       | 32<br>—  | <br>t <sub>cyc</sub> + 32   | <br>t <sub>cyc</sub> + 32                  | t <sub>cyc</sub><br>μs |
| Monotonicity                  | Conversion result never decreases with an increase in input voltage and has no missing codes                                             |                         | (        | Guarantee                   | d                                          |                        |
| Zero Input reading            | Conversion result when V <sub>In</sub> = V <sub>RL</sub>                                                                                 | 00                      | _        | _                           | _                                          | Hex                    |
| Full Scale reading            | Conversion result when V <sub>In</sub> = V <sub>RH</sub>                                                                                 | _                       | _        | FF                          | FF                                         | Hex                    |

Continued

## **Electrical Characteristics**

|                               |                                                                        |     |          | M                           |                                            |                        |
|-------------------------------|------------------------------------------------------------------------|-----|----------|-----------------------------|--------------------------------------------|------------------------|
| Characteristic <sup>(1)</sup> | Parameter                                                              | Min | Absolute | f <sub>o</sub> ≤ 2.0<br>MHz | f <sub>o</sub> > 2.0<br>MHz <sup>(2)</sup> | Unit                   |
| Sample acquisition time       | Analog input acquisition sampling time: E Clock Internal RC Oscillator | _   | 12<br>—  | <u> </u>                    | <u> </u>                                   | t <sub>cyc</sub><br>μs |
| Sample/hold capacitance       | Input capacitance during sample PE[7:0]                                |     | 20 (Typ) | _                           | _                                          | pF                     |
| Input leakage                 | Input leakage on A/D pins PE[7:0] V <sub>RL</sub> , V <sub>RH</sub>    | _   | _        | 400<br>1.0                  | 400<br>1.0                                 | nΑ<br>μΑ               |

<sup>1.</sup>  $V_{DD}$  = 4.5 to 5.5 Vdc for standard devices;  $V_{SS}$  = 0 Vdc,  $T_A$  =  $T_L$  to  $T_H$  Source impedances greater than 10  $k\Omega$  affect accuracy adversely because of input leakage.

All timing measurements refer to 20%  $V_{DD}$  and 70%  $V_{DD},$  unless otherwise noted.

<sup>2.</sup> Up to 4.0 MHz for standard devices.

<sup>3.</sup> Performance is verified down to 2.5 V  $\Delta V_R$ , but accuracy is tested and guaranteed at  $\Delta V_R$  = 5 V  $\pm 10\%$ .

## 12.11 Expansion Bus Timing

| Mirror   | Characteristic <sup>(1)</sup>                                                                                                     | Symbol            |          | MHz      | 3.0      | MHz      | 4.0      | MHz      | I last |
|----------|-----------------------------------------------------------------------------------------------------------------------------------|-------------------|----------|----------|----------|----------|----------|----------|--------|
| Num      |                                                                                                                                   | Symbol            | Min      | Max      | Min      | Max      | Min      | Max      | Unit   |
|          | Frequency of operation (E clock) <sup>(2)</sup>                                                                                   | f <sub>o</sub>    | dc       | 2.0      | dc       | 3.0      | dc       | 4.0      | MHz    |
| 1        | Cycle time, t <sub>cyc</sub> = 1/f <sub>o</sub>                                                                                   | t <sub>cyc</sub>  | 500      | _        | 333      | _        | 250      | _        | ns     |
| 2        | Pulse width, E low, $PW_{EL} = 1/2 t_{cyc} - 20 \text{ ns}$                                                                       | PW <sub>EL</sub>  | 230      | _        | 147      | _        | 105      | _        | ns     |
| 3        | Pulse width, E high <sup>(3)</sup><br>PW <sub>EH</sub> = 1/2 t <sub>cyc</sub> – 25 ns                                             | PW <sub>EH</sub>  | 225      | _        | 142      | _        | 100      | _        | ns     |
| 4A<br>4B | E clock Rise time Fall time                                                                                                       | t <sub>r</sub>    | <u> </u> | 20<br>20 | <u> </u> | 20<br>18 | <u> </u> | 20<br>15 | ns     |
| 9        | Address hold time, $t_{AH} = 1/8 t_{cyc} - 10 \text{ ns}$                                                                         | t <sub>AH</sub>   | 53       | _        | 32       | _        | 21       | _        | ns     |
| 11       | Address delay time, $t_{AD} = 1/8 t_{cyc} + 40 \text{ ns}$                                                                        | t <sub>AD</sub>   | _        | 103      | _        | 82       |          | 71       | ns     |
| 12       | Address valid time to E rise $t_{AV} = PW_{EL} - t_{AD}$                                                                          | t <sub>AV</sub>   | 128      | _        | 65       | _        | 34       | _        | ns     |
| 17       | Read data setup time                                                                                                              | t <sub>DSR</sub>  | 30       | _        | 30       | _        | 20       | _        | ns     |
| 18       | Read data hold time                                                                                                               | t <sub>DHR</sub>  | 0        | _        | 0        | _        | 0        | _        | ns     |
| 19       | Write data delay time                                                                                                             | t <sub>DDW</sub>  | _        | 40       | _        | 40       | _        | 40       | ns     |
| 21       | Write data hold time, t <sub>DHW</sub> = 1/8 t <sub>cyc</sub>                                                                     | t <sub>DHW</sub>  | 63       | _        | 42       | _        | 31       | _        | ns     |
| 29       | MPU address access time <sup>(3)</sup> $t_{ACCA} = t_{cyc} - t_f - t_{DSR} - t_{AD}$                                              | t <sub>ACCA</sub> | 348      | _        | 203      | _        | 144      | _        | ns     |
| 39       | Write data setup time <sup>(3)</sup> $t_{DSW} = PW_{EH} - t_{DDW}$                                                                | t <sub>DSW</sub>  | 185      | _        | 102      | _        | 60       | _        | ns     |
| 50       | E valid chip-select delay time                                                                                                    | t <sub>ECSD</sub> | _        | 40       | _        | 40       | _        | 40       | ns     |
| 51       | E valid chip-select access time <sup>(3)</sup> $t_{ECSA} = PW_{EH} - t_{ECSD} - t_{DSR}$                                          | t <sub>ECSA</sub> | 155      | _        | 72       | _        | 40       | _        | ns     |
| 52       | Chip select hold time                                                                                                             | t <sub>CH</sub>   | 0        | 20       | 0        | 20       | 0        | 20       | ns     |
| 54       | Address valid chip-select delay time $t_{ACSD} = 1/4 t_{cyc} + 40 \text{ ns}$                                                     | t <sub>ACSD</sub> | _        | 165      | _        | 123      | _        | 103      | ns     |
| 55       | Address valid chip-select access time $t_{\text{ACSA}} = t_{\text{cyc}} - t_{\text{f}} - t_{\text{DSR}} - t_{\text{ACSD}} ^{(3)}$ | t <sub>ACSA</sub> | 285      | _        | 162      | _        | 113      | _        | ns     |
| 56       | Address valid to chip-select time                                                                                                 | t <sub>AVCS</sub> | 10       | _        | 10       | _        | 10       | _        | ns     |
| 57       | Address valid to data three-state time                                                                                            | t <sub>AVDZ</sub> | _        | 10       | _        | 10       | _        | 10       | ns     |

<sup>1.</sup>  $V_{DD}$  = 5.0 ± 10%,  $V_{SS}$  = 0 Vdc,  $T_A$  =  $T_L$  to  $T_H$ , unless otherwise noted All timing measurements refer to 20%  $V_{DD}$  and 70%  $V_{DD}$ , unless otherwise noted. 2. Input clocks with duty cycles other than 50% affect bus performance.

<sup>3.</sup> This parameter is affected by clock stretching. Add  $n(t_{cyc})$  to parameter value, where n = 1, 2, or 3 depending on values written to CSCSTR register or n = 1 for STRCH = 1 on KS parts.



Figure 12-9. Expansion Bus Timing

# 12.12 Serial Peripheral Interface Timing

| Num | Characteristic <sup>(1)</sup>                                     | Symbol                                      | Min                                                | Max                                 | Unit             |
|-----|-------------------------------------------------------------------|---------------------------------------------|----------------------------------------------------|-------------------------------------|------------------|
|     | Operating frequency Master Slave                                  | f <sub>op(m)</sub><br>f <sub>op(s)</sub>    | f <sub>o</sub> /128<br>dc                          | f <sub>o</sub> /2<br>f <sub>o</sub> | MHz              |
| 1   | Cycle time<br>Master<br>Slave                                     | t <sub>cyc(m)</sub> t <sub>cyc(s)</sub>     | 2 1                                                | 128<br>—                            | t <sub>cyc</sub> |
| 2   | Enable lead time<br>Slave                                         | t <sub>Lead(s)</sub>                        | 1                                                  | _                                   | t <sub>cyc</sub> |
| 3   | Enable lag time<br>Slave                                          | t <sub>Lag(s)</sub>                         | 1                                                  | _                                   | t <sub>cyc</sub> |
| 4   | Clock (SCK) high time<br>Master<br>Slave                          | t <sub>w(SCKH)m</sub> t <sub>w(SCKH)s</sub> | t <sub>cyc</sub> – 25<br>1/2 t <sub>cyc</sub> – 25 | 64 t <sub>cyc</sub>                 | ns               |
| 5   | Clock (SCK) low time<br>Master<br>Slave                           | $t_{w(SCKL)m}$ $t_{w(SCKL)s}$               | t <sub>cyc</sub> – 25<br>1/2 t <sub>cyc</sub> – 25 | 64 t <sub>cyc</sub>                 | ns               |
| 6   | Data setup time (inputs) Master Slave                             | t <sub>su(m)</sub> t <sub>su(s)</sub>       | 30<br>30                                           |                                     | ns               |
| 7   | Data hold time (inputs) Master Slave                              | t <sub>h(m)</sub> t <sub>h(s)</sub>         | 30<br>30                                           | _<br>_                              | ns               |
| 8   | Slave access time (time to data active from high-impedance state) | t <sub>a</sub>                              | 0                                                  | 40                                  | ns               |
| 9   | Slave disable time (hold time to high-impedance state)            | t <sub>dis</sub>                            | _                                                  | 50                                  | ns               |
| 10  | Data valid (after enable edge) <sup>(2)</sup>                     | t <sub>v(s)</sub>                           | _                                                  | 50                                  | ns               |
| 11  | Data hold time (outputs) (after enable edge)                      | t <sub>ho</sub>                             | 0                                                  | _                                   | ns               |

<sup>1.</sup>  $V_{DD}$  = 4.5 to 5.5 Vdc,  $V_{SS}$  = 0 Vdc,  $T_A$  =  $T_L$  to  $T_H$ . All timing measurements refer to 20%  $V_{DD}$  and 70%  $V_{DD}$ , unless otherwise noted.

<sup>2.</sup> Capacitive load on all SPI pins is 200 pF.



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

### a) SPI Master Timing (CPHA = 0)



Note: This last clock edge is generated internally but is not seen at the SCK pin.

## b) SPI Master Timing (CPHA = 1)

Figure 12-10. SPI Timing Diagram (Sheet 1 of 2)



Note: Not defined, but normally MSB of character just received

### a) SPI Slave Timing (CPHA = 0)



Note: Not defined, but normally LSB of character previously transmitted

## b) SPI Slave Timing (CPHA = 1)

Figure 12-10. SPI Timing Diagram (Sheet 2 of 2)

## **Electrical Characteristics**

### 12.13 EEPROM Characteristics

| Characteristic <sup>(1)</sup>                                                                                         | Т              | emperature Ran           | ge                       | Unit   |
|-----------------------------------------------------------------------------------------------------------------------|----------------|--------------------------|--------------------------|--------|
| Characteristic                                                                                                        | -40 to 85°C    | -40 to 105°C             | -40 to 125°C             | Ullit  |
| Programming time <1.0 MHz, RCO enabled <sup>(2)</sup> 1.0 to 2.0 MHz, RCO disabled ≥ 2.0 MHz (or anytime RCO enabled) | 10<br>20<br>10 | 15<br>Must use RCO<br>15 | 20<br>Must use RCO<br>20 | ms     |
| Erase time <sup>(2)</sup> Byte, row, and bulk                                                                         | 10             | 10                       | 10                       | ms     |
| Write/erase endurance <sup>(3)</sup>                                                                                  | 10,000         | 10,000                   | 10,000                   | Cycles |
| Data retention <sup>(3)</sup>                                                                                         | 10             | 10                       | 10                       | Years  |

<sup>1.</sup>  $V_{DD}$  = 5.0 Vdc  $\pm 10\%$ ,  $V_{SS}$  = 0 Vdc,  $T_A$  =  $T_L$  to  $T_H$  2. 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.

<sup>3.</sup> Refer to Reliability Monitor Report (current quarterly issue) for current failure rate information.

## **Section 13. Mechanical Data**

### 13.1 Contents

| 13.2 | Introduction                                  | .273 |
|------|-----------------------------------------------|------|
| 13.3 | 84-Pin Plastic-Leaded Chip Carrier (Case 780) | 275  |
| 13.4 | 84-Pin J-Cerquad (Case 780A)                  | .276 |
| 13.5 | 80-Pin Quad Flat Pack (Case 841B)             | .277 |
| 13.6 | 80-Pin Low-Profile Quad Flat Pack (Case 917A) | .278 |
| 13.7 | 68-Pin Plastic Leaded Chip Carrier (Case 779) | .279 |
| 13.8 | 68-Pin J-Cerquad (Case 779A)                  | .280 |

### 13.2 Introduction

The M68HC11K series microcontrollers are available in:

- 84-pin plastic-leaded chip carrier (PLCC)
- 84-pin J-cerquad (ceramic windowed version of PLCC)
- 80-pin quad flat pack (QFP)
- 80-pin low-profile quad flat pack (LQFP)
- 68-pin PLCC
- 68-pin J-cerquad

## **Mechanical Data**

The diagrams included in this section show the latest package specifications available at the time of this publication. To make sure that you have the latest information, contact one of the following:

- Local Motorola Sales Office
- World Wide Web at http://www.motorola.com/semiconductors

Follow the World Wide Web on-line instructions to retrieve the current mechanical specifications.

## 13.3 84-Pin Plastic-Leaded Chip Carrier (Case 780)





#### VIEW D-D

- NOTES:
  1. DATUMS L, M, AND N DETERMINED WHERE TOP OF LEAD SHOULDER EXITS PACKAGE BODY AT MOLD PARTING LINE.
- DIMENSION G1 TO BE MEASURED AT CLOSEST APPROACH OF LEAD TO DATUM T, SEATING PLANE.
- DIMENSIONS R AND U DO NOT INCLUDE MOLD FLASH. ALLOWABLE MOLD FLASH IS 0.010 (0.25) PER SIDE.
- DIMENSIONING AND TOLERANCING PER ANSI Y14.5M, 1982.
- CONTROLLING DIMENSION: INCH.
- 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 OF THE PLASTIC BODY.
- 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.94). THE DAMBAR INTRUSION(S) SHALL NOT CAUSE THE H DIMENSION TO BE SMALLER THAN 0.025 (0.635).





|     | INC   | HES   | MILLIN | IETERS |
|-----|-------|-------|--------|--------|
| DIM | MIN   | MAX   | MIN    | MAX    |
| Α   | 1.185 | 1.195 | 30.10  | 30.35  |
| В   | 1.185 | 1.195 | 30.10  | 30.35  |
| C   | 0.165 | 0.180 | 4.20   | 4.57   |
| Е   | 0.090 | 0.120 | 2.29   | 3.05   |
| F   | 0.013 | 0.021 | 0.33   | 0.53   |
| G   | 0.050 | BSC   | 1.27   | BSC    |
| Н   | 0.026 | 0.032 | 0.66   | 0.81   |
| J   | 0.020 |       | 0.51   |        |
| K   | 0.025 |       | 0.64   |        |
| R   | 1.150 | 1.156 | 29.21  | 29.36  |
| כ   | 1.150 | 1.156 | 29.21  | 29.36  |
| ٧   | 0.042 | 0.048 | 1.07   | 1.21   |
| W   | 0.042 | 0.048 | 1.07   | 1.21   |
| Х   | 0.042 | 0.056 | 1.07   | 1.42   |
| Υ   | -     | 0.020 | -      | 0.50   |
| Z   | 2°    | 10°   | 2°     | 10°    |
| G1  | 0.545 | 0.565 | 13.84  | 14.35  |
| K1  | 0.060 |       | 1.52   |        |
| R1  | 0.025 | 0.045 | 0.64   | 1.14   |

## 13.4 84-Pin J-Cerquad (Case 780A)





## 

⊕ 0.25 (0.010) T LS-MS NS-PS

#### **DETAIL D-D**

#### NOTES:

- DATUMS -L-, -M-, -N-, AND -P- DETERMINED WHERE TOP
   OF LEAD SHOULDER EXITS PACKAGE BODY AT GLASS
   PARTING LINE.
- 2. DIMENSION G1, TRUE POSITION TO BE MEASURED AT DATUM -T-, SEATING PLANE.
- DIMENSIONS R AND U DO NOT INCLUDE GLASS PROTRUSION. ALLOWABLE GLASS PROTRUSION IS 0.25 (0.010) PER SIDE.
- DIMENSIONING AND TOLERANCING PER ANSI Y14.5M, 1982.
- 5. CONTROLLING DIMENSION: INCH.

|              |          | 51 Ja 11          | <del>0</del> | 0.18 | (0.00 | )7M)          | Т | L®-I | ИS           | N®- | P ® |
|--------------|----------|-------------------|--------------|------|-------|---------------|---|------|--------------|-----|-----|
|              |          | →   ← H           | $\oplus$     | 0.18 | (0.00 | )7 <u>(</u> M | Т | N®-I | <b>-</b> (§) | L®- | M®  |
| <u> </u>     |          |                   |              |      |       |               |   |      |              |     |     |
| <del> </del> | <u> </u> |                   |              |      |       |               |   |      |              |     |     |
| K1⊸<br>K     | <u></u>  | U<br>   _         |              | 0.18 |       |               |   | L®-I |              | N®- |     |
|              |          | →  <del> </del> F | $\Phi$       | 0.18 | (0.00 | )7 <u>M</u>   | Т | N®-I | PS           | L®- | MS  |
|              |          | DETAIL S          |              |      |       |               |   |      |              |     |     |

|            | INC   | HES   | MILLIN | IETERS |
|------------|-------|-------|--------|--------|
| DIM        | MIN   | MAX   | MIN    | MAX    |
| Α          | 1.185 | 1.195 | 30.10  | 30.35  |
| В          | 1.185 | 1.195 | 30.10  | 30.35  |
| O          | 0.165 | 0.180 | 4.20   | 4.57   |
| Е          | 0.090 | 0.110 | 2.29   | 2.79   |
| F          | 0.013 | 0.021 | 0.33   | 0.53   |
| G          | 0.050 | BSC   | 1.27   | BSC    |
| H          | 0.026 | 0.032 | 0.66   | 0.81   |
| ۲          | 0.020 | -     | 0.51   | -      |
| Κ          | 0.025 |       | 0.64   |        |
| R          | 1.150 | 1.156 | 29.21  | 29.36  |
| U          | 1.150 | 1.156 | 29.21  | 29.36  |
| ٧          | 0.042 | 0.048 | 1.07   | 1.21   |
| W          | 0.042 | 0.048 | 1.07   | 1.21   |
| Χ          | 0.042 | 0.056 | 1.07   | 1.42   |
| Υ          |       | 0.020 |        | 0.50   |
| Z          | 2°    | 10°   | 2 °    | 10°    |
| G1         | 1.110 | 1.130 | 28.20  | 28.70  |
| K1         | 0.040 |       | 1.02   |        |
| <b>Z</b> 1 | 2°    | 10°   | 2°     | 10°    |
|            |       |       |        |        |

Technical Data M68HC11K Family

**DETAIL S** 

### 13.5 80-Pin Quad Flat Pack (Case 841B)





#### NOTES:

- 1. DIMENSIONING AND TOLERANCING PER ANSI Y14.5M, 1982.
- 2. CONTROLLING DIMENSION: MILLIMETER.
- 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.
- DATUMS -A-, -B- AND -D- TO BE DETERMINED AT DATUM PLANE -H-.
- . DIMENSIONS S AND V TO BE DETERMINED AT SEATING PLANE -C-.
- DIMENSIONS A AND B DO NOT INCLUDE MOLD
   PROTRUSION. ALLOWABLE PROTRUSION IS 0.25
   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 TOTAL IN EXCESS OF THE D DIMENSION AT MAXIMUM MATERIAL CONDITION. DAMBAR CANNOT BE LOCATED ON THE LOWER RADIUS OR THE FOOT.

|        | MILLIN | IETERS |
|--------|--------|--------|
| MIC    | MIN    | MAX    |
| Α      | 13.90  | 14.10  |
| В      | 13.90  | 14.10  |
| С      | 2.15   | 2.45   |
| D      | 0.22   | 0.38   |
| Е      | 2.00   | 2.40   |
| F      | 0.22   | 0.33   |
| G      | 0.65   | BSC    |
| Н      | -      | 0.25   |
| J      | 0.13   | 0.23   |
| K      | 0.65   | 0.95   |
| L      | 12.35  | REF    |
| М      | 5°     | 10°    |
| N      | 0.13   | 0.17   |
| Р      | 0.325  | BSC    |
| Q      | 0 °    | 7°     |
| R      | 0.13   | 0.30   |
| S      | 16.95  | 17.45  |
| T<br>U | 0.13   | -      |
|        | 0 °    |        |
| ٧      | 16.95  | 17.45  |
| W      | 0.35   | 0.45   |
| Χ      | 1.6    | REF    |
|        |        |        |

## 13.6 80-Pin Low-Profile Quad Flat Pack (Case 917A)











SECTION AB-AB ROTATED 90° CLOCKWISE

#### NOTES:

- . DIMENSIONING AND TOLERANCING PER ANSI Y14.5M, 1982.
- 2. CONTROLLING DIMENSION: MILLIMETER.
- 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 -L-, -M- AND -N- TO BE DETERMINED AT DATUM PLANE -H-.
- 5. DIMENSIONS SAND V TO BE DETERMINED AT SEATING PLANE -T-.
- 6. DIMENSIONS A AND B DO NOT INCLUDE MOLD PROTRUSION. ALLOWABLE PROTRUSION IS 0.250 (0.010) PER SIDE. DIMENSIONS A AND B DO INCLUDE MOLD MISMATCH AND ARE DETERMINED AT DATUM PLANE -H-.
- DIMENSION D DOES NOT INCLUDE DAMBAR PROTRUSION. DAMBAR PROTRUSION SHALL NOT CAUSE THE LEAD WIDTH TO EXCEED 0.460 (0.018). MINIMUM SPACE BETWEEN PROTRUSION AND ADJACENT LEAD OR PROTRUSION 0.07 (0.003).

|     | MILLIN | IETERS | INC   | HES   |
|-----|--------|--------|-------|-------|
| DIM | MIN    | MAX    | MIN   | MAX   |
| Α   | 14.00  | BSC    | 0.551 | BSC   |
| A1  | 7.00   | BSC    | 0.276 | BSC   |
| В   | 14.00  | BSC    | 0.551 | BSC   |
| B1  | 7.00   | BSC    | 0.276 | BSC   |
| С   | -      | 1.60   | -     | 0.063 |
| C1  | 0.04   | 0.24   | 0.002 | 0.009 |
| C2  | 1.30   | 1.50   | 0.051 | 0.059 |
| D   | 0.22   | 0.38   | 0.009 | 0.015 |
| Е   | 0.40   | 0.75   | 0.016 | 0.030 |
| F   | 0.17   | 0.33   | 0.007 | 0.013 |
| G   | 0.65   | BSC    | 0.026 | BSC   |
| J   | 0.09   | 0.27   | 0.004 | 0.011 |
| K   | 0.50   | REF    | 0.020 | REF   |
| Р   | 0.325  | BSC    | 0.013 | REF   |
| R1  | 0.10   | 0.20   | 0.004 | 0.008 |
| S   | 16.00  | BSC    | 0.630 | BSC   |
| S1  | 8.00   | BSC    | 0.315 | BSC   |
| U   | 0.09   | 0.16   | 0.004 | 0.006 |
| ٧   | 16.00  | BSC    | 0.630 | ) BSC |
| V1  | 8.00   | BSC    | 0.315 | BSC   |
| W   | 0.20   | REF    | 0.008 | REF   |
| Z   | 1.00   | REF    |       | REF   |
| 0   | 0 °    | 10°    | 0 °   | 10°   |
| 01  | 0 °    |        | 0 °   |       |
| 02  | 9°     | 14°    | 9°    | 14°   |

### 13.7 68-Pin Plastic Leaded Chip Carrier (Case 779)









|     | INC   | HES   |
|-----|-------|-------|
| DIM | MIN   | MAX   |
| Α   | 0.985 | 0.995 |
| В   | 0.985 | 0.995 |
| С   | 0.165 | 0.180 |
| E   | 0.090 | 0.110 |
| F   | 0.013 | 0.019 |
| G   | 0.050 | BSC   |
| Н   | 0.026 | 0.032 |
| J   | 0.020 |       |
| K   | 0.025 |       |
| R   | 0.950 | 0.956 |
| U   | 0.950 | 0.956 |
| V   | 0.042 | 0.048 |
| W   | 0.042 | 0.048 |
| Х   | 0.042 | 0.056 |
| Υ   |       | 0.020 |
| Ζ   | 2 °   | 10°   |
| G1  | 0.910 | 0.930 |
| K1  | 0.040 |       |

#### NOTES:

- DATUMS L, M, AND N DETERMINED WHERE TOP
  OF LEAD SHOULDER EXITS PLASTIC BODY AT
  MOLD PARTING LINE.
- 2. DIMENSION G1, TRUE POSITION TO BE MEASURED AT DATUM T, SEATING PLANE.
- DIMENSIONS R AND U DO NOT INCLUDE MOLD FLASH. ALLOWABLE MOLD FLASH IS 0.010 PER SIDE.
- 4. DIMENSIONING AND TOLERANCING PER ANSI Y14.5M, 1982.
- 5. CONTROLLING DIMENSION: INCH.
- 6. THE PACKAGE TOP MAY BE SMALLER THAN THE PACKAGE BOTTOM BY UP TO 0.012.

  DIMENSIONS R AND UARE 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 OF THE PLASTIC BODY.
- 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. THE DAMBAR INTRUSION(S) SHALL NOT CAUSE THE H DIMENSION TO BE SMALLER THAN 0.025.

## 13.8 68-Pin J-Cerquad (Case 779A)









- 1. DATUMS -L-, -M-, -N-, AND -P- DETERMINED WHERE TOP OF LEAD SHOULDER EXITS PLASTIC BODY AT MOLD PARTING LINE.
- 2. DIMENSION G1, TRUE POSITION TO BE MEASURED AT DATUM -T-, SEATING
- DIMENSIONS R AND U DO NOT INCLUDE MOLD FLASH. ALLOWABLE MOLD FLASH IS 0.25 (0.010) PER SIDE.
- DIMENSIONING AND TOLERANCING PER ANSI Y14.5M, 1982. CONTROLLING DIMENSION: INCH.

| یا دا اد | фþ.             | .18 ( | 0.007€ | ) T | L   | ®-N   | 1 (S) | N    | Ŝ-P   | · (S) |
|----------|-----------------|-------|--------|-----|-----|-------|-------|------|-------|-------|
| — H      | <del>ф</del> 0. | .18 ( | 0.007€ | ) T | N   | ®-P   | · (S) | L (  | S)-N  | 1 (§  |
| * K      |                 |       |        |     |     |       |       |      |       |       |
| <b>₹</b> | <b>⊕</b> þ.1    | 8 (0. | .007∭  | Т   | L ( | ⑤-M ( | S ∣   | N (S | }-P ⟨ | S     |
|          | <b>⊕</b> 0.1    | 8 (0. | .007(0 | Т   | N ( | ®-P   | S     | L®   | )-M   | S     |
| DETAIL S |                 |       |        |     |     |       |       |      |       |       |

|     | INC   | HES   | MILLIM | ETERS |
|-----|-------|-------|--------|-------|
| DIM | MIN   | MAX   | MIN    | MAX   |
| Α   | 0.985 | 0.995 | 25.02  | 25.27 |
| В   | 0.985 | 0.995 | 25.02  | 25.27 |
| С   | 0.155 | 0.200 | 3.94   | 5.08  |
| Е   | 0.090 | 0.120 | 2.29   | 3.05  |
| F   | 0.017 | 0.021 | 0.43   | 0.48  |
| G   | 0.050 | BSC   | 1.27   | BSC   |
| Н   | 0.026 | 0.032 | 0.66   | 0.81  |
| J   | 0.020 | -     | 0.51   | -     |
| K   | 0.050 | REF   | 1.27   | REF   |
| L   | 0.003 | -     | 0.08   | -     |
| R   | 0.930 | 0.958 | 23.62  | 24.33 |
| U   | 0.930 | 0.958 | 23.62  | 24.33 |
| ٧   | 0.036 | 0.044 | 0.91   | 1.12  |
| W   | 0.036 | 0.044 | 0.91   | 1.12  |
| G1  | 0.890 | 0.930 | 22.61  | 23.62 |

# **Section 14. Ordering Information**

Use Table 14-1 to determine part numbers when placing an order.

Table 14-1. M68HC11K Family Devices

| Device<br>Number                                | ROM<br>or EPROM | RAM               | EEPROM          | I/O            | Chip<br>Select    | Slow<br>Mode   | Packages                                                     |
|-------------------------------------------------|-----------------|-------------------|-----------------|----------------|-------------------|----------------|--------------------------------------------------------------|
| MC68HC(L)11K0<br>MC68HC(L)11K1<br>MC68HC(L)11K4 | 0<br>0<br>24 K  | 768<br>768<br>768 | 0<br>640<br>640 | 37<br>37<br>62 | Yes<br>Yes<br>Yes | No<br>No<br>No | 84-pin PLCC <sup>(1)</sup><br>80-pin QFP <sup>(2)</sup>      |
| MC68HC711K4                                     | 24 K            | 768               | 640             | 62             | Yes               | No             | 84-pin J-cerquad <sup>(3)</sup><br>84-pin PLCC<br>80-pin QFP |
| MC68HC11KS2                                     | 32 K            | 1 K               | 640             | 51             | No                | Yes            | 68-pin PLCC<br>80-pin LQFP <sup>(4)</sup>                    |
| MC68HC711KS2                                    | 32 K            | 1 K               | 640             | 51             | No                | Yes            | 68-pin PLCC<br>80-pin LQFP<br>68-pin J-cerquad               |

<sup>1.</sup> PLCC = Plastic leaded chip carrier

<sup>2.</sup> QFP = Quad flat pack

<sup>3.</sup> J-cerquad = Ceramic windowed version of PLCC

<sup>4.</sup> LQFP = Low-profile quad flat pack

# Ordering Information

# **Section 15. Development Support**

Motorola has developed tools for use in debugging and evaluating M68HC11 equipment. Specific development tools for use with the M68HC11K series include:

- M68HC11KEVS evaluation system
- M68HC711KPGMR programmer board
- M68HC711KEVB evaluation board

For more information about Motorola and third party development system hardware and software, contact one of the following:

- Local Motorola Sales Office
- World Wide Web at http://www.motorola.com/semiconductors

# **Development Support**

M68HC11K Family

# Index

| BAUD Baud Rate SCP[1:0] SCI Baud Rate Prescaler Selects                                                                                                                                                                                                                        |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| C CFORC Timer Compare Force FOC[1:5] Force Output Comparison                                                                                                                                                                                                                   |
| FOC[1:5] Force Output Comparison 201  CONFIG System Configuration  NOCOP ROM/PROM Enable 108  ROMON ROM/PROM Enable 88, 89  H  HPRIO Highest Priority I-Bit Interrupt and Miscellaneous  MDA Mode Select A 81  PSEL[3:0] Priority Select Bits 123  RBOOT Read Bootstrap ROM 80 |
| FOC[1:5] Force Output Comparison 201  CONFIG System Configuration  NOCOP ROM/PROM Enable 108  ROMON ROM/PROM Enable 88, 89  H  HPRIO Highest Priority I-Bit Interrupt and Miscellaneous  MDA Mode Select A 81  PSEL[3:0] Priority Select Bits 123  RBOOT Read Bootstrap ROM 80 |
| CONFIG System Configuration  NOCOP ROM/PROM Enable                                                                                                                                                                                                                             |
| NOCOP ROM/PROM Enable                                                                                                                                                                                                                                                          |
| H HPRIO Highest Priority I-Bit Interrupt and Miscellaneous MDA Mode Select A                                                                                                                                                                                                   |
| H HPRIO Highest Priority I-Bit Interrupt and Miscellaneous MDA Mode Select A                                                                                                                                                                                                   |
| HPRIO Highest Priority I-Bit Interrupt and MiscellaneousMDA Mode Select A81PSEL[3:0] Priority Select Bits123RBOOT Read Bootstrap ROM80                                                                                                                                         |
| MDA Mode Select A81PSEL[3:0] Priority Select Bits123RBOOT Read Bootstrap ROM80                                                                                                                                                                                                 |
| PSEL[3:0] Priority Select Bits                                                                                                                                                                                                                                                 |
| RBOOT Read Bootstrap ROM 80                                                                                                                                                                                                                                                    |
| ·                                                                                                                                                                                                                                                                              |
| SMOD Special Mode Select                                                                                                                                                                                                                                                       |
|                                                                                                                                                                                                                                                                                |
|                                                                                                                                                                                                                                                                                |
| l                                                                                                                                                                                                                                                                              |
| INIT RAM and I/O Mapping Register                                                                                                                                                                                                                                              |
| RAM[3:0] RAM Map Position84                                                                                                                                                                                                                                                    |
| REG[3:0] Register Block Position                                                                                                                                                                                                                                               |
| •                                                                                                                                                                                                                                                                              |
| L IDDV/ LID Drivers                                                                                                                                                                                                                                                            |
| LIRDV LIR Driven                                                                                                                                                                                                                                                               |
| 0                                                                                                                                                                                                                                                                              |
| OC1D Output Compare 1 Data                                                                                                                                                                                                                                                     |
| OC1D[7:3] Output Compare Masks203                                                                                                                                                                                                                                              |
| OC1M Output Compare 1 Mask                                                                                                                                                                                                                                                     |
| OC1M[7:3] Output Compare 1 Masks                                                                                                                                                                                                                                               |
| Technical Data                                                                                                                                                                                                                                                                 |

| OPTION System Configuration Options             |      |
|-------------------------------------------------|------|
| CME Clock Monitor Enable                        | 111  |
| CR[1:0] COP Timer Rate Select Bits              | 109  |
| DLY Enable Oscillator Startup Delay             | 132  |
| IRQE Configure IRQ for Edge-Sensitive Operation | 121  |
|                                                 |      |
| Р                                               |      |
| PACTL Pulse Accumulator Control                 |      |
| I4/O5 Input Capture 4/Output Compare 5          | 191  |
| PAEN Pulse Accumulator System Enable            |      |
| PAMOD Pulse Accumulator Mode                    |      |
| RTR[1:0] Real Time Interrupt Rate Select        |      |
| PPROG EPROM Programming Control                 |      |
| ELAT PROM Latch Control                         | . 93 |
|                                                 |      |
| S                                               |      |
| SCCR1 SCI Control Register 1                    |      |
| M Mode (SCI Word Size)                          | 160  |
| WAKE Wakeup mode                                | .160 |
| SCCR2 SCI Control Register 2                    |      |
| ILIE Idle Line Interrupt Enable                 | 161  |
| RE Receiver Enable                              | 162  |
| RIE Receiver Interrupt Enable                   | 161  |
| RWU Receiver Wakeup Control                     | 162  |
| TCIE Transmit Complete Interrupt Enable         | 161  |
| TE Transmitter Enable                           | 162  |
| TIE Transmit Interrupt Enable                   | 161  |
| SCI Control Register 2                          |      |
| SBK Send Break                                  | 162  |
| SCSR SCI Status Register                        |      |
| FE Framing Error Flag                           | 164  |
| IDLE Idle Line Detected Flag                    | 163  |
| NF Noise Error Flag                             | 163  |
| OR Overrun Error Flag                           | 163  |
| RDRF Receive Data Register Full Flag            | 163  |
| TC Transmit Complete Flag                       | 163  |
| TDRE Transmit Data Register Empty Flag          | 163  |
|                                                 |      |

| SPCR Serial Peripheral Control Register                              |     |
|----------------------------------------------------------------------|-----|
| CPHA Clock Phase                                                     | 175 |
| CPOL Clock Polarity                                                  | 175 |
| DWOM Port D Wired-OR Mode                                            | 174 |
| MSTR Master Mode Select                                              | 174 |
| SPE Serial Peripheral System Enable                                  | 174 |
| SPR[1:0] SPI Clock Rate Selects                                      | 175 |
| SPSR Serial Peripheral Status Register                               |     |
| MODF Mode Fault                                                      | 176 |
| SPIF SPI Transfer Complete Flag                                      | 176 |
| WCOL Write Collision                                                 | 176 |
|                                                                      |     |
| T                                                                    |     |
| TCTL1 Timer Control 1                                                | 000 |
| OM[2:5] Output Mode                                                  | 200 |
| TCTL2 Timer Control 2                                                | 405 |
| EDGxB and EDGxA Input Capture Edge Control                           | 195 |
| TFLG1 Timer Interrupt Flag 1                                         | 400 |
| I4/O5F Input Capture 4/Output Compare 5 Flag 194,                    |     |
| 1 1                                                                  | 194 |
| 1 1                                                                  | 199 |
| TFLG2 Timer Interrupt Flag 2  PAIF Pulse Accumulator Input Edge Flag | 207 |
| 1 3 3                                                                |     |
| PAOVF Pulse Accumulator Overflow Flag                                |     |
| RTIF Real-Time Interrupt Flag                                        | 189 |
| TMSK1 Timer Interrupt Mask 1                                         | 109 |
| I4/O5I Input Capture 4                                               |     |
| or Output Compare 5 Interrupt Enable 195,                            | 200 |
|                                                                      | 194 |
|                                                                      | 200 |
| TMSK2 Timer Interrupt Mask 2                                         | 200 |
| •                                                                    | 190 |
| · ·                                                                  | 209 |
| ·                                                                    | 189 |

# Index

### How to Reach Us:

#### **USA/EUROPE/LOCATIONS NOT LISTED:**

Motorola Literature Distribution P.O. Box 5405 Denver, Colorado 80217 1-303-675-2140 1-800-441-2447

#### **TECHNICAL INFORMATION CENTER:**

1-800-521-6274

#### JAPAN:

Motorola Japan Ltd. SPS, Technical Information Center 3-20-1, Minami-Azabu, Minato-ku Tokyo 106-8573 Japan 81-3-3440-3569

#### ASIA/PACIFIC:

Motorola Semiconductors H.K. Ltd. Silicon Harbour Centre 2 Dai King Street Tai Po Industrial Estate Tai Po, N.T., Hong Kong 852-26668334

### HOME PAGE:

http://www.motorola.com/semiconductors/

