MC68HC08QA24/D



# MC68HC08QA24 HCMOS Microcontroller Unit

**TECHNICAL DATA** 



Motorola reserves the right to make changes without further notice to any products herein to improve reliability, function or design. Motorola does not assume any liability arising out of the application or use of any product or circuit described herein; neither does it 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., 2000

Technical Data

# **List of Sections**

| Section 1. General Description                            |
|-----------------------------------------------------------|
| Section 2. Memory Map                                     |
| Section 3. Random-Access Memory (RAM)63                   |
| Section 4. Read-Only Memory (ROM)65                       |
| Section 5. Mask Options67                                 |
| Section 6. Electrically Erasable Programmable             |
| Read-Only Memory (EEPROM)                                 |
| Section 7. Central Processor Unit (CPU)81                 |
| Section 8. Error Detection Central Processor Unit (EDC)97 |
| Section 9. Clock Generator Module (CGM)                   |
| Section 10. System Integration Module (SIM)129            |
| Section 11. Low-Voltage Inhibit (LVI)151                  |
| Section 12. Break Module (Break)157                       |
| Section 13. Monitor ROM (MON)163                          |
| Section 14. Computer Operating Properly (COP)173          |
| Section 15. External Interrupt (IRQ)179                   |
| Section 16. Input/Output (I/O) Ports                      |
| Section 17. Serial Communications Interface (SCI)         |
| Section 18. Serial Peripheral Interface (SPI)241          |
| Section 19. Analog-to-Digital Converter (ADC)273          |
| Section 20. Timer Interface A (TIMA)                      |
| Section 21. Timer Interface B (TIMB)                      |
| Section 22. CAN Controller                                |
| Section 23. Electrical Specifications                     |
| Section 24. Mechanical Data                               |

**Technical Data** 

MC68HC08QA24

List of Sections

MOTOROLA

# **Table of Contents**

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

| 1.1    | Contents                                                 |
|--------|----------------------------------------------------------|
| 1.2    | Introduction                                             |
| 1.3    | Features                                                 |
| 1.4    | MCU Block Diagram                                        |
| 1.5    | Pin Assignments                                          |
| 1.5.1  | Power Supply Pins (V <sub>DD</sub> and V <sub>SS</sub> ) |
| 1.5.2  | Oscillator Pins (OSC1 and OSC2)                          |
| 1.5.3  | External Reset Pin (RST)                                 |
| 1.5.4  | External Interrupt Pin (IRQ)                             |
| 1.5.5  | Analog Power Supply Pin (V <sub>DDA</sub> )              |
| 1.5.6  | Analog Ground Pin (V <sub>SSA</sub> /V <sub>REFL</sub> ) |
| 1.5.7  | External Filter Capacitor Pin (CGMXFC)                   |
| 1.5.8  | Port A Input/Output (I/O) Pins (PTA7–PTA0)               |
| 1.5.9  | Port B I/O Pins (PTB7/ATD7–PTB0/ATD0)                    |
| 1.5.10 | Port C I/O Pins (PTC4–PTC0)                              |
| 1.5.11 | Port D I/O Pins (PTD5–PTD0/ATD8)                         |
| 1.5.12 | Port E I/O Pins (PTE7/SPSCK–PTE0/TxD)                    |
| 1.5.13 | Port F I/O Pins (PTF3/TACLK–PTF0/TBCH0)37                |
| 1.5.14 |                                                          |
| 1.5.15 | CAN Receive Pin (CANRx)                                  |

### Section 2. Memory Map

| 2.1 | Contents                      | 41 |
|-----|-------------------------------|----|
| 2.2 |                               | 41 |
| 2.3 | Summary of Internal Registers | 43 |

#### Section 3. Random-Access Memory (RAM)

| 3.1 | Contents               | 53 |
|-----|------------------------|----|
| 3.2 |                        | 63 |
| 3.3 | Functional Description | 33 |

### Section 4. Read-Only Memory (ROM)

| 4.1 | Contents               | 65 |
|-----|------------------------|----|
| 4.2 | Introduction           | 65 |
| 4.3 | Functional Description | 65 |

#### Section 5. Mask Options

| 5.1 | Contents               | .67 |
|-----|------------------------|-----|
| 5.2 |                        | .67 |
| 5.3 | Functional Description | .67 |
| 5.4 | Mask Option Register   | .68 |

### Section 6. Electrically Erasable Programmable Read-Only Memory (EEPROM)

| 6.1     | Contents                                |
|---------|-----------------------------------------|
| 6.2     | Introduction                            |
| 6.3     | Features                                |
| 6.4     | Functional Description                  |
| 6.4.1   | EEPROM Programming72                    |
| 6.4.2   | EEPROM Erasing74                        |
| 6.4.3   | EEPROM Block Protection                 |
| 6.4.4   | EEPROM Redundant Mode                   |
| 6.4.5   | EEPROM Configuration                    |
| 6.4.6   | EEPROM Control Register                 |
| 6.4.7   | EEPROM Non-Volatile Register and EEPROM |
|         | Array Configuration Register            |
| 6.4.8   | Low-Power Modes                         |
| 6.4.8.1 | 1 Wait Mode                             |
| 6.4.8.2 | 2 Stop Mode                             |

**Technical Data** 

# Section 7. Central Processor Unit (CPU)

| 7.1                                              | Contents                                             |
|--------------------------------------------------|------------------------------------------------------|
| 7.2                                              | Introduction                                         |
| 7.3                                              | Features                                             |
| 7.4<br>7.4.1<br>7.4.2<br>7.4.3<br>7.4.4<br>7.4.5 | CPU Registers                                        |
| 7.5                                              | Arithmetic/Logic Unit (ALU)                          |
| 7.6                                              | CPU During Break Interrupts                          |
| 7.7                                              | Instruction Set Summary                              |
| 7.8                                              | Opcode Map                                           |
| Sect                                             | tion 8. Error Detection Central Processor Unit (EDC) |
| 8.1                                              | Contents                                             |
| 8.2                                              | Introduction                                         |
| 8.3                                              | Features                                             |
| 8.4                                              | Functional Description                               |
| 8.5                                              | FLT Pin                                              |
| 8.6                                              | EDC Control Register                                 |

# Section 9. Clock Generator Module (CGM)

| 9.1 Contents                                        |
|-----------------------------------------------------|
| 9.2 Introduction                                    |
| 9.3 Features                                        |
| 9.4 Functional Description                          |
| 9.4.1 Crystal Oscillator Circuit                    |
| 9.4.2 Phase-Locked Loop Circuit (PLL)               |
| 9.4.2.1 Circuits                                    |
| 9.4.2.2 Acquisition and Tracking Modes              |
| 9.4.2.3 Manual and Automatic PLL Bandwidth Modes109 |
| 9.4.2.4 Programming the PLL                         |
| 9.4.2.5 Special Programming Exceptions              |
| 9.4.3 Base Clock Selector Circuit                   |
| 9.4.4 CGM External Connections                      |
| 9.5 I/O Signals                                     |
| 9.5.1 Crystal Amplifier Input Pin (OSC1)            |
| 9.5.2 Crystal Amplifier Output Pin (OSC2)115        |
| 9.5.3 External Filter Capacitor Pin (CGMXFC)115     |
| 9.5.4 Analog Power Pin (V <sub>DDA</sub> )          |
| 9.5.5 Oscillator Enable Signal (SIMOSCEN)           |
| 9.5.6 Crystal Output Frequency Signal (CGMXCLK)     |
| 9.5.7 CGM Base Clock Output (CGMOUT)                |
| 9.5.8 CGM CPU Interrupt (CGMINT)116                 |
| 9.6 CGM Registers                                   |
| 9.6.1 PLL Control Register                          |
| 9.6.2 PLL Bandwidth Control Register                |
| 9.6.3 PLL Programming Register                      |
| 9.7 Interrupts                                      |
| 9.8 Special Modes                                   |
| 9.8.1 Wait Mode                                     |
| 9.8.2 Stop Mode                                     |
| 9.9 CGM During Break Interrupts                     |
| 9.10 Acquisition/Lock Time Specifications           |
| 9.10.1 Acquisition/Lock Time Definitions            |
| 9.10.2 Parametric Influences on Reaction Time       |
| 9.10.3 Choosing a Filter Capacitor                  |

**Technical Data** 

# Section 10. System Integration Module (SIM)

| 10.1 Con                                                  | tents                                                                                                                                                  |
|-----------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| 10.2 Intro                                                | duction                                                                                                                                                |
| 10.3.1 E<br>10.3.2 C                                      | Bus Clock Control and Generation.133Bus Timing.133Clock Startup from POR or LVI Reset133Clocks in Stop Mode and Wait Mode.134                          |
| 10.4.1 E                                                  | et and System Initialization                                                                                                                           |
| 10.5.1 S<br>10.5.2 S                                      | Counter.139SIM Counter During Power-On Reset.139SIM Counter During Stop Mode Recovery.139SIM Counter and Reset States.139                              |
| 10.6.1 In<br>10.6.1.1<br>10.6.1.2<br>10.6.2 F<br>10.6.3 E | gram Exception Control.140nterrupts.140Hardware Interrupts.142SWI Instruction.143Reset.143Break Interrupts.143Status Flag Protection in Break Mode.144 |
| 10.7.1 V                                                  | -Power Modes                                                                                                                                           |
| 10.8.1 S<br>10.8.2 S                                      | Registers                                                                                                                                              |

# Section 11. Low-Voltage Inhibit (LVI)

| 11.1 Contents                                                                                                            |
|--------------------------------------------------------------------------------------------------------------------------|
| 11.2 Introduction                                                                                                        |
| 11.3 Features                                                                                                            |
| 11.4Functional Description15211.4.1Polled LVI Operation15311.4.2Forced Reset Operation15311.4.3False Reset Protection153 |
| 11.5 LVI Status Register                                                                                                 |
| 11.6 LVI Interrupts154                                                                                                   |
| 11.7 Wait Mode154                                                                                                        |
| 11.8 Stop Mode                                                                                                           |
| Section 12. Break Module (Break)                                                                                         |
|                                                                                                                          |
| 12.1 Contents                                                                                                            |
| 12.1    Contents                                                                                                         |
|                                                                                                                          |
| 12.2 Introduction157                                                                                                     |
| 12.2Introduction                                                                                                         |

### Section 13. Monitor ROM (MON)

### Section 14. Computer Operating Properly (COP)

| 14.1 Contents                                                                                                                                                                                                                                                                                                       |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14.2 Introduction                                                                                                                                                                                                                                                                                                   |
| 14.3 Functional Description                                                                                                                                                                                                                                                                                         |
| 14.4    I/O Signals    176      14.4.1    CGMXCLK.    176      14.4.2    STOP Instruction    176      14.4.3    COPCTL Write    176      14.4.4    Internal Reset Resources    176      14.4.5    Reset Vector Fetch    176      14.4.6    COPD (COP Disable)    176      14.4.7    COPS (COP Short Timeout)    177 |
| 14.5 COP Control Register                                                                                                                                                                                                                                                                                           |
| 14.6 Interrupts                                                                                                                                                                                                                                                                                                     |
| 14.7 Monitor Mode                                                                                                                                                                                                                                                                                                   |
| 14.8      Low-Power Modes      178        14.8.1      Wait Mode      178        14.8.2      Stop Mode      178                                                                                                                                                                                                      |
| 14.9 COP Module During Break Interrupts                                                                                                                                                                                                                                                                             |

MC68HC08QA24

### Section 15. External Interrupt (IRQ)

| 15.1 | Contents                           |
|------|------------------------------------|
| 15.2 | Introduction                       |
| 15.3 | Features                           |
| 15.4 | Functional Description             |
| 15.5 | IRQ Pin                            |
| 15.6 | IRQ Module During Break Interrupts |
| 15.7 | IRQ Status and Control Register    |

### Section 16. Input/Output (I/O) Ports

| 16.1 C                      | ontents    |
|-----------------------------|------------|
| 16.2 In                     | troduction |
| 16.3 Po<br>16.3.1<br>16.3.2 | ort A      |
| 16.4 Po<br>16.4.1<br>16.4.2 | ort B      |
| 16.5 Po<br>16.5.1<br>16.5.2 | ort C      |
| 16.6 Po<br>16.6.1<br>16.6.2 | ort D      |
| 16.7 Po<br>16.7.1<br>16.7.2 | ort E      |
| 16.8 Po<br>16.8.1<br>16.8.2 | ort F      |

**Technical Data** 

# Section 17. Serial Communications Interface (SCI)

| 17.1 Contents                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 17.2 Introduction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
| 17.3 Features                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 17.4Functional Description.20917.4.1Data Format.21217.4.2Transmitter.21217.4.3Character Length.21217.4.4Character Transmission.21217.4.5Break Characters.21417.4.6Idle Characters.21517.4.7Inversion of Transmitted Output.215                                                                                                                                                                                                                                                                                                   |
| 17.4.7 Inversion of Transmitted Output                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 17.4.8    Transmitter Interrupts    .215      17.4.9    Receiver    .216      17.4.10    Character Length.    .216      17.4.10    Character Reception    .216      17.4.11    Character Reception    .216      17.4.12    Data Sampling.    .216      17.4.13    Framing Errors    .216      17.4.14    Receiver Wakeup    .220      17.5    Receiver Interrupts    .220      17.5    Receiver Interrupts    .221      17.5.1    Error Interrupts    .222      17.6    Low-Power Modes    .222      17.6.1    Wait Mode    .223 |
| 17.6.2 Stop Mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 17.7    SCI During Break Module Interrupts.    .223      17.8    I/O Signals    .224      17.8.1    PTE0/TxD (Transmit Data)    .224      17.8.2    PTE1/RxD (Receive Data)    .224                                                                                                                                                                                                                                                                                                                                              |
| 17.9    I/O Registers.    .224      17.9.1    SCI Control Register 1    .225      17.9.2    SCI Control Register 2    .228      17.9.3    SCI Control Register 3    .231      17.9.4    SCI Status Register 1    .233                                                                                                                                                                                                                                                                                                            |

| 17.9.5 SCI Status Register 2                                                                                                                                                                 | :37            |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------|
| 17.9.6 SCI Data Register                                                                                                                                                                     | 38             |
| 17.9.7 SCI Baud Rate Register                                                                                                                                                                | 38             |
| Section 18. Serial Peripheral Interface (SPI)                                                                                                                                                |                |
| 18.1 Contents                                                                                                                                                                                | 41             |
| 18.2 Introduction                                                                                                                                                                            | 42             |
| 18.3 Features                                                                                                                                                                                | 42             |
| 18.4 Pin Name and Register Name Conventions2                                                                                                                                                 | 43             |
| 18.5Functional Description218.5.1Master Mode218.5.2Slave Mode2                                                                                                                               | 46             |
| 18.6Transmission Formats.218.6.1Clock Phase and Polarity Controls.218.6.2Transmission Format When CPHA = 0.218.6.3Transmission Format When CPHA = 1.218.6.4Transmission Initiation Latency.2 | 48<br>49<br>50 |
| 18.7Error Conditions.218.7.1Overflow Error.218.7.2Mode Fault Error.2                                                                                                                         | 254<br>256     |
| 18.8 Interrupts                                                                                                                                                                              | :57            |
| 18.9 Queuing Transmission Data                                                                                                                                                               | :59            |
| 18.10 Resetting the SPI                                                                                                                                                                      | 60             |
| 18.11 Low-Power Modes    .2      18.11.1 Wait Mode    .2      18.11.2 Stop Mode    .2                                                                                                        | 61             |
| 18.12 SPI During Break Interrupts                                                                                                                                                            | 62             |

| 18.13 I/C | D Signals                       |
|-----------|---------------------------------|
| 18.13.1   | MISO (Master In/Slave Out)      |
| 18.13.2   | MOSI (Master Out/Slave In)      |
| 18.13.3   | SPSCK (Serial Clock)            |
| 18.13.4   | SS (Slave Select)               |
| 18.13.5   | V <sub>SS</sub> (Clock Ground)  |
| 18.14 I/C | D Registers                     |
| 18.14.1   | SPI Control Register            |
| 18.14.2   | SPI Status and Control Register |
| 18.14.3   | SPI Data Register               |

# Section 19. Analog-to-Digital Converter (ADC)

| 19.1 Contents                                                                                                              |
|----------------------------------------------------------------------------------------------------------------------------|
| 19.2 Introduction                                                                                                          |
| 19.3 Features                                                                                                              |
| 19.4Functional Description.27419.4.1ADC Port I/O Pins.27419.4.2Voltage Conversion.27619.4.3Conversion Time.276             |
| 19.4.4 Continuous Conversion                                                                                               |
| 19.4.5 Accuracy and Precision                                                                                              |
| 19.5 Interrupts                                                                                                            |
| 19.6      Low-Power Modes      .277        19.6.1      Wait Mode      .277        19.6.2      Stop Mode      .277          |
| 19.7I/O Signals                                                                                                            |
| Voltage Reference Pin (V <sub>REFH</sub> )                                                                                 |
| 19.7.3ADC Voltage In (ADCVIN).278                                                                                          |
| 19.8I/O Registers27919.8.1ADC Status and Control Register.27919.8.2ADC Data Register.28219.8.3ADC Input Clock Register.282 |

MC68HC08QA24

# Section 20. Timer Interface A (TIMA)

| 20.1 Contents                                                                                                                                                                                                                                                                                                                                  |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 20.2 Introduction                                                                                                                                                                                                                                                                                                                              |
| 20.3 Features                                                                                                                                                                                                                                                                                                                                  |
| 20.4Functional Description.28920.4.1TIMA Counter Prescaler.28920.4.2Input Capture28920.4.3Output Compare.29120.4.3.1Unbuffered Output Compare.29120.4.3.2Buffered Output Compare.29220.4.4Pulse Width Modulation (PWM).29220.4.4.1Unbuffered PWM Signal Generation.29320.4.4.2Buffered PWM Signal Generation.29420.4.4.3PWM Initialization.295 |
| 20.5 Interrupts                                                                                                                                                                                                                                                                                                                                |
| 20.6      Low-Power Modes      .297        20.6.1      Wait Mode      .297        20.6.2      Stop Mode      .297                                                                                                                                                                                                                              |
| 20.7 TIMA During Break Interrupts                                                                                                                                                                                                                                                                                                              |
| 20.8      I/O Signals                                                                                                                                                                                                                                                                                                                          |
| 20.9I/O Registers29920.9.1TIMA Status and Control Register29920.9.2TIMA Counter Registers.30220.9.3TIMA Counter Modulo Registers30320.9.4TIMA Channel Status and Control Registers.30420.9.5TIMA Channel Registers308                                                                                                                          |

# Section 21. Timer Interface B (TIMB)

| 21.2    Introduction                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 21.1 Contents                                                                                                                                                                                                                                                                      |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 21.4    Functional Description    .315      21.4.1    TIMB Counter Prescaler    .315      21.4.2    Input Capture.    .315      21.4.3    Output Compare    .317      21.4.3    Unbuffered Output Compare    .317      21.4.3.1    Unbuffered Output Compare    .317      21.4.3.2    Buffered Output Compare    .318      21.4.4    Pulse Width Modulation (PWM)    .318      21.4.4    Pulse Width Modulation (PWM)    .318      21.4.4.1    Unbuffered PWM Signal Generation    .319      21.4.4.2    Buffered PWM Signal Generation    .320      21.4.4.3    PWM Initialization    .321      21.5    Interrupts    .322      21.6    Low-Power Modes    .323      21.6.1    Wait Mode    .323      21.6.2    Stop Mode    .323      21.6.3    IVO Signals    .324      21.8    I/O Signals    .324      21.8.1    TIMB Clock Pin (PTF2/TBCLK)    .324      21.8.2    TIMB Channel I/O Pins (PTF1/TBCH1–PTF0/TBCH0)    .324      21.9.1    TIMB Status and Control Register.        | 21.2 Introduction                                                                                                                                                                                                                                                                  |
| 21.4.1    TIMB Counter Prescaler    .315      21.4.2    Input Capture.    .315      21.4.3    Output Compare    .317      21.4.3.1    Unbuffered Output Compare    .317      21.4.3.2    Buffered Output Compare    .318      21.4.4    Pulse Width Modulation (PWM)    .318      21.4.4    Pulse Width Modulation (PWM)    .318      21.4.4.1    Unbuffered PWM Signal Generation    .320      21.4.4.2    Buffered PWM Signal Generation    .320      21.4.4.3    PWM Initialization.    .321      21.5    Interrupts.    .322      21.6    Low-Power Modes    .323      21.6.1    Wait Mode    .323      21.6.2    Stop Mode    .323      21.6.1    Wait Mode    .323      21.6.2    Stop Mode    .323      21.6.3    JUD Signals    .324      21.8    I/O Signals    .324      21.8.1    TIMB Clock Pin (PTF2/TBCLK).    .324      21.8.2    TIMB Channel I/O Pins (PTF1/TBCH1-PTF0/TBCH0)    .324      21.9.1    TIMB Status and Control Register.    .325 <td>21.3 Features</td> | 21.3 Features                                                                                                                                                                                                                                                                      |
| 21.5    Interrupts.    322      21.6    Low-Power Modes    322      21.6.1    Wait Mode    323      21.6.2    Stop Mode    323      21.7    TIMB During Break Interrupts    323      21.8    I/O Signals    324      21.8.1    TIMB Clock Pin (PTF2/TBCLK)    324      21.8.2    TIMB Channel I/O Pins (PTF1/TBCH1–PTF0/TBCH0)    324      21.9    I/O Registers    325      21.9.1    TIMB Status and Control Register    325      21.9.2    TIMB Counter Registers    328      21.9.3    TIMB Counter Modulo Registers    329      21.9.4    TIMB Channel Status and Control Registers    320                                                                                                                                                                                                                                                                                                                                                                                        | 21.4.1TIMB Counter Prescaler.31521.4.2Input Capture31521.4.3Output Compare.31721.4.3.1Unbuffered Output Compare.31721.4.3.2Buffered Output Compare.31821.4.4Pulse Width Modulation (PWM).31821.4.4.1Unbuffered PWM Signal Generation.31921.4.4.2Buffered PWM Signal Generation.320 |
| 21.6Low-Power Modes32221.6.1Wait Mode32321.6.2Stop Mode32321.7TIMB During Break Interrupts32321.8I/O Signals32421.8.1TIMB Clock Pin (PTF2/TBCLK)32421.8.2TIMB Channel I/O Pins (PTF1/TBCH1–PTF0/TBCH0)32421.9I/O Registers32521.9.1TIMB Status and Control Register32521.9.2TIMB Counter Registers32821.9.3TIMB Counter Modulo Registers32921.9.4TIMB Channel Status and Control Registers32921.9.4TIMB Channel Status and Control Registers329                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                    |
| 21.8I/O Signals.32421.8.1TIMB Clock Pin (PTF2/TBCLK).32421.8.2TIMB Channel I/O Pins (PTF1/TBCH1–PTF0/TBCH0).32421.9I/O Registers.32521.9.1TIMB Status and Control Register.32521.9.2TIMB Counter Registers.32821.9.3TIMB Counter Modulo Registers.32921.9.4TIMB Channel Status and Control Registers.330                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 21.6    Low-Power Modes    .322      21.6.1    Wait Mode    .323      21.6.2    Stop Mode    .323                                                                                                                                                                                  |
| 21.9.1TIMB Status and Control Register32521.9.2TIMB Counter Registers.32821.9.3TIMB Counter Modulo Registers.32921.9.4TIMB Channel Status and Control Registers.330                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | 21.8    I/O Signals                                                                                                                                                                                                                                                                |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 21.9.1TIMB Status and Control Register32521.9.2TIMB Counter Registers.32821.9.3TIMB Counter Modulo Registers.32921.9.4TIMB Channel Status and Control Registers.330                                                                                                                |

### Section 22. CAN Controller

| 22.1 Contents                                                                                                                                                                       |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 22.2 Introduction                                                                                                                                                                   |
| 22.3 Features                                                                                                                                                                       |
| 22.4 External Pins                                                                                                                                                                  |
| 22.5Message Storage.34122.5.1Background.34122.5.2Receive Structures.34222.5.3Transmit Structures.344                                                                                |
| 22.6 Identifier Acceptance Filter                                                                                                                                                   |
| 22.7      Interrupts.                                                                                                                                                               |
| 22.8 Protocol Violation Protection                                                                                                                                                  |
| 22.9Low-Power Modes.35122.9.1MSCAN08 Internal Sleep Mode.35122.9.2CPU Wait Mode.35222.9.3CPU Stop Mode.35322.9.4Programmable Wakeup Function.353                                    |
| 22.10 Timer Link                                                                                                                                                                    |
| 22.11 Clock System                                                                                                                                                                  |
| 22.12 Memory Map                                                                                                                                                                    |
| 22.13 Programmer's Model of Message Storage.35722.13.1 Message Buffer Outline.35822.13.2 Identifier Registers.36022.13.3 Data Length Register.36122.13.4 Data Segment Registers.361 |
| 22.13.4Data Segment Registers                                                                                                                                                       |

18

| 22.14 Pro | grammer's Model of Control Registers              |
|-----------|---------------------------------------------------|
| 22.14.1   | MSCAN08 Module Control Register                   |
| 22.14.2   | MSCAN08 Module Control Register                   |
| 22.14.3   | MSCAN08 Bus Timing Register 0                     |
| 22.14.4   | MSCAN08 Bus Timing Register 1                     |
| 22.14.5   | MSCAN08 Receiver Flag Register                    |
| 22.14.6   | MSCAN08 Receiver Interrupt Enable Register        |
| 22.14.7   | MSCAN08 Transmitter Flag Register                 |
| 22.14.8   | MSCAN08 Transmitter Control Register              |
| 22.14.9   | MSCAN08 Identifier Acceptance Control Register376 |
| 22.14.10  | MSCAN08 Receive Error Counter Register            |
| 22.14.11  | MSCAN08 Transmit Error Counter Register           |
| 22.14.12  | MSCAN08 Identifier Acceptance Registers           |
| 22.14.13  | MSCAN08 Identifier Mask Registers                 |

### Section 23. Electrical Specifications

| 23.1  | Contents                                                      |
|-------|---------------------------------------------------------------|
| 23.2  | Maximum Ratings                                               |
| 23.3  | Functional Operating Range                                    |
| 23.4  | Thermal Characteristics                                       |
| 23.5  | DC Electrical Characteristics                                 |
| 23.6  | Control Timing                                                |
| 23.7  | ADC Characteristics                                           |
| 23.8  | 5.0 Vdc $\pm$ 10% Serial Peripheral Interface (SPI) Timing389 |
| 23.9  | CGM Operating Conditions                                      |
| 23.10 | CGM Component Information                                     |
| 23.11 | CGM Acquisition/Lock Time Information                         |
| 23.12 | Timer Module Characteristics                                  |
| 23.13 | Memory Characteristics                                        |

### Section 24. Mechanical Data

| 24.1 | Contents                                              | 395 |
|------|-------------------------------------------------------|-----|
| 24.2 |                                                       | 395 |
| 24.3 | 52-Pin Plastic Leaded Chip Carrier Package (Case 778) | 396 |

# **List of Figures**

| Figure | Title                                 | Page |
|--------|---------------------------------------|------|
| 1-1    | MCU Block Diagram                     |      |
| 1-2    | 52-Pin PLCC Assignments (Top View)    |      |
| 1-3    | Power Supply Bypassing                |      |
| 2-1    | Memory Map                            |      |
| 2-2    | Control, Status, and Data Registers   |      |
| 5-1    | Mask Option Register (MOR)            |      |
| 6-1    | EEPROM Control Register (EECR)        |      |
| 6-2    | EEPROM Array Control Register (EEACR) |      |
| 6-3    | EEPROM Non-Volatile Register (EENVR)  |      |
| 7-1    | CPU Registers                         |      |
| 7-2    | Accumulator (A)                       |      |
| 7-3    | Index Register (H:X)                  |      |
| 7-4    | Stack Pointer (SP)                    |      |
| 7-5    | Program Counter (PC)                  |      |
| 7-6    | Condition Code Register (CCR)         |      |
| 8-1    | EDC Block Diagram                     |      |
| 8-2    | EDC Control Register (EDCR)           | 100  |
| 9-1    | CGM Block Diagram                     |      |
| 9-2    | CGM I/O Register Summary              |      |
| 9-3    | CGM External Connections              |      |
| 9-4    | CGM I/O Register Summary              |      |
| 9-5    | PLL Control Register (PCTL)           |      |
| 9-6    | PLL Bandwidth Control Register (PBWC) |      |
| 9-7    | PLL Programming Register (PPG)        |      |

| Figure | Title                                      | Page |
|--------|--------------------------------------------|------|
| 10-1   | SIM Block Diagram                          | 131  |
| 10-2   | SIM I/O Register Summary                   | 132  |
| 10-3   | CGM Clock Signals                          | 133  |
| 10-4   | External Reset Timing                      | 135  |
| 10-5   | Internal Reset Timing                      | 136  |
| 10-6   | Sources of Internal Reset                  | 136  |
| 10-7   | POR Recovery                               |      |
| 10-8   | Hardware Interrupt Entry                   |      |
| 10-9   | Interrupt Processing                       |      |
| 10-10  | Hardware Interrupt Recovery                |      |
| 10-11  | Interrupt Recognition Example              |      |
| 10-12  | Wait Mode Entry Timing                     |      |
| 10-13  | Wait Recovery from Interrupt or Break      |      |
| 10-14  | Wait Recovery from Internal Reset          |      |
| 10-15  | Stop Mode Entry Timing                     |      |
| 10-16  | Stop Mode Recovery from Interrupt or Break |      |
| 10-17  | SIM Break Status Register (SBSR)           |      |
| 10-18  | SIM Reset Status Register (SRSR)           |      |
| 10-19  | SIM Break Flag Control Register (SBFCR)    | 150  |
|        |                                            |      |
| 11-1   | LVI Module Block Diagram.                  |      |
| 11-2   | LVI Status Register (LVISR)                | 153  |
| 10.4   |                                            | 450  |
| 12-1   | Break Module Block Diagram.                |      |
| 12-2   | Break I/O Register Summary                 |      |
| 12-3   | Break Status and Control Register (BRKSCR) |      |
| 12-4   | Break Address Register (BRKH)              |      |
| 12-5   | Break Address Register (BRKL)              | 162  |
| 13-1   | Manitar Mada Circuit                       | 105  |
| 13-1   | Monitor Mode Circuit                       |      |
| 13-2   | Monitor Data Format                        |      |
| 13-3   | Sample Monitor Waveforms                   |      |
| 13-4   | Read Transaction Break Transaction         |      |
| 13-5   |                                            | 100  |
| 14-1   | COP Block Diagram                          | 174  |
| 14-2   | COP Control Register (COPCTL).             |      |
|        |                                            |      |
| 15-1   | IRQ Block Diagram                          | 180  |
| 15-2   | IRQ Interrupt Flowchart                    |      |
| 15-3   | IRQ Status and Control Register (ISCR)     |      |
|        |                                            |      |

| Figure | Title                                | Page |
|--------|--------------------------------------|------|
| 16-1   | I/O Port Register Summary            | 186  |
| 16-2   | Port A Data Register (PTA)           | 188  |
| 16-3   | Data Direction Register A (DDRA)     | 188  |
| 16-4   | Port A I/O Circuit                   | 189  |
| 16-5   | Port B Data Register (PTB)           | 190  |
| 16-6   | Data Direction Register B (DDRB)     | 191  |
| 16-7   | Port B I/O Circuit                   | 191  |
| 16-8   | Port C Data Register (PTC)           | 193  |
| 16-9   | Data Direction Register C (DDRC)     | 194  |
| 16-10  | Port C I/O Circuit                   |      |
| 16-11  | Port D Data Register (PTD)           | 196  |
| 16-12  | Data Direction Register D (DDRD)     |      |
| 16-13  | Port D I/O Circuit                   |      |
| 16-14  | Port E Data Register (PTE)           |      |
| 16-15  | Data Direction Register E (DDRE)     |      |
| 16-16  | Port E I/O Circuit                   |      |
| 16-17  | Port F Data Register (PTF)           |      |
| 16-18  | Data Direction Register F (DDRF)     |      |
| 16-19  | Port F I/O Circuit.                  | 205  |
|        |                                      |      |
| 17-1   | SCI Module Block Diagram             |      |
| 17-2   | SCI I/O Register Summary             |      |
| 17-3   | SCI Data Formats.                    |      |
| 17-4   | SCI Transmitter                      |      |
| 17-5   | SCI Receiver Block Diagram           |      |
| 17-6   | Receiver Data Sampling.              |      |
| 17-7   | SCI Control Register 1 (SCC1)        |      |
| 17-8   | SCI Control Register 2 (SCC2)        |      |
| 17-9   | SCI Control Register 3 (SCC3)        |      |
| 17-10  | SCI Status Register 1 (SCS1)         |      |
| 17-11  | Flag Clearing Sequence.              |      |
| 17-12  | SCI Status Register 2 (SCS2)         |      |
| 17-13  | SCI Data Register (SCDR)             |      |
| 17-14  | SCI BAUD Rate Register 1 (SCBR)      | 238  |
| 18-1   | SPI I/O Register Summary             | 244  |
| 18-2   | SPI Module Block Diagram             |      |
| 18-3   | Full-Duplex Master-Slave Connections |      |
| 18-4   | Transmission Format (CPHA = 0)       |      |
| 18-5   | CPHA/SS Timing                       |      |
| 18-6   | Transmission Format (CPHA = 1)       |      |
|        |                                      |      |

MC68HC08QA24

| Figure | Title                                                | Page |
|--------|------------------------------------------------------|------|
| 18-7   | Transmission Start Delay (Master)                    |      |
| 18-8   | Missed Read of Overflow Condition                    |      |
| 18-9   | Clearing SPRF When OVRF Interrupt Is Not Enabled     |      |
| 18-10  | SPI Interrupt Request Generation                     |      |
| 18-11  | SPRF/SPTE CPU Interrupt Timing.                      |      |
| 18-12  | CPHA/SS Timing                                       |      |
| 18-13  | SPI Control Register (SPCR)                          |      |
| 18-14  | SPI Status and Control Register (SPSCR)              |      |
| 18-15  | SPI Data Register (SPDR)                             | 272  |
| 19-1   | ADC Block Diagram                                    | 275  |
| 19-2   | ADC Status and Control Register (ADSCR)              | 279  |
| 19-3   | ADC Data Register (ADR)                              | 282  |
| 19-4   | ADC Input Clock Register (ADICLK)                    | 282  |
| 20-1   | TIMA Block Diagram                                   | 287  |
| 20-2   | TIMA I/O Register Summary                            |      |
| 20-3   | PWM Period and Pulse Width                           |      |
| 20-4   | TIMA Status and Control Register (TASC)              | 300  |
| 20-5   | TIMA Counter Registers (TACNTH and TACNTL)           | 302  |
| 20-6   | TIMA Counter Modulo Registers (TMODH and TMODL)      | 303  |
| 20-7   | TIMA Channel Status                                  |      |
|        | and Control Registers (TASC0–TASC1)                  |      |
| 20-8   | CHxMAX Latency                                       |      |
| 20-9   | TIMA Channel Registers (TACH0H/L–TACH1H/L)           | 308  |
| 21-1   | TIMB Block Diagram                                   | 313  |
| 21-2   | TIMB I/O Register Summary                            |      |
| 21-3   | PWM Period and Pulse Width                           |      |
| 21-4   | TIMB Status and Control Register (TBSC)              |      |
| 21-5   | TIMB Counter Registers (TBCNTH and TBCNTL)           | 328  |
| 21-6   | TIMB Counter Modulo Registers<br>(TBMODH and TBMODL) | 329  |
| 21-7   | TIMB Channel Status                                  |      |
|        | and Control Registers (TBSC0–TBSC1)                  | 330  |
| 21-8   | CHxMAX Latency                                       |      |
| 21-9   | TIMB Channel Registers (TBCH0H/L–TBCH1H/L)           |      |

24

| Figure | Title                                                | Page |
|--------|------------------------------------------------------|------|
| 22-1   | CAN System.                                          | 340  |
| 22-2   | User Model for Message Buffer Organization           | 343  |
| 22-3   | Single 32-Bit Maskable Identifier Acceptance Filter  | 346  |
| 22-4   | Dual 16-Bit Maskable Acceptance Filters              | 347  |
| 22-5   | Quadruple 8-Bit Maskable Acceptance Filters          | 348  |
| 22-6   | Sleep Request/Acknowledge Cycle                      | 352  |
| 22-7   | Clocking Scheme                                      | 354  |
| 22-8   | Segments within the Bit Time                         | 356  |
| 22-9   | Message Buffer Organization                          | 357  |
| 22-10  | Receive/Transmit Message Buffer                      |      |
|        | Extended Identifier Registers                        | 358  |
| 22-11  | Standard Identifier Mapping                          | 359  |
| 22-12  | Transmit Buffer Priority Register (TBPR)             | 362  |
| 22-13  | MSCAN08 Control Register Struture                    |      |
| 22-14  | CAN Module Control Register 0 (CMCR0)                |      |
| 22-15  | CAN Module Control Register 1 (CMCR1)                |      |
| 22-16  | CAN Bus Timing Register 0 (CBTR0)                    |      |
| 22-17  | CAN Bus Timing Register 1 (CBTR1)                    |      |
| 22-18  | CAN Receiver Flag Register (CRFLG)                   |      |
| 22-19  | CAN Receiver Interrupt Enable Register (CRIER)       |      |
| 22-20  | CAN Transmitter Flag Register (CTFLG)                |      |
| 22-21  | CAN Transmitter Control Register (CTCR)              |      |
| 22-22  | CAN Identifier Acceptance Control Register (CIDAC) . |      |
| 22-23  | CAN Receiver Error Counter Register (CRXERR)         |      |
| 22-24  | CAN Transmit Error Counter Register (CTXERR)         |      |
| 22-25  | CAN Identifier Acceptance Registers (CIDAR0–CIDAR    | · ·  |
| 22-26  | CAN Identifier Mask Registers (CIDMR0–CIDMR3)        | 381  |
| 23-1   | SPI Master Timing                                    |      |
| 23-2   | SPI Slave Timing                                     | 391  |

# **List of Tables**

| Table                                                                | Title                                                                                                                                                                                                                                                                           | Page |
|----------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------|
| 1-1                                                                  | External Pins Summary                                                                                                                                                                                                                                                           |      |
| 2-1                                                                  | Vector Addresses                                                                                                                                                                                                                                                                | 62   |
| 6-1<br>6-2<br>6-3                                                    | EEPROM Program/Erase Cycling ReductionEEPROM Array Address BlocksEEPROM Program/Erase Mode Select                                                                                                                                                                               |      |
| 7-1<br>7-2                                                           | Instruction Set Summary                                                                                                                                                                                                                                                         |      |
| 9-1                                                                  | VCO Frequency Multiplier (N) Selection                                                                                                                                                                                                                                          | 122  |
| 10-1<br>10-2                                                         | Signal Name Conventions                                                                                                                                                                                                                                                         |      |
| 11-1                                                                 | LVIOUT Bit Indication                                                                                                                                                                                                                                                           | 154  |
| 13-1<br>13-2<br>13-3<br>13-4<br>13-5<br>13-6<br>13-7<br>13-8<br>13-9 | Mode Selection<br>Mode Differences<br>READ (Read Memory) Command<br>WRITE (Write Memory) Command.<br>IREAD (Indexed Read) Command.<br>IWRITE (Indexed Write) Command.<br>READSP (Read Stack Pointer) Command.<br>RUN (Run User Program) Command.<br>Monitor Baud Rate Selection |      |
| 16-1<br>16-2<br>16-3                                                 | Port A Pin Functions<br>Port B Pin Functions<br>Port C Pin Functions                                                                                                                                                                                                            | 192  |

MC68HC08QA24

| Table        | Title                                                                                  | Page |
|--------------|----------------------------------------------------------------------------------------|------|
| 16-4         | Port D Pin Functions.                                                                  | 198  |
| 16-5         | Port E Pin Functions                                                                   | 202  |
| 16-6         | Port F Pin Functions                                                                   | 205  |
| 474          |                                                                                        | 240  |
| 17-1<br>17-2 | Start Bit Verification                                                                 |      |
| 17-2         | Data Bit Recovery.   Stop Bit Recovery.                                                |      |
| 17-3         | Character Format Selection                                                             |      |
| 17-4         | SCI Baud Rate Prescaling                                                               |      |
| 17-6         | SCI Baud Rate Selection                                                                |      |
| 17-7         | SCI Baud Rate Selection Examples                                                       |      |
|              |                                                                                        |      |
| 18-1         | Pin Name Conventions                                                                   | 243  |
| 18-2         | I/O Register Addresses                                                                 |      |
| 18-3         | SPI Interrupts                                                                         |      |
| 18-4         | SPI Configuration                                                                      |      |
| 18-5         | SPI Master Baud Rate Selection                                                         | 271  |
|              |                                                                                        |      |
| 19-1         | Mux Channel Select                                                                     |      |
| 19-2         | ADC Clock Divide Ratio                                                                 | 283  |
| 20-1         | Prescaler Selection.                                                                   | 201  |
| 20-1         | Mode, Edge, and Level Selection.                                                       |      |
| 20-2         |                                                                                        |      |
| 21-1         | Prescaler Selection.                                                                   | 327  |
| 21-2         | Mode, Edge, and Level Selection                                                        | 332  |
| 22-1         | MSCANO2 Interrupt )/actor Addresses                                                    | 250  |
| 22-1         | MSCAN08 Interrupt Vector Addresses<br>CAN Standard Compliant Bit Time Segment Settings |      |
| 22-2         | Data Length Codes.                                                                     |      |
| 22-3         | Synchronization Jump Width                                                             |      |
| 22-4         | Baud Rate Prescaler                                                                    |      |
| 22-5<br>22-6 | Time Segment Syntax                                                                    |      |
| 22-7         | Time Segment 1 Values                                                                  |      |
| 22-8         | Time Segment 2 Values                                                                  |      |
| 22-9         | Identifier Acceptance Mode Settings                                                    |      |
| 22-10        | Identifier Acceptance Hit Indication                                                   |      |
|              |                                                                                        |      |

# **Section 1. General Description**

#### **1.1 Contents**

| 1.2    | Introduction                                             |
|--------|----------------------------------------------------------|
| 1.3    | Features                                                 |
| 1.4    | MCU Block Diagram                                        |
| 1.5    | Pin Assignments                                          |
| 1.5.1  | Power Supply Pins (V <sub>DD</sub> and V <sub>SS</sub> ) |
| 1.5.2  | Oscillator Pins (OSC1 and OSC2)                          |
| 1.5.3  | External Reset Pin (RST)                                 |
| 1.5.4  | External Interrupt Pin (IRQ)                             |
| 1.5.5  | Analog Power Supply Pin (V <sub>DDA</sub> )              |
| 1.5.6  | Analog Ground Pin (V <sub>SSA</sub> /V <sub>REFL</sub> ) |
| 1.5.7  | External Filter Capacitor Pin (CGMXFC)                   |
| 1.5.8  | Port A Input/Output (I/O) Pins (PTA7–PTA0)               |
| 1.5.9  | Port B I/O Pins (PTB7/ATD7–PTB0/ATD0)                    |
| 1.5.10 |                                                          |
| 1.5.11 |                                                          |
| 1.5.12 | Port E I/O Pins (PTE7/SPSCK–PTE0/TxD)                    |
| 1.5.13 | Port F I/O Pins (PTF3/TACLK–PTF0/TBCH0)37                |
| 1.5.14 |                                                          |
| 1.5.15 | 6 CAN Receive Pin (CANRx)                                |
|        |                                                          |

#### **1.2 Introduction**

The MC68HC08QA24 is a member of the low-cost, high-performance M68HC08 Family of 8-bit microcontroller units (MCUs). The M68HC08 Family is based on the customer-specified integrated circuit (CSIC) design strategy. All MCUs in the family use the enhanced M68HC08 central processor unit (CPU08) and are available with a variety of modules, memory sizes and types, and package types.

#### **1.3 Features**

Features of the MC68HC08QA24 include:

- High-performance M68HC08 architecture
- Fully upward-compatible object code with M6805, M146805, and M68HC05 Families
- 8.4-MHz internal bus frequency
- 24,064 bytes of user read-only memory (ROM)
- ROM data security<sup>(1)</sup>
- 512 bytes of on-chip electrically erasable programmable read-only memory (EEPROM)
- 768 bytes of on-chip random-access memory (RAM)
- Serial peripheral interface module (SPI)
- Serial communications interface module (SCI)
- Two 16-bit, 2-channel timer interface modules (TIMA and TIMB)
- Clock generator module (CGM)
- 8-bit, 12-channel analog-to-digital converter module (ADC)
- Motorola scalable controller area network module (MSCAN)

<sup>1.</sup> No security feature is absolutely secure. However, Motorola's strategy is to make reading or copying the ROM difficult for unauthorized users.

- System protection features:
  - Computer operating properly (COP) with optional reset
  - Low-voltage detection with optional reset
  - Illegal opcode detection with optional reset
  - Illegal address detection with optional reset
  - Dual CPU for error detection reset
- Low-power design (fully static with stop and wait modes)
- Master reset pin and power-on reset (POR)

Features of the CPU08 include:

- Enhanced HC05 programming model
- Extensive loop control functions
- 16 addressing modes (eight more than the HC05)
- 16-bit index register and stack pointer
- Memory-to-memory data transfers
- Fast 8 × 8 multiply instruction
- Fast 16/8 divide instruction
- Binary-coded decimal (BCD) instructions
- Optimization for controller applications
- C language support

#### 1.4 MCU Block Diagram

Figure 1-1 shows the structure of the MC68HC08QA24.





32

**Technical Data** 

General Description

### 1.5 Pin Assignments



**Figure 1-2** shows the 52-pin plastic leaded chip carrier (PLCC) assignments.

Figure 1-2. 52-Pin PLCC Assignments (Top View)

#### 1.5.1 Power Supply Pins (V<sub>DD</sub> and V<sub>SS</sub>)

 $V_{\text{DD}}$  and  $V_{\text{SS}}$  are the power supply and ground pins. The MCU operates from a single power supply.

Fast signal transitions on MCU pins place high, short-duration current demands on the power supply. To prevent noise problems, take special care to provide power supply bypassing at the MCU as Figure 1-3 shows. Place the C1 bypass capacitor as close to the MCU as possible. Use a high-frequency-response ceramic capacitor for C1. C2 is an optional bulk current bypass capacitor for use in applications that require the port pins to source high current levels.



Note: Component values shown represent typical applications.

#### Figure 1-3. Power Supply Bypassing

 $V_{SS}$  is also the ground for the port output buffers and the ground return for the serial clock in the serial peripheral interface module (SPI). (See Section 18. Serial Peripheral Interface (SPI).)

**NOTE:** V<sub>SS</sub> must be grounded for proper MCU operation.

Technical Data

#### 1.5.2 Oscillator Pins (OSC1 and OSC2)

The OSC1 and OSC2 pins are the connections for the on-chip oscillator circuit. (See Section 9. Clock Generator Module (CGM).)

#### 1.5.3 External Reset Pin (RST)

A logic 0 on the RST pin forces the MCU to a known startup state. RST is bidirectional, allowing a reset of the entire system. It is driven low when any internal reset source is asserted. (See Section 10. System Integration Module (SIM) for more information.)

#### 1.5.4 External Interrupt Pin (IRQ)

IRQ is an asynchronous external interrupt pin. (See Section 15. External Interrupt (IRQ).)

#### 1.5.5 Analog Power Supply Pin (V<sub>DDA</sub>)

V<sub>DDA</sub> is the power supply pin for the analog portion of the chip. These modules are the analog-to-digital converter (ADC) and the clock generator module (CGM). (See Section 9. Clock Generator Module (CGM) and Section 19. Analog-to-Digital Converter (ADC).)

#### 1.5.6 Analog Ground Pin (V<sub>SSA</sub>/V<sub>REFL</sub>)

The  $V_{SSA}/V_{REFL}$  analog ground pin is used only for the ground connections for the analog sections of the circuit and should be decoupled as per the  $V_{SS}$  digital ground pin. The analog sections consist of a clock generator module (CGM) and an analog-to-digital converter (ADC).  $V_{SSA}/V_{REFL}$  is also the lower reference supply for the ADC. (See Section 9. Clock Generator Module (CGM) and Section 19. Analog-to-Digital Converter (ADC).)

#### 1.5.7 External Filter Capacitor Pin (CGMXFC)

CGMXFC is an external filter capacitor connection for the CGM. (See **Section 9. Clock Generator Module (CGM)**.)

#### MC68HC08QA24

#### 1.5.8 Port A Input/Output (I/O) Pins (PTA7–PTA0)

PTA7–PTA0 are general-purpose bidirectional input/output (I/O) port pins. (See Section 16. Input/Output (I/O) Ports.)

#### 1.5.9 Port B I/O Pins (PTB7/ATD7-PTB0/ATD0)

Port B is an 8-bit special function port that shares all eight pins with the analog-to-digital converter (ADC). (See Section 19. Analog-to-Digital Converter (ADC) and Section 16. Input/Output (I/O) Ports.)

#### 1.5.10 Port C I/O Pins (PTC4–PTC0)

PTC4–PTC3 and PTC1–PTC0 are general-purpose, bidirectional I/O port pins. PTC2/MCLK is a special function port that shares its pin with the system clock. (See Section 16. Input/Output (I/O) Ports.)

#### 1.5.11 Port D I/O Pins (PTD5-PTD0/ATD8)

Port D is a 6-bit special function port that shares four of its pins with the analog-to-digital converter module (ADC). (See Section 19. Analog-to-Digital Converter (ADC) and Section 16. Input/Output (I/O) Ports.)

#### 1.5.12 Port E I/O Pins (PTE7/SPSCK-PTE0/TxD)

Port E is an 8-bit special function port that shares two of its pins with the timer A interface module (TIMA), four of its pins with the serial peripheral interface module (SPI), and two of its pins with the serial communication interface module (SCI). (See Section 17. Serial Communications Interface (SCI), Section 18. Serial Peripheral Interface (SPI), Section 20. Timer Interface A (TIMA), and Section 16. Input/Output (I/O) Ports.)
#### 1.5.13 Port F I/O Pins (PTF3/TACLK-PTF0/TBCH0)

Port F is a 4-bit special function port that shares three of its pins with the timer B interface module (TIMB) and one of its pins with the timer A interface module(TIMA). (See Section 20. Timer Interface A (TIMA), Section 21. Timer Interface B (TIMB) and Section 16. Input/Output (I/O) Ports.)

#### 1.5.14 CAN Transmit Pin (CANTx)

This pin is the digital output from the controller area network (CAN) module (CANTx). (See Section 22. CAN Controller.)

#### 1.5.15 CAN Receive Pin (CANRx)

This pin is the digital input to the CAN module (CANRx). (See Section 22. CAN Controller.)

| Pin Name             | Function                                   | Driver Type              | Hysteresis | Reset State |
|----------------------|--------------------------------------------|--------------------------|------------|-------------|
| PTA7–PTA0            | General-purpose I/O                        | Dual state               | No         | Input hi-z  |
| PTB7/ATD7-PTB0/ATD0  | General-purpose I/O<br>ADC channel         | Dual state               | No         | Input hi-z  |
| PTC4–PTC0            | General-purpose I/O                        | Dual state               | No         | Input hi-z  |
| FLT                  | Output only<br>for dual CPU fault          | Dual state               | No         | Output      |
| PTD5–PTD4            | General-purpose I/O                        | Dual state               | No         | Input hi-z  |
| PTD3/ATD11-PTD0/ATD8 | General-purpose I/O<br>ADC channel         | Dual state               | No         | Input hi-z  |
| PTE7/SPSCK           | General-purpose I/O<br>SPI clock           | Dual state<br>open drain | Yes        | Input hi-z  |
| PTE6/MOSI            | General-purpose I/O<br>SPI data path       | Dual state<br>open drain | Yes        | Input hi-z  |
| PTE5/MISO            | General-purpose I/O<br>SPI data path       | Dual state<br>open drain | Yes        | Input hi-z  |
| PTE4/SS              | General-purpose I/O<br>SPI slave select    | Dual state               | Yes        | Input hi-z  |
| PTE3/TACH1           | General-purpose I/O<br>timer A channel 1   | Dual state               | Yes        | Input hi-z  |
| PTE2/TACH0           | General-purpose I/O<br>timer A channel 0   | Dual state               | Yes        | Input hi-z  |
| PTE1/RxD             | General-purpose I/O<br>SCI receive data    | Dual state               | Yes        | Input hi-z  |
| PTE0/TxD             | General-purpose I/O<br>SCI transmit data   | Dual state               | Yes        | Input hi-z  |
| PTF3/TACLK           | General-purpose I/O<br>timer A input clock | Dual state               | Yes        | Input hi-z  |
| PTF2/TBCLK           | General-purpose I/O<br>timer B input clock | Dual state               | Yes        | Input hi-z  |
| PTF1/TBCH1           | General-purpose I/O<br>timer B channel 1   | Dual state               | Yes        | Input hi-z  |
| PTF0/TBCH0           | General-purpose I/O<br>timer B channel 0   | Dual state               | Yes        | Input hi-z  |
| V <sub>DD</sub>      | Chip power supply                          | N/A                      | N/A        | N/A         |

| Pin Name                            | Function                                | Driver Type | Hysteresis | Reset State |  |  |
|-------------------------------------|-----------------------------------------|-------------|------------|-------------|--|--|
| V <sub>SS</sub>                     | Chip ground                             | N/A         | N/A        | N/A         |  |  |
| V <sub>DDA</sub>                    | Analog power supply                     | N/A         | N/A        | N/A         |  |  |
| V <sub>SSA</sub> /V <sub>REFL</sub> | Analog ground/<br>ADC reference voltage | N/A         | N/A        | N/A         |  |  |
| V <sub>REFH</sub>                   | A/D reference voltage                   | N/A         | N/A        | N/A         |  |  |
| OSC1                                | External clock in                       | N/A         | N/A N/A    |             |  |  |
| OSC2                                | External clock out                      | N/A         | N/A        | Output      |  |  |
| CGMXFC                              | PLL loop filter capacitor               | N/A         | N/A        | N/A         |  |  |
| IRQ                                 | External interrupt request              | N/A         | N/A        | Input hi-z  |  |  |
| RST                                 | Reset                                   | N/A         | N/A        | Output low  |  |  |
| CANRx                               | CAN serial input                        | N/A         | Yes        | Input hi-z  |  |  |
| CANTx                               | CAN serial output                       | Output      | No         | Output      |  |  |

**Technical Data** 

# Section 2. Memory Map

### 2.1 Contents

| 2.2 | Introduction                  | 41 |
|-----|-------------------------------|----|
| 2.3 | Summary of Internal Registers | 43 |

### 2.2 Introduction

The CPU08 can address 64 Kbytes of memory space. The memory map, shown in **Figure 2-1**, includes:

- 24,064 bytes of user ROM
- 768 bytes of RAM
- 512 bytes of EEPROM
- 40 bytes of user-defined vectors
- 224 bytes of monitor ROM

These definitions apply to the memory map representation of reserved and unimplemented locations.

- Reserved Accessing a reserved location can have unpredictable effects on MCU operation.
- Unimplemented Accessing an unimplemented location causes an illegal address reset if illegal address resets are enabled.

|              | Figure 2-1. Memory Map                                                   |
|--------------|--------------------------------------------------------------------------|
| \$9FFF       | UNIMPLEMENTED — 37,886 BYTES                                             |
| $\downarrow$ |                                                                          |
| \$0A00       | RESERVED — 2 BYTES                                                       |
| \$09FF       |                                                                          |
| $\downarrow$ | EEPROM — 512 BYTES                                                       |
| \$0800       |                                                                          |
| \$07FF       |                                                                          |
| $\downarrow$ | UNIMPLEMENTED — 640 BYTES                                                |
| \$0580       |                                                                          |
| \$057F       |                                                                          |
| $\downarrow$ | CAN MESSAGE BUFFERS — 64 BYTES                                           |
| \$0540       |                                                                          |
| \$053F       |                                                                          |
| $\downarrow$ | RESERVED — 32 BYTES                                                      |
| \$0520       |                                                                          |
| \$051F       |                                                                          |
| $\downarrow$ | CAN CONTROL REGISTERS — 32 BYTES                                         |
| \$0500       |                                                                          |
| \$04FF       |                                                                          |
| $\downarrow$ | UNIMPLEMENTED — 446 BYTES                                                |
| \$0342       |                                                                          |
| \$0340       | RESERVED — 2 BYTES                                                       |
| \$033F       |                                                                          |
| $\downarrow$ | RAM — 768 BYTES                                                          |
| \$0040       |                                                                          |
| \$003F       |                                                                          |
| $\downarrow$ | UNIMPLEMENTED — 5 BYTES                                                  |
| \$003B       |                                                                          |
| \$003A       |                                                                          |
| $\downarrow$ | (\$000A, \$000B, \$000E, \$000F, \$001B, \$0021, \$002D<br>ARE RESERVED) |
| \$0000       | I/O REGISTERS — 52 BYTES                                                 |



Figure 2-1. Memory Map (Continued)

## 2.3 Summary of Internal Registers

Control and status registers for most of the internal functional modules are located within addresses \$0000–\$003A, shown in **Figure 2-2**. The control and message buffers for the CAN are located in addresses \$0500–\$057F as shown in the CAN module section of this specification. Additional control registers are located between \$FE00 and \$FE1F and are also shown in **Figure 2-2**.

| Addr.  | Register Name                       |                 | Bit 7  | 6                   | 5     | 4          | 3          | 2     | 1     | Bit 0  |
|--------|-------------------------------------|-----------------|--------|---------------------|-------|------------|------------|-------|-------|--------|
| \$0000 | Port A Data Register<br>(PTA)       | Read:<br>Write: | PTA7   | PTA6                | PTA5  | PTA4       | PTA3       | PTA2  | PTA1  | PTA0   |
|        | See page 188.                       | Reset:          |        |                     |       | Unaffected | d by reset |       |       |        |
| \$0001 | Port B Data Register<br>(PTB)       | Read:<br>Write: | PTB7   | PTB6                | PTB5  | PTB4       | PTB3       | PTB2  | PTB1  | PTB0   |
|        | See page 190.                       | Reset:          |        |                     |       | Unaffected | d by reset |       |       |        |
|        | Port C Data Register                | Read:           | 0      | 0                   | 0     | PTC4       | PTC3       | PTC2  | PTC1  | PTC0   |
| \$0002 | (PTC)                               | Write:          | R      | R                   | R     | PIC4       | PICS       | PICZ  |       | PICU   |
|        | See page 193.                       | Reset:          |        | Unaffected by reset |       |            |            |       |       |        |
|        | Port D Data Register                | Read:           | 0      | 0                   | PTD5  | PTD4       | PTD3       | PTD2  | PTD1  | PTD0   |
| \$0003 | (PTD)<br>See page 196.              | Write:          | R      | R                   |       | דטוו       |            | 1102  |       | 1100   |
|        | See page 190.                       | Reset:          |        |                     |       | Unaffected | d by reset |       |       |        |
| \$0004 | Data Direction Register A<br>(DDRA) | Read:<br>Write: | DDRA7  | DDRA6               | DDRA5 | DDRA4      | DDRA3      | DDRA2 | DDRA1 | DDRA0  |
|        | See page 188.                       | Reset:          | 0      | 0                   | 0     | 0          | 0          | 0     | 0     | 0      |
| \$0005 | Data Direction Register B<br>(DDRB) | Read:<br>Write: | DDRB7  | DDRB6               | DDRB5 | DDRB4      | DDRB3      | DDRB2 | DDRB1 | DDRB0  |
|        | See page 191.                       | Reset:          | 0      | 0                   | 0     | 0          | 0          | 0     | 0     | 0      |
|        | Data Direction Register C           | Read:           | MCLKEN | 0                   | 0     | DDRC4      | DDRC3      | DDRC2 | DDRC1 | DDRC0  |
| \$0006 | (DDRC)<br>See page 194.             | Write:          | MOEREN | R                   | R     | DDITOT     | DDI(03     | DDROZ | DBROT | DDINOU |
|        | See page 174.                       | Reset:          | 0      | 0                   | 0     | 0          | 0          | 0     | 0     | 0      |
|        | Data Direction Register D           | Read:           | 0      | 0                   | DDRD5 | DDRD4      | DDRD3      | DDR2  | DDRD1 | DDRD0  |
| \$0007 | (DDRD)<br>See page 197.             | Write:          | R      | R                   |       |            |            |       |       |        |
|        |                                     | Reset:          | 0      | 0                   | 0     | 0          | 0          | 0     | 0     | 0      |
| \$0008 | Port E Data Register<br>(PTE)       | Read:<br>Write: | PTE7   | PTE6                | PTE5  | PTE4       | PTE3       | PTE2  | PTE1  | PTE0   |
|        | See page 199.<br>R                  |                 |        |                     |       | Unaffected | d by reset |       |       |        |
|        |                                     |                 | R      | = Reserve           | ed    | U = Una    | affected   |       |       |        |

Figure 2-2. Control, Status, and Data Registers (Sheet 1 of 18)

| Addr.                                      | Register Name                  |                 | Bit 7     | 6           | 5       | 4          | 3          | 2       | 1     | Bit 0 |
|--------------------------------------------|--------------------------------|-----------------|-----------|-------------|---------|------------|------------|---------|-------|-------|
|                                            | Port F Data Register           | Read:           | 0         | 0           | 0       | 0          | PTF3       | PTF2    | PTF1  | PTF0  |
| \$0009                                     | (PTF)                          | Write:          | R         | R           | R       | R          |            | FIFZ    |       | FILA  |
|                                            | See page 203.                  | Reset:          |           |             |         | Unaffected | d by reset | •       |       |       |
| \$000A                                     | Reserved                       |                 | R         | R           | R       | R          | R          | R       | R     | R     |
|                                            |                                |                 |           |             |         | -          |            |         |       |       |
| \$000B                                     | Reserved                       |                 | R         | R           | R       | R          | R          | R       | R     | R     |
|                                            |                                |                 |           |             |         |            |            |         |       |       |
| Data Direction Register E<br>\$000C (DDRE) | Read:<br>Write:                | DDRE7           | DDRE6     | DDRE5       | DDRE4   | DDRE3      | DDRE2      | DDRE1   | DDRE0 |       |
|                                            | See page 201.                  | Reset:          | 0         | 0           | 0       | 0          | 0          | 0       | 0     | 0     |
|                                            | Read:                          | 0               | 0         | 0           | 0       | DDRF3      | DDRF2      | DDRF1   | DDRF0 |       |
|                                            | (DDRF)                         | Write:          | R         | R           | R       | R          | DDRF3      | DDRFZ   | DDRFT | DDRFU |
|                                            | See page 204.                  | Reset:          | 0         | 0           | 0       | 0          | 0          | 0       | 0     | 0     |
| \$000E                                     | Reserved                       |                 | R         | R           | R       | R          | R          | R       | R     | R     |
|                                            |                                |                 |           |             |         |            |            |         |       |       |
| \$000F                                     | Reserved                       |                 | R         | R           | R       | R          | R          | R       | R     | R     |
|                                            |                                |                 |           |             |         |            |            |         |       |       |
| \$0010                                     | SPI Control Register<br>(SPCR) | Read:<br>Write: | SPRIE     | R           | SPMSTR  | CPOL       | CPHA       | SPWOM   | SPE   | SPTIE |
|                                            | See page 266.                  | Reset:          | 0         | 0           | 1       | 0          | 1          | 0       | 0     | 0     |
|                                            | SPI Status and Control         | Read:           | SPRF      | ERRIE       | OVRF    | MODF       | SPTE       | MODFEN  | SPR1  | SPR0  |
| \$0011                                     | Register (SPSCR)               | Write:          | R         |             | R       | R          | R          |         | 511(1 | 51 10 |
|                                            | See page 269.                  | Reset:          | 0         | 0           | 0       | 0          | 1          | 0       | 0     | 0     |
|                                            | SPI Data Register              | Read:           | R7        | R6          | R5      | R4         | R3         | R2      | R1    | R0    |
| \$0012                                     | \$0012 (SPDR)                  | Write:          | T7        | T6          | T5      | Τ4         | Т3         | T2      | T1    | Т0    |
| See page 272.                              |                                | Reset:          |           |             |         | Unaffected | d by reset |         |       |       |
|                                            |                                |                 | R         | ] = Reserve | ed      | U = Una    | affected   |         |       |       |
|                                            | Figure 2-2. C                  | ontro           | ol, Statu | is, and     | Data Ro | egisters   | (Sheet     | 2 of 18 | )     |       |

Figure 2-2. Control, Status, and Data Registers (Sheet 2 of 18)

MC68HC08QA24

| Addr.  | Register Name                                                                                 |                 | Bit 7 | 6     | 5     | 4          | 3          | 2    | 1       | Bit 0 |  |
|--------|-----------------------------------------------------------------------------------------------|-----------------|-------|-------|-------|------------|------------|------|---------|-------|--|
| \$0013 | SCI Control Register 1<br>(SCC1)                                                              | Read:<br>Write: | LOOPS | ENSCI | TXINV | М          | WAKE       | ILTY | PEN     | РТҮ   |  |
|        | See page 225.                                                                                 | Reset:          | 0     | 0     | 0     | 0          | 0          | 0    | 0       | 0     |  |
| \$0014 | SCI Control Register 2<br>\$0014 (SCC2)                                                       | Read:<br>Write: | SCTIE | TCIE  | SCRIE | ILIE       | TE         | RE   | RWU     | SBK   |  |
|        | See page 228.                                                                                 | Reset:          | 0     | 0     | 0     | 0          | 0          | 0    | 0       | 0     |  |
|        | SCI Control Register 3                                                                        | Read:           | R8    | Т8    | R     | R          | ORIE       | NEIE | FEIE    | PEIE  |  |
| \$0015 | (SCC3)                                                                                        | Write:          | R     | 10    | ĸ     | ĸ          | UKIE       |      | FEIE    | PEIE  |  |
|        | See page 231.                                                                                 | Reset:          | U     | U     | 0     | 0          | 0          | 0    | 0       | 0     |  |
|        | SCI Status Register 1                                                                         | Read:           | SCTE  | TC    | SCRF  | IDLE       | OR         | NF   | FE      | PE    |  |
| \$0016 | (SCS1)                                                                                        | Write:          | R     | R     | R     | R          | R          | R    | R       | R     |  |
|        | See page 233.                                                                                 | Reset:          | 1     | 1     | 0     | 0          | 0          | 0    | 0       | 0     |  |
|        | SCI Status Register 2                                                                         | Read:           | 0     | 0     | 0     | 0          | 0          | 0    | BKF     | RPF   |  |
| \$0017 | (SCS2)                                                                                        | Write:          | R     | R     | R     | R          | R          | R    | R       | R     |  |
|        | See page 237.                                                                                 | Reset:          | 0     | 0     | 0     | 0          | 0          | 0    | 0       | 0     |  |
|        | SCI Data Register                                                                             | Read:           | R7    | R6    | R5    | R4         | R3         | R2   | R1      | R0    |  |
| \$0018 | (SCDR)                                                                                        | Write:          | T7    | T6    | T5    | T4         | Т3         | T2   | T1      | Т0    |  |
|        | See page 238.                                                                                 | Reset:          |       |       |       | Unaffected | d by reset |      |         |       |  |
| \$0019 | SCI Baud Rate Register<br>(SCBR)                                                              | Read:<br>Write: | R     | R     | SCP1  | SCP0       | R          | SCR2 | SCR1    | SCR0  |  |
|        | See page 238.                                                                                 | Reset:          | 0     | 0     | 0     | 0          | 0          | 0    | 0       | 0     |  |
|        | IRQ Status and Control                                                                        | Read:           | 0     | 0     | 0     | 0          | IRQF       | 0    | IMASK   | MODE  |  |
| \$001A | Register (ISCR)                                                                               | Write:          | R     | R     | R     | R          | R          | ACK  | IIVIAJN | WODL  |  |
|        | See page 184.                                                                                 | Reset:          | 0     | 0     | 0     | 0          | 0          | 0    | 0       | 0     |  |
| \$001B | Reserved                                                                                      |                 | R     | R     | R     | R          | R          | R    | R       | R     |  |
|        | R = Reserved U = Unaffected   Figure 2-2. Control, Status, and Data Registers (Sheet 3 of 18) |                 |       |       |       |            |            |      |         |       |  |

Figure 2-2. Control, Status, and Data Registers (Sheet 3 of 18)

| Addr.  | Register Name                              |                 | Bit 7   | 6         | 5      | 4          | 3          | 2       | 1        | Bit 0 |
|--------|--------------------------------------------|-----------------|---------|-----------|--------|------------|------------|---------|----------|-------|
|        | PLL Control Register                       | Read:           |         | PLLF      | DULON  | DOC        | 1          | 1       | 1        | 1     |
| \$001C | (PCTL)                                     | Write:          | PLLIE   | R         | PLLON  | BCS        | R          | R       | R        | R     |
|        | See page 118.                              | Reset:          | 0       | 0         | 1      | 0          | 1          | 1       | 1        | 1     |
|        | PLL Bandwidth Control                      | Read:           | AUTO    | LOCK      | ACO    | VID        | 0          | 0       | 0        | 0     |
| \$001D | Register (PBWC)                            | Write:          | AUTU    | R         | ACQ    | XLD        | R          | R       | R        | R     |
|        | See page 120.                              | Reset:          | 0       | 0         | 0      | 0          | 0          | 0       | 0        | 0     |
| \$001E | PLL Programming Register<br>(PPG)          | Read:<br>Write: | MUL7    | MUL6      | MUL5   | MUL4       | VRS7       | VRS6    | VRS5     | VRS4  |
|        | See page 122.                              | Reset:          | 0       | 1         | 1      | 0          | 0          | 1       | 1        | 0     |
|        | Mask Option Register                       | Read:           | LVISTOP | ROMSEC    | LVIRST | LVIPWR     | SSREC      | COPS    | STOP     | COPD  |
| \$001F | (MOR)                                      | Write:          | R       | R         | R      | R          | R          | R       | R        | R     |
|        | See page 68.                               | Reset:          |         |           |        | Unaffected | d by reset |         |          |       |
|        | TIMA Status and Control<br>Register (TASC) | Read:           | TOF     | TOIE      | TSTOP  | 0          | 0          | PS2     | PS1      | PS0   |
| \$0020 |                                            | Write:          | 0       |           | 13105  | TRST       | R          | F 32    |          | r JU  |
|        | See page 300.                              | Reset:          | 0       | 0         | 1      | 0          | 0          | 0       | 0        | 0     |
| \$0021 | Reserved                                   |                 | R       | R         | R      | R          | R          | R       | R        | R     |
|        |                                            |                 |         |           |        |            |            |         |          |       |
|        | TIMA Counter Register High                 | Read:           | Bit 15  | 14        | 13     | 12         | 11         | 10      | 9        | Bit 8 |
| \$0022 | (TACNTH)                                   | Write:          | R       | R         | R      | R          | R          | R       | R        | R     |
|        | See page 302.                              | Reset:          | 0       | 0         | 0      | 0          | 0          | 0       | 0        | 0     |
|        | TIMA Counter Register Low                  | Read:           | Bit 7   | 6         | 5      | 4          | 3          | 2       | 1        | Bit 0 |
| \$0023 | (TACNTL)                                   | Write:          | R       | R         | R      | R          | R          | R       | R        | R     |
|        | See page 302.                              | Reset:          | 0       | 0         | 0      | 0          | 0          | 0       | 0        | 0     |
| \$0024 | TIMA Modulo Register High<br>(TAMODH)      | Read:<br>Write: | Bit 15  | 14        | 13     | 12         | 11         | 10      | 9        | Bit 8 |
|        | See page 303.                              | Reset:          | 1       | 1         | 1      | 1          | 1          | 1       | 1        | 1     |
|        |                                            |                 | R       | = Reserve | ed     | U = Una    | iffected   |         |          |       |
|        | Figure 2-2 C                               | ontro           | Statu   | ie and    | Nata P | anistare   | (Sheet     | 1 of 19 | <u>م</u> |       |

Figure 2-2. Control, Status, and Data Registers (Sheet 4 of 18)

| Addr.                                          | Register Name                                 |                 | Bit 7                     | 6           | 5       | 4           | 3            | 2         | 1     | Bit 0   |  |  |
|------------------------------------------------|-----------------------------------------------|-----------------|---------------------------|-------------|---------|-------------|--------------|-----------|-------|---------|--|--|
| \$0025                                         | TIMA Modulo Register Low<br>(TAMODL)          | Read:<br>Write: | Bit 7                     | 6           | 5       | 4           | 3            | 2         | 1     | Bit 0   |  |  |
|                                                | See page 303.                                 | Reset:          | 1                         | 1           | 1       | 1           | 1            | 1         | 1     | 1       |  |  |
|                                                | TIMA Channel 0 Status                         | Read:           | CH0F                      | CHOIE       | MS0B    | MS0A        | ELS0B        | ELS0A     | TOV0  | CHOMAX  |  |  |
| \$0026                                         | and Control Register<br>(TASC0)               | Write:          | 0                         |             | IVISUD  | IVISUA      | ELJUD        | ELSUA     | 1000  |         |  |  |
|                                                | See page 304.                                 | Reset:          | 0                         | 0           | 0       | 0           | 0            | 0         | 0     | 0       |  |  |
| \$0027                                         | · · · · · · · · · · · · · · · · · · ·         | Read:<br>Write: | Bit 15                    | 14          | 13      | 12          | 11           | 10        | 9     | Bit 8   |  |  |
| See page 308.                                  |                                               | Reset:          | Indeterminate after reset |             |         |             |              |           |       |         |  |  |
| TIMA Channel 0 Register Low<br>\$0028 (TACH0L) | Read:<br>Write:                               | Bit 7           | 6                         | 5           | 4       | 3           | 2            | 1         | Bit 0 |         |  |  |
|                                                | See page 308.                                 | Reset:          | Indeterminate after reset |             |         |             |              |           |       |         |  |  |
| \$0029                                         | TIMA Channel 1 Status<br>and Control Register | Read:           | CH1F                      |             | 0       |             |              | ELS1A     |       | CLIIMAN |  |  |
|                                                |                                               | Write:          | 0                         | CH1IE       | R       | MS1A        | ELS1B        | ELSIA     | TOV1  | CH1MAX  |  |  |
|                                                | (TASC1) See page 304.                         | Reset:          | 0                         | 0           | 0       | 0           | 0            | 0         | 0     | 0       |  |  |
| \$002A                                         | TIMA Channel 1 Register High<br>(TACH1H)      | Read:<br>Write: | Bit 15                    | 14          | 13      | 12          | 11           | 10        | 9     | Bit 8   |  |  |
|                                                | See page 308.                                 | Reset:          |                           |             | I       | ndeterminat | e after rese | t         |       |         |  |  |
| \$002B                                         | TIMA Channel 1 Register Low<br>(TACH1L)       | Read:<br>Write: | Bit 7                     | 6           | 5       | 4           | 3            | 2         | 1     | Bit 0   |  |  |
|                                                | See page 308.                                 | Reset:          |                           |             | I       | ndeterminat | e after rese | t         |       |         |  |  |
|                                                | TIMB Status and Control                       | Read:           | TOF                       | TOIE        | TSTOP   | 0           | 0            | PS2       | PS1   | PS0     |  |  |
| \$002C                                         | Register (TBSC)                               | Write:          | 0                         | TOIL        | ISTOP   | TRST        | R            | F JZ      | FJI   | F 30    |  |  |
|                                                | See page 326.                                 | Reset:          | 0                         | 0           | 1       | 0           | 0            | 0         | 0     | 0       |  |  |
| \$002D                                         | Reserved                                      |                 | R                         | R           | R       | R           | R            | R         | R     | R       |  |  |
|                                                | <b>F</b> '                                    | [               | R                         | ] = Reserve |         | U = Una     |              | F . ( ) ( |       |         |  |  |
|                                                | Figure 2-2. C                                 | ontro           | i, Statu                  | is, and     | Data Re | egisters    | (Sheet       | 5 of 18   | )     |         |  |  |

Figure 2-2. Control, Status, and Data Registers (Sheet 5 of 18)

| Addr.  | Register Name                                                          |                 | Bit 7                     | 6         | 5      | 4           | 3            | 2       | 1        | Bit 0  |
|--------|------------------------------------------------------------------------|-----------------|---------------------------|-----------|--------|-------------|--------------|---------|----------|--------|
|        | TIMB Counter Register High                                             | Read:           | Bit 15                    | 14        | 13     | 12          | 11           | 10      | 9        | Bit 8  |
| \$002E | (TBCNTH)                                                               | Write:          | R                         | R         | R      | R           | R            | R       | R        | R      |
|        | See page 328.                                                          | Reset:          | 0                         | 0         | 0      | 0           | 0            | 0       | 0        | 0      |
|        | TIMB Counter Register Low                                              | Read:           | Bit 7                     | 6         | 5      | 4           | 3            | 2       | 1        | Bit 0  |
| \$002F | (TBCNTL)                                                               | Write:          | R                         | R         | R      | R           | R            | R       | R        | R      |
|        | See page 328.                                                          | Reset:          | 0                         | 0         | 0      | 0           | 0            | 0       | 0        | 0      |
| \$0030 | TIMB Modulo Register High                                              | Read:<br>Write: | Bit 15                    | 14        | 13     | 12          | 11           | 10      | 9        | Bit 8  |
|        | See page 329.                                                          | Reset:          | 1                         | 1         | 1      | 1           | 1            | 1       | 1        | 1      |
| \$0031 | TIMB Modulo Register Low<br>\$0031 (TBMODL)<br>See page 329.           | Read:<br>Write: | Bit 7                     | 6         | 5      | 4           | 3            | 2       | 1        | Bit 0  |
|        |                                                                        | Reset:          | 1                         | 1         | 1      | 1           | 1            | 1       | 1        | 1      |
| \$0032 | TIMB Channel 0 Status and<br>Control Register (TBSC0)<br>See page 330. | Read:<br>Write: | CH0F<br>0                 | CHOIE     | MS0B   | MS0A        | ELS0B        | ELS0A   | TOV0     | CHOMAX |
|        |                                                                        | Reset:          | 0                         | 0         | 0      | 0           | 0            | 0       | 0        | 0      |
| \$0033 | TIMB Channel 0 Register High<br>33 (TBCH0H)                            | Read:<br>Write: | Bit 15                    | 14        | 13     | 12          | 11           | 10      | 9        | Bit 8  |
|        | See page 334.                                                          | Reset:          | Indeterminate after reset |           |        |             |              |         |          |        |
| \$0034 | TIMB Channel 0 Register Low<br>(TBCH0L)                                | Read:<br>Write: | Bit 7                     | 6         | 5      | 4           | 3            | 2       | 1        | Bit 0  |
|        | See page 334.                                                          | Reset:          |                           |           | l      | ndeterminat | e after rese | et      |          |        |
|        | TIMB Channel 1 Status and                                              | Read:           | CH1F                      |           | 0      |             | EL 04 D      | 51.044  | TO1/4    |        |
| \$0035 | Control Register (TBSC1)                                               | Write:          | 0                         | CH1IE     | R      | MS1A        | ELS1B        | ELS1A   | TOV1     | CH1MAX |
|        | See page 330.                                                          | Reset:          | 0                         | 0         | 0      | 0           | 0            | 0       | 0        | 0      |
| \$0036 | TIMB Channel 1 Register High<br>(TBCH1H)                               | Read:<br>Write: | Bit 15                    | 14        | 13     | 12          | 11           | 10      | 9        | Bit 8  |
|        | See page 334.                                                          | Reset:          |                           |           | I      | ndeterminat | e after rese | t       |          |        |
|        |                                                                        | ſ               | R                         | = Reserve | ed     | U = Una     | affected     |         |          |        |
|        |                                                                        | ontro           | L Statu                   |           | Data D | alictore    | (Shaat       | 6 of 10 | <b>\</b> |        |

Figure 2-2. Control, Status, and Data Registers (Sheet 6 of 18)

MC68HC08QA24

| Addr.  | Register Name                                      |                 | Bit 7 | 6         | 5      | 4           | 3            | 2         | 1        | Bit 0  |
|--------|----------------------------------------------------|-----------------|-------|-----------|--------|-------------|--------------|-----------|----------|--------|
| \$0037 | TIMB Channel 1 Register Low<br>(TBCH1L)            | Read:<br>Write: | Bit 7 | 6         | 5      | 4           | 3            | 2         | 1        | Bit 0  |
|        | See page 334.                                      | Reset:          |       |           | I      | ndeterminat | e after rese | t         |          |        |
|        | Analog-to-Digital Status                           | Read:           | COCO  | AIEN      | ADCO   | ADCH4       | ADCH3        | ADCH2     | ADCH1    | ADCH0  |
| \$0038 | and Control Register                               | Write:          | R     |           | ADCO   |             | АДСПЗ        | ADCHZ     | ADCHI    |        |
|        | (ADSCR) See page 279.                              | Reset:          | 0     | 0         | 0      | 1           | 1            | 1         | 1        | 1      |
|        | Analog-to-Digital                                  | Read:           | AD7   | AD6       | AD5    | AD4         | AD3          | AD2       | AD1      | AD0    |
| \$0039 | Data Register                                      | Write:          | R     | R         | R      | R           | R            | R         | R        | R      |
|        | (ADR) See page 282.                                | Reset:          |       |           | I      | ndeterminat | e after rese | t         |          |        |
|        | Analog-to-Digital Input                            | Read:           | ADIV2 | ADIV1     | ADIV0  | ADICLK      | 0            | 0         | 0        | 0      |
| \$003A | Clock Register                                     | Write:          | ADIVZ | ADIVI     | ADIVU  | ADICLK      | R            | R         | R        | R      |
|        | (ADICLK) See page 282.                             | Reset:          | 0     | 0         | 0      | 0           | 0            | 0         | 0        | 0      |
|        | CAN Module Control                                 | Read:           | 0     | 0         | 0      | SYNCH       |              | SLPAK     | SLPRQ    | SFTRES |
| \$0500 | Register 0                                         | Write:          | R     | R         | R      | R           | TLNKEN       | R         | JLPKU    | SFIRES |
|        | (CMCR0) See page 365.                              | Reset:          | 0     | 0         | 0      | 0           | 0            | 0         | 0        | 0      |
|        | CAN Module Control                                 | Read:           | 0     | 0         | 0      | 0           | 0            | LOOPB     | WUPM     | CLKSRC |
| \$0501 | Register 1                                         | Write:          | R     | R         | R      | R           | R            | LUUPD     | WUFIVI   | CLKSKC |
|        | (CMCR1) See page 367.                              | Reset:          | 0     | 0         | 0      | 0           | 0            | 0         | 0        | 0      |
| \$0502 | CAN Bus Timing Register 0<br>(CBTR0) See page 368. | Read:<br>Write: | SJW1  | SJW0      | BRP5   | BRP4        | BRP3         | BRP2      | BRP1     | BRP0   |
|        | (, pg                                              | Reset:          | 0     | 0         | 0      | 0           | 0            | 0         | 0        | 0      |
| \$0503 | CAN Bus Timing Register 1<br>(CBTR1) See page 369. | Read:<br>Write: | SAMP  | TSEG22    | TSEG21 | TSEG20      | TSEG13       | TSEG12    | TSEG11   | TSEG10 |
|        |                                                    | Reset:          | 0     | 0         | 0      | 0           | 0            | 0         | 0        | 0      |
| \$0504 | CAN Receiver Flag Register<br>(CRFLG)              | Read:<br>Write: | WUPF  | RWRNIF    | TWRNIF | RERRIF      | TERRIF       | BOFFIF    | OVRIF    | RXF    |
|        | See page 371.                                      | Reset:          | 0     | 0         | 0      | 0           | 0            | 0         | 0        | 0      |
|        |                                                    |                 | R     | = Reserve | ed     | U = Una     | affected     |           |          |        |
|        |                                                    |                 | 04-44 |           |        |             |              | 7 - 6 4 0 | <b>`</b> |        |

Figure 2-2. Control, Status, and Data Registers (Sheet 7 of 18)

**Technical Data** 

| Addr.        | Register Name                                                     |                 | Bit 7  | 6         | 5       | 4          | 3        | 2      | 1      | Bit 0  |
|--------------|-------------------------------------------------------------------|-----------------|--------|-----------|---------|------------|----------|--------|--------|--------|
| \$0505       | CAN Receiver Interrupt<br>Enable Register                         | Read:<br>Write: | WUPIE  | RWRNIE    | TWRNIE  | RERRIE     | TERRIE   | BOFFIE | OVRIE  | RXFIE  |
|              | (CRIER) See page 373.                                             | Reset:          | 0      | 0         | 0       | 0          | 0        | 0      | 0      | 0      |
|              | CAN Transmitter                                                   | Read:           | 0      | ABTAK2    | ABTAK1  | ABTAK0     | 0        | туга   | ΤΥΓ1   | ΤΥΓΩ   |
| \$0506       | Flag Register                                                     | Write:          | R      | R         | R       | R          | R        | TXE2   | TXE1   | TXE0   |
|              | (CTFLG) See page 374.                                             | Reset:          | 0      | 0         | 0       | 0          | 0        | 1      | 1      | 1      |
|              | CAN Transmitter                                                   | Read:           | 0      | ABTRQ2    | ABTRQ1  | ABTRQ0     | 0        | TXEIE2 | TXEIE1 | TXEIE0 |
| \$0507       | Control Register                                                  | Write:          | R      | ADIKUZ    | ADIKUI  | ADIKUU     | R        | INCIEZ | INCICI | INCIEU |
|              | (CTCR) See page 375.                                              | Reset:          | 0      | 0         | 0       | 0          | 0        | 1      | 1      | 1      |
| \$0508       | CAN Identifier Acceptance                                         | Read:           | 0      | 0         | IDAM1   | IDAM0      | 0        | 0      | IDHIT1 | IDHIT0 |
| 90006        | Control Register                                                  | Write:          | R      | R         | IDAIIII | IDAINU     | R        | R      | R      | R      |
|              | (CIDAC) See page 376.                                             | Reset:          | 0      | 0         | 0       | 0          | 0        | 0      | 0      | 0      |
| \$0509       | Reserved                                                          |                 | R      | R         | R       | R          | R        | R      | R      | R      |
| $\downarrow$ | $\downarrow$                                                      | ·               |        |           |         |            |          |        |        |        |
| \$050D       | Reserved                                                          |                 | R      | R         | R       | R          | R        | R      | R      | R      |
|              |                                                                   | ·               |        |           |         |            |          |        |        |        |
|              | CAN Receiver Error                                                | Read:           | RXERR7 | RXERR6    | RXERR5  | RXERR4     | RXERR3   | RXERR2 | RXERR1 | RXERR0 |
| \$050E       | Counter Register                                                  | Write:          | R      | R         | R       | R          | R        | R      | R      | R      |
|              | (CRXERR) See page 378.                                            | Reset:          | 0      | 0         | 0       | 0          | 0        | 0      | 0      | 0      |
|              | CAN Transmitter Error                                             | Read:           | TXERR7 | TXERR6    | TXERR5  | TXERR4     | TXERR3   | TXERR2 | TXERR1 | TXERR0 |
| \$050F       | Counter Register                                                  | Write:          | R      | R         | R       | R          | R        | R      | R      | R      |
|              | (CTXERR) See page 378.                                            | Reset:          | 0      | 0         | 0       | 0          | 0        | 0      | 0      | 0      |
| \$0510       | CAN Identifier Acceptance<br>Register 0<br>(CIDAR0) See page 379. | Read:<br>Write: | AC7    | AC6       | AC5     | AC4        | AC3      | AC2    | AC1    | AC0    |
|              |                                                                   | Reset:          |        | 1         |         | Unaffected | 5        |        |        |        |
|              |                                                                   |                 | R      | = Reserve | ed      | U = Una    | offected |        |        |        |

Figure 2-2. Control, Status, and Data Registers (Sheet 8 of 18)

| Addr.  | Register Name                                                  | _               | Bit 7 | 6         | 5    | 4          | 3          | 2    | 1    | Bit 0 |
|--------|----------------------------------------------------------------|-----------------|-------|-----------|------|------------|------------|------|------|-------|
| \$0511 | CAN Identifier Acceptance<br>Register 1                        | Read:<br>Write: | AC7   | AC6       | AC5  | AC4        | AC3        | AC2  | AC1  | AC0   |
|        | (CIDAR1) See page 379.                                         | Reset:          |       |           |      | Unaffected | d by reset |      |      |       |
| \$0512 | CAN Identifier Acceptance<br>Register 2                        | Read:<br>Write: | AC7   | AC6       | AC5  | AC4        | AC3        | AC2  | AC1  | AC0   |
|        | (CIDAR2) See page 379.                                         | Reset:          |       |           |      | Unaffected | d by reset |      |      |       |
| \$0513 | CAN Identifier Acceptance<br>Register 3                        | Read:<br>Write: | AC7   | AC6       | AC5  | AC4        | AC3        | AC2  | AC1  | AC0   |
|        | (CIDAR3) See page 379.                                         | Reset:          |       |           |      | Unaffected | d by reset |      |      |       |
| \$0514 | CAN Identifier Mask<br>Register 0                              | Read:<br>Write: | AM7   | AM6       | AM5  | AM4        | AM3        | AM2  | AM1  | AM0   |
|        | (CIDMR0) See page 381.                                         | Reset:          |       |           |      | Unaffected | d by reset |      |      |       |
| \$0515 | CAN Identifier Mask<br>Register 1                              | Read:<br>Write: | AM7   | AM6       | AM5  | AM4        | AM3        | AM2  | AM1  | AM0   |
|        | (CIDMR1) See page 381.                                         | Reset:          |       |           |      | Unaffected | d by reset |      |      |       |
| \$0516 | CAN Identifier Mask<br>Register 0                              | Read:<br>Write: | AM7   | AM6       | AM5  | AM4        | AM3        | AM2  | AM1  | AM0   |
|        | (CIDMR0) See page 381.                                         | Reset:          |       |           |      | Unaffected | d by reset |      |      |       |
| \$0517 | CAN Identifier Mask<br>Register 1                              | Read:<br>Write: | AM7   | AM6       | AM5  | AM4        | AM3        | AM2  | AM1  | AM0   |
|        | (CIDMR1) See page 381.                                         | Reset:          |       |           |      | Unaffected | d by reset |      |      |       |
| \$0540 | CAN Receive Identifier<br>Register 0                           | Read:<br>Write: | ID28  | ID27      | ID26 | ID25       | ID24       | ID23 | ID22 | ID21  |
|        | (CRIDR0) See page 360.                                         | Reset:          |       |           |      | Unaffected | d by reset |      |      |       |
| \$0541 | CAN Receive Identifier<br>Register 1<br>(CRIDR1) See page 360. | Read:<br>Write: | ID20  | ID19      | ID16 | SRR(1)     | IDE(1)     | ID17 | ID16 | ID15  |
|        | (UNIDICI) See page 300.                                        | Reset:          |       | 1         |      | Unaffected | d by reset |      |      |       |
|        | Eiguro 2.2 C                                                   |                 | R     | = Reserve |      | U = Una    |            |      | _    |       |

Figure 2-2. Control, Status, and Data Registers (Sheet 9 of 18)

**Technical Data** 

| \$0542CAN Receive Identifier<br>Register 2<br>(CRIDR2) See page 360.<br>Reset:Read:<br>ID14ID13ID12ID11ID10ID9ID8ID7\$0543CAN Receive Identifier<br>Register 3<br>(CRIDR3) See page 360.<br>(CRIDR3) See page 360.<br>Reset:Read:<br>ID6ID5ID4ID3ID2ID1ID0RTR\$0543CAN Receiver Data<br>Segment Register 3<br>(CRIDSR0) See page 361.<br>(CRIDSR0) See page 361.<br>(CRIDSR1) See page 361.<br>(CRIDSR2) See page 361.Read:<br>DB7DB6DB5DB4DB3DB2DB1DB0\$0546CAN Receiver Data<br>Register 1<br>(CRDSR1) See page 361.<br>(CRDSR2) See page 361.<br>(CRDSR2) See page 361.Read:<br>DB7DB6DB5DB4DB3DB2DB1DB0\$0546CAN Receiver Data Segment<br>Register 2<br>(CRDSR2) See page 361.<br>(CRDSR3) See page 361.Read:<br>Read:<br>DB7DB6DB5DB4DB3DB2DB1DB0\$0547CAN Receiver Data Segment<br>Register 4<br>(CRDSR3) See page 361.<br>(CRDSR3) See page 361.Read:<br>Read:<br>(DB7DB6DB5DB4DB3DB2DB1DB0\$0548CAN Receiver Data Segment<br>Register 4<br>(CRDSR4) See page 361.<br>(CRDSR5) See page 361.Read:<br>(DB7DB6DB5DB4DB3DB2DB1DB0\$0544CAN Receiver Data Segment<br>Register 4<br>(CRDSR4) See page 361.<br>(CRDSR5) See page 361.Read:<br>(DB7DB6DB5DB4DB3DB2DB1DB0\$0544CAN Receiver Data Segment<br>Register 4<br>(CRDSR5) See page 36                                                                                                                                                                                                                                                                                                                                                                                                              | Addr.  | Register Name          |        | Bit 7 | 6         | 5    | 4          | 3          | 2   | 1   | Bit 0      |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|------------------------|--------|-------|-----------|------|------------|------------|-----|-----|------------|
| KestUnaffected by reset\$0543CAN Receive Identifier<br>Register 3<br>(CRIDR3) See page 360.<br>(CRDR3) See page 361.<br>Segment Register 0<br>(CRDSR0) See page 361.<br>Reset:Read:<br>DB7DB6DB5DB4DB3DB2DB1DB0\$0544CAN Receiver Data<br>Segment Register 0<br>(CRDSR0) See page 361.<br>(CRDSR1) See page 361.<br>(CRDSR1) See page 361.<br>(CRDSR2) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0\$0546CAN Receiver Data Segment<br>Register 1<br>(CRDSR1) See page 361.<br>(CRDSR2) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0\$0547CAN Receiver Data Segment<br>Register 4<br>(CRDSR3) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0\$0548CAN Receiver Data Segment<br>Register 3<br>(CRDSR3) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0\$0549CAN Receiver Data Segment<br>Register 4<br>(CRDSR4) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0\$0544CAN Receiver Data Segment<br>Register 3<br>(CRDSR5) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0\$0544CAN Receiver Data Segment<br>Register 6<br>(CRDSR4) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0\$0544CAN Receiver Data Segment<br><td>\$0542</td> <td>Register 2</td> <td></td> <td>ID14</td> <td>ID13</td> <td>ID12</td> <td>ID11</td> <td>ID10</td> <td>ID9</td> <td>ID8</td> <td>ID7</td>                                                                                                                                                                                                                                                                                                                                     | \$0542 | Register 2             |        | ID14  | ID13      | ID12 | ID11       | ID10       | ID9 | ID8 | ID7        |
| CAN Receive Identifier<br>(CRIDR3) See page 360.<br>Segment Register 3<br>(CRDSR0) See page 361.ID6ID5ID4ID3ID2ID1ID0RTR\$0543CAN Receiver Data<br>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |        | (CRIDR2) See page 360. | Reset: |       |           |      | Unaffected | l by reset |     |     |            |
| CAN Receiver Data<br>Segment Register 0     Read:<br>CAN Receiver Data Segment<br>Register 1     DB7     DB6     DB5     DB4     DB3     DB2     DB1     DB0       \$0544     Segment Register 0     Write:     DB7     DB6     DB5     DB4     DB3     DB2     DB1     DB0       \$0545     CAN Receiver Data Segment<br>Register 1     Read:<br>Write:     DB7     DB6     DB5     DB4     DB3     DB2     DB1     DB0       \$0546     CAN Receiver Data Segment<br>Register 2     Read:<br>Write:     DB7     DB6     DB5     DB4     DB3     DB2     DB1     DB0       \$0546     CAN Receiver Data Segment<br>Register 3     Read:<br>(CRDSR3) See page 361.<br>(CRDSR3) See page 361.<br>(CRDSR4) See page 361.<br>(CRDSR5) See page 361.<br>(CRDSR6) See page 361.<br>(CRDSR5) See page 361.<br>(CRDSR5) See page 361.<br>(CRDSR5) See page 361.<br>(CRDSR6) See | \$0543 | Register 3             |        | ID6   | ID5       | ID4  | ID3        | ID2        | ID1 | ID0 | RTR        |
| S0544CAN Receiver Data<br>Segment Register 0<br>(CRDSR0) See page 361)DB7DB6DB5DB4DB3DB2DB1DB0S0545CAN Receiver Data Segment<br>Register 1<br>(CRDSR1) See page 361)Read:<br>Reset:DB7DB6DB5DB4DB3DB2DB1DB0S0545CAN Receiver Data Segment<br>Register 2<br>(CRDSR2) See page 361)Read:<br>Read:DB7DB6DB5DB4DB3DB2DB1DB0S0546CAN Receiver Data Segment<br>(CRDSR2) See page 361)Read:<br>Register 3<br>(CRDSR3) See page 361)DB7DB6DB5DB4DB3DB2DB1DB0S0547CAN Receiver Data Segment<br>(CRDSR4) See page 361)Read:<br>Register 3<br>(CRDSR4) See page 361)DB7DB6DB5DB4DB3DB2DB1DB0S0548CAN Receiver Data Segment<br>(CRDSR4) See page 361)Read:<br>Register 4<br>(CRDSR4) See page 361)DB7DB6DB5DB4DB3DB2DB1DB0S0549CAN Receiver Data Segment<br>(CRDSR6) See page 361)Read:<br>Reset:DB7DB6DB5DB4DB3DB2DB1DB0S0544CAN Receiver Data Segment<br>(CRDSR6) See page 361)Read:<br>Reset:DB7DB6DB5DB4DB3DB2DB1DB0S0544CAN Receiver Data Segment<br>(CRDSR6) See page 361)Read:<br>Reset:DB7DB6DB5DB4DB3DB2DB1DB0S0544CAN Receiver Data Segment<br>(CRDSR6) See page 361) <t< td=""><td></td><td>(CRIDR3) See page 360.</td><td>Reset:</td><td></td><td></td><td></td><td>Unaffected</td><td>l by reset</td><td></td><td></td><td>I]</td></t<>                                                                                                                                                                                                                                                                                                                                                                                                                   |        | (CRIDR3) See page 360. | Reset: |       |           |      | Unaffected | l by reset |     |     | I]         |
| CAN Receiver Data Segment<br>Register 1<br>(CRDSR1) See page 361.     Read:<br>Write:     DB7     DB6     DB5     DB4     DB3     DB2     DB1     DB0       \$0546     CAN Receiver Data Segment<br>Register 2<br>(CRDSR2) See page 361.     Read:<br>Reset:     Unaffected by reset     Unaffected by reset       \$0546     CAN Receiver Data Segment<br>Register 2<br>(CRDSR2) See page 361.     Read:<br>Reset:     DB7     DB6     DB5     DB4     DB3     DB2     DB1     DB0       \$0547     CAN Receiver Data Segment<br>Register 3<br>(CRDSR3) See page 361.     Read:<br>Reset:     DB7     DB6     DB5     DB4     DB3     DB2     DB1     DB0       \$0547     CAN Receiver Data Segment<br>Register 3<br>(CRDSR4) See page 361.     Read:<br>Reset:     DB7     DB6     DB5     DB4     DB3     DB2     DB1     DB0       \$0548     CAN Receiver Data Segment<br>Register 4<br>(CRDSR4) See page 361.     Read:<br>Reset:     DB7     DB6     DB5     DB4     DB3     DB2     DB1     DB0       \$0549     CAN Receiver Data Segment<br>Register 5<br>(CRDSR5) See page 361.     Read:<br>Write:     DB7     DB6     DB5     DB4     DB3     DB2     DB1     DB0       \$0544     CAN Receiver Data Segment<br>Regist                                                                                                                                                                                                                                                                                                                                                                                                                       | \$0544 | Segment Register 0     |        | DB7   | DB6       | DB5  | DB4        | DB3        | DB2 | DB1 | DB0        |
| CAN Receiver Data Segment<br>Register 1<br>(CRDSR1) See page 361.DB7DB6DB5DB4DB3DB2DB1DB0S0546CAN Receiver Data Segment<br>Register 2<br>(CRDSR2) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0S0546CAN Receiver Data Segment<br>Register 3<br>(CRDSR3) See page 361.Read:<br>Reset:DB7DB6DB5DB4DB3DB2DB1DB0S0547CAN Receiver Data Segment<br>Register 3<br>(CRDSR3) See page 361.Read:<br>Reset:DB7DB6DB5DB4DB3DB2DB1DB0S0548CAN Receiver Data Segment<br>Register 4<br>(CRDSR4) See page 361.Read:<br>Read:<br>Register 5DB7DB6DB5DB4DB3DB2DB1DB0S0549CAN Receiver Data Segment<br>Register 6<br>(CRDSR5) See page 361.Read:<br>Read:<br>Read:<br>DB7DB6DB5DB4DB3DB2DB1DB0S0544CAN Receiver Data Segment<br>Register 6<br>(CRDSR5) See page 361.Read:<br>Read:<br>Read:<br>DB7DB6DB5DB4DB3DB2DB1DB0S0544CAN Receiver Data Segment<br>Register 6<br>(CRDSR6) See page 361.Read:<br>Write:<br>Read:<br>DB7DB6DB5DB4DB3DB2DB1DB0S0544CAN Receiver Data Segment<br>Register 6<br>(CRDSR6) See page 361.Read:<br>Write:<br>Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0S0544CAN Receiver Data Segmen                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |        | (CRDSR0) See page 361. | Reset: |       |           |      | Unaffected | l by reset |     |     |            |
| CAN Receiver Data Segment<br>Register 2<br>(CRDSR2) See page 361.     Read:<br>Write:<br>(CRDSR2) See page 361.     DB7     DB6     DB5     DB4     DB3     DB2     DB1     DB0       \$0546     (CRDSR2) See page 361.<br>(CRDSR3) See page 361.     Read:<br>Write:     DB7     DB6     DB5     DB4     DB3     DB2     DB1     DB0       \$0547     CAN Receiver Data Segment<br>Register 3     Read:<br>Write:     DB7     DB6     DB5     DB4     DB3     DB2     DB1     DB0       \$0547     CAN Receiver Data Segment<br>(CRDSR3) See page 361.     Read:<br>Reset:     DB7     DB6     DB5     DB4     DB3     DB2     DB1     DB0       \$0548     CAN Receiver Data Segment<br>(CRDSR4) See page 361.     Read:<br>Read:     DB7     DB6     DB5     DB4     DB3     DB2     DB1     DB0       \$0549     CAN Receiver Data Segment<br>(CRDSR5) See page 361.     Read:<br>Read:     DB7     DB6     DB5     DB4     DB3     DB2     DB1     DB0       \$0549     CAN Receiver Data Segment<br>(CRDSR6) See page 361.     Read:<br>Write:     DB7     DB6     DB5     DB4     DB3     DB2     DB1     DB0       \$0544     CAN Receiv                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | \$0545 | Register 1             |        | DB7   | DB6       | DB5  | DB4        | DB3        | DB2 | DB1 | DB0        |
| CAN Receiver Data Segment<br>Register 2<br>(CRDSR2) See page 361.DB7DB6DB5DB4DB3DB2DB1DB0\$0546(CRDSR2) See page 361.Reset:Unaffected by reset\$0547CAN Receiver Data Segment<br>Register 3<br>(CRDSR3) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0\$0548CAN Receiver Data Segment<br>Register 4<br>(CRDSR4) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0\$0548CAN Receiver Data Segment<br>Register 4<br>(CRDSR4) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0\$0549CAN Receiver Data Segment<br>Register 5<br>(CRDSR5) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0\$0549CAN Receiver Data Segment<br>Register 5<br>(CRDSR5) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0\$0544CAN Receiver Data Segment<br>Register 6<br>(CRDSR6) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0\$0544CAN Receiver Data Segment<br>Register 6<br>(CRDSR6) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0\$0544Receiver Data Segment<br>Register 6<br>(CRDSR6) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0 <tr<< td=""><td></td><td>(CRDSR1) See page 361.</td><td>Reset:</td><td></td><td></td><td></td><td>Unaffected</td><td>l by reset</td><td></td><td></td><td></td></tr<<>                                                                                                                                                                                                                                                                                                                                                                                                                          |        | (CRDSR1) See page 361. | Reset: |       |           |      | Unaffected | l by reset |     |     |            |
| Keset:Unaffected by reset\$0547CAN Receiver Data Segment<br>Register 3<br>(CRDSR3) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0\$0548CAN Receiver Data Segment<br>Register 4<br>(CRDSR4) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0\$0548CAN Receiver Data Segment<br>Register 5<br>(CRDSR4) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0\$0549CAN Receiver Data Segment<br>Register 5<br>(CRDSR5) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0\$0544CAN Receiver Data Segment<br>Register 5<br>(CRDSR5) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0\$0544CAN Receiver Data Segment<br>Register 6<br>(CRDSR6) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0 <t< td=""><td>\$0546</td><td>Register 2</td><td></td><td>DB7</td><td>DB6</td><td>DB5</td><td>DB4</td><td>DB3</td><td>DB2</td><td>DB1</td><td>DB0</td></t<>                                                                                                                                                                                                                                                                                                                                                                                                                                         | \$0546 | Register 2             |        | DB7   | DB6       | DB5  | DB4        | DB3        | DB2 | DB1 | DB0        |
| CAN Receiver Data Segment<br>Register 3<br>(CRDSR3) See page 361.DB7DB6DB5DB4DB3DB2DB1DB0\$0547(CRDSR3) See page 361.<br>(CRDSR4) See page 361.Write:<br>Reset:Write:<br>DB7DB6DB5DB4DB3DB2DB1DB0\$0548CAN Receiver Data Segment<br>(CRDSR4) See page 361.Read:<br>Register 4DB7DB6DB5DB4DB3DB2DB1DB0\$0549CAN Receiver Data Segment<br>Register 5<br>(CRDSR5) See page 361.Read:<br>Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0\$0544CAN Receiver Data Segment<br>Register 5<br>(CRDSR5) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0\$0544CAN Receiver Data Segment<br>Register 6<br>(CRDSR6) See page 361.B7DB6DB5DB4DB3DB2DB1DB0\$0544CAN Receiver Data Segment<br>Register 6<br>(CRDSR6) See page 361.DB7DB6DB5DB4DB3DB2DB1DB0\$0544CAN Receiver Data Segment<br>Register 6<br>(CRDSR6) See page 361.DB7DB6DB5DB4DB3DB2DB1DB0\$0544CAN Receiver Data Segment<br>Register 6<br>(CRDSR6) See page 361.DB7DB6DB5DB4DB3DB2DB1DB0\$0544CAN Receiver Data Segment<br>Register 6<br>(CRDSR6) See page 361.DB7DB6DB5DB4DB3DB2DB1DB0\$0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |        | (CRDSR2) See page 361. | Reset: |       |           |      | Unaffected | l by reset |     |     |            |
| Reset:     Unaffected by reset       \$0548     CAN Receiver Data Segment<br>Register 4<br>(CRDSR4) See page 361.     Read:<br>Write:     DB7     DB6     DB5     DB4     DB3     DB2     DB1     DB0       \$0548     CAN Receiver Data Segment<br>Register 5<br>(CRDSR5) See page 361.     Read:<br>Write:     DB7     DB6     DB5     DB4     DB3     DB2     DB1     DB0       \$0549     CAN Receiver Data Segment<br>Register 5<br>(CRDSR5) See page 361.     Read:<br>Write:     DB7     DB6     DB5     DB4     DB3     DB2     DB1     DB0       \$0544     CAN Receiver Data Segment<br>Register 6<br>(CRDSR6) See page 361.     B7     DB6     DB5     DB4     DB3     DB2     DB1     DB0       \$0544     CAN Receiver Data Segment<br>Register 6<br>(CRDSR6) See page 361.     DB7     DB6     DB5     DB4     DB3     DB2     DB1     DB0       \$0544     CAN Receiver Data Segment<br>Register 6     B7     DB6     DB5     DB4     DB3     DB2     DB1     DB0       \$0544     CAN Receiver Data Segment<br>Register 6     CB7     DB6     DB5     DB4     DB3     DB2     DB1     DB0       Reset:     Unaffected b                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | \$0547 | Register 3             |        | DB7   | DB6       | DB5  | DB4        | DB3        | DB2 | DB1 | DB0        |
| CAN Receiver Data Segment<br>Register 4<br>(CRDSR4) See page 361.DB7DB6DB5DB4DB3DB2DB1DB0\$0549CAN Receiver Data Segment<br>Register 5<br>(CRDSR5) See page 361.Write:<br>Read:<br>(DB7DB6DB5DB4DB3DB2DB1DB0\$054ACAN Receiver Data Segment<br>Register 6<br>(CRDSR6) See page 361.Read:<br>Write:<br>DB7DB6DB5DB4DB3DB2DB1DB0\$054ACAN Receiver Data Segment<br>Register 6<br>(CRDSR6) See page 361.Read:<br>Write:<br>DB7DB6DB5DB4DB3DB2DB1DB0\$054ACAN Receiver Data Segment<br>Register 6<br>(CRDSR6) See page 361.Read:<br>Write:<br>DB7DB6DB5DB4DB3DB2DB1DB0\$054ACAN Receiver Data Segment<br>Register 6<br>(CRDSR6) See page 361.Read:<br>Write:<br>Read:<br>DB7DB6DB5DB4DB3DB2DB1DB0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |        | (CRDSR3) See page 361. | Reset: |       |           |      | Unaffected | l by reset |     |     | . <u> </u> |
| Kest:     Unaffected by reset       CAN Receiver Data Segment<br>Register 5<br>(CRDSR5) See page 361.     Read:<br>Write:     DB7     DB6     DB5     DB4     DB3     DB2     DB1     DB0       \$0549     CAN Receiver Data Segment<br>(CRDSR5) See page 361.     Read:<br>Reset:     DB7     DB6     DB5     DB4     DB3     DB2     DB1     DB0       \$054A     CAN Receiver Data Segment<br>Register 6<br>(CRDSR6) See page 361.     Read:<br>Write:     DB7     DB6     DB5     DB4     DB3     DB2     DB1     DB0       \$054A     CAN Receiver Data Segment<br>Register 6<br>(CRDSR6) See page 361.     DB7     DB6     DB5     DB4     DB3     DB2     DB1     DB0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | \$0548 | Register 4             |        | DB7   | DB6       | DB5  | DB4        | DB3        | DB2 | DB1 | DB0        |
| CAN Receiver Data Segment<br>Register 5<br>(CRDSR5) See page 361.DB7DB6DB5DB4DB3DB2DB1DB0\$0549Register 5<br>(CRDSR5) See page 361.Write:<br>Reset:DB7DB6DB5DB4DB3DB2DB1DB0\$054ACAN Receiver Data Segment<br>Register 6<br>(CRDSR6) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0\$054ARegister 6<br>(CRDSR6) See page 361.Read:<br>Reset:DB7DB6DB5DB4DB3DB2DB1DB0\$054ARegister 6<br>(CRDSR6) See page 361.Reset:Unaffected by resetUnaffected by resetUnaffected by reset                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |        | (CRDSR4) See page 361. | Reset: |       |           |      | Unaffected | l by reset |     |     |            |
| CAN Receiver Data Segment     Read:<br>Mrite:     DB7     DB6     DB5     DB4     DB3     DB2     DB1     DB0       \$054A     Register 6<br>(CRDSR6) See page 361.     Write:     DB7     DB6     DB5     DB4     DB3     DB2     DB1     DB0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | \$0549 | Register 5             |        | DB7   | DB6       | DB5  | DB4        | DB3        | DB2 | DB1 | DB0        |
| CAN Receiver Data Segment DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0 (CRDSR6) See page 361.<br>Reset: Unaffected by reset                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |        | (CRDSR5) See page 361. | Reset: |       |           |      | Unaffected | l by reset |     | -   | ·]         |
| Reset: Unaffected by reset                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | \$054A | Register 6             |        | DB7   | DB6       | DB5  | DB4        | DB3        | DB2 | DB1 | DB0        |
| R = Reserved U = Unaffected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |        | CINDONOJ SEE Page 301. | Reset: |       | 1         |      | Unaffected | l by reset |     |     |            |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |        |                        |        | R     | = Reserve | ed   | U = Una    | ffected    |     |     |            |



MC68HC08QA24

| Addr.        | Register Name                                                         |                 | Bit 7  | 6         | 5    | 4          | 3          | 2    | 1        | Bit 0 |
|--------------|-----------------------------------------------------------------------|-----------------|--------|-----------|------|------------|------------|------|----------|-------|
| \$054B       | CAN Receiver Data Segment<br>Register 7                               | Read:<br>Write: | DB7    | DB6       | DB5  | DB4        | DB3        | DB2  | DB1      | DB0   |
|              | (CRDSR7) See page 361.<br>F                                           | Reset:          |        |           |      | Unaffected | d by reset |      |          |       |
| \$054C       | CAN Receiver Data Length                                              | Read:<br>Write: | DB7    | DB6       | DB5  | DB4        | DB3        | DB2  | DB1      | DB0   |
|              | (CRDSR7) See page 501.                                                | Reset:          |        |           |      | Unaffected | d by reset |      |          |       |
| \$054D       | Reserved                                                              |                 | R      | R         | R    | R          | R          | R    | R        | R     |
| $\downarrow$ | $\downarrow$                                                          | _               |        |           |      |            |            |      |          |       |
| \$054F       | Reserved                                                              | ſ               | R      | R         | R    | R          | R          | R    | R        | R     |
|              |                                                                       | L               |        |           |      |            |            |      |          |       |
| \$0550       | CAN Transmit 0 Identifier<br>Register 0                               | Read:<br>Write: | ID28   | ID27      | ID26 | ID25       | ID24       | ID23 | ID22     | ID21  |
|              | (CT0IDR0) See page 360.<br>F                                          | Reset:          |        |           |      | Unaffected | d by reset |      |          |       |
| \$0551       | CAN Transmit 0 Identifier<br>Register 1                               | Read:<br>Write: | ID20   | ID19      | ID16 | SRR(1)     | IDE(1)     | ID17 | ID16     | ID15  |
|              | (CT0IDR1) See page 360.<br>F                                          | Reset:          |        | 1         |      | Unaffected | d by reset |      |          |       |
| \$0552       | CAN Transmit 0 Identifier<br>Register 2                               | Read:<br>Write: | ID14   | ID13      | ID12 | ID11       | ID10       | ID9  | ID8      | ID7   |
|              | (CT0IDR2) See page 360.<br>F                                          | Reset:          |        |           |      | Unaffected | d by reset |      |          |       |
| \$0553       | CAN Transmit 0 Identifier<br>Register 3                               | Read:<br>Write: | ID6    | ID5       | ID4  | ID3        | ID2        | ID1  | ID0      | RTR   |
|              | (CT0IDR3) See page 360.<br>F                                          | Reset:          |        |           |      | Unaffected | d by reset |      |          |       |
| \$0554       | CAN Transmit 0 Data Segment<br>Register 0 \<br>(CT0DSR0) See page 361 | Read:<br>Write: | DB7    | DB6       | DB5  | DB4        | DB3        | DB2  | DB1      | DB0   |
|              | F                                                                     | Reset:          |        |           |      | Unaffected | d by reset |      |          |       |
|              |                                                                       |                 | R      | = Reserve | ed   | U = Una    | iffected   |      |          |       |
|              |                                                                       |                 | 01-1-1 |           |      |            | (Ol ( )    | A    | <b>^</b> |       |

Figure 2-2. Control, Status, and Data Registers (Sheet 11 of 18)

54

| Addr.  | Register Name                                                         |                 | Bit 7 | 6         | 5   | 4          | 3          | 2   | 1   | Bit 0 |
|--------|-----------------------------------------------------------------------|-----------------|-------|-----------|-----|------------|------------|-----|-----|-------|
| \$0555 | CAN Transmit 0 Data Segment<br>Register 1                             | Read:<br>Write: | DB7   | DB6       | DB5 | DB4        | DB3        | DB2 | DB1 | DB0   |
|        | (CT0DSR1) See page 361.                                               | Reset:          |       |           |     | Unaffected | l by reset |     |     |       |
| \$0556 | CAN Transmit 0 Data Segment<br>Register 2                             | Read:<br>Write: | DB7   | DB6       | DB5 | DB4        | DB3        | DB2 | DB1 | DB0   |
|        | (CT0DSR2) See page 361.                                               | Reset:          |       |           |     | Unaffected | l by reset |     |     |       |
| \$0557 | CAN Transmit 0 Data Segment<br>Register 3                             | Read:<br>Write: | DB7   | DB6       | DB5 | DB4        | DB3        | DB2 | DB1 | DB0   |
|        | (CT0DSR3) See page 361.                                               | Reset:          |       |           |     | Unaffected | l by reset |     |     |       |
| \$0558 | CAN Transmit 0 Data Segment<br>Register 4                             | Read:<br>Write: | DB7   | DB6       | DB5 | DB4        | DB3        | DB2 | DB1 | DB0   |
|        | (CT0DSR4) See page 361.                                               | Reset:          |       |           |     | Unaffected | l by reset |     |     |       |
| \$0559 | CAN Transmit 0 Data Segment<br>Register 5                             | Read:<br>Write: | DB7   | DB6       | DB5 | DB4        | DB3        | DB2 | DB1 | DB0   |
|        | (CT0DSR5) See page 361.                                               | Reset:          |       |           |     | Unaffected | l by reset |     |     |       |
| \$055A | CAN Transmit 0 Data Segment<br>Register 6                             | Read:<br>Write: | DB7   | DB6       | DB5 | DB4        | DB3        | DB2 | DB1 | DB0   |
|        | (CT0DSR6) See page 361.                                               | Reset:          |       |           |     | Unaffected | l by reset |     |     |       |
| \$055B | CAN Transmit 0 Data Segment<br>Register 7                             | Read:<br>Write: | DB7   | DB6       | DB5 | DB4        | DB3        | DB2 | DB1 | DB0   |
|        | (CT0DSR7) See page 361.                                               | Reset:          |       |           |     | Unaffected | l by reset |     |     |       |
| \$055C | CAN Transmit 0 Data<br>Length Register                                | Read:<br>Write: | DB7   | DB6       | DB5 | DB4        | DB3        | DB2 | DB1 | DB0   |
|        | (CT0DSR7) See page 361.                                               | Reset:          |       | ·         |     | Unaffected | l by reset |     |     |       |
| \$055D | CAN Transmit 0 Buffer<br>Priority Register<br>(CT0TBPR) See page 362. | Read:<br>Write: | DB7   | DB6       | DB5 | DB4        | DB3        | DB2 | DB1 | DB0   |
|        | CTOTOFIC See page 302.                                                | Reset:          |       | 1         |     | Unaffected | l by reset |     |     |       |
|        |                                                                       |                 | R     | = Reserve |     | U = Una    |            |     |     |       |

Figure 2-2. Control, Status, and Data Registers (Sheet 12 of 18)

MC68HC08QA24

| Addr.  | Register Name                             |                 | Bit 7 | 6         | 5       | 4          | 3          | 2         | 1    | Bit 0 |
|--------|-------------------------------------------|-----------------|-------|-----------|---------|------------|------------|-----------|------|-------|
| \$055E | Reserved                                  |                 | R     | R         | R       | R          | R          | R         | R    | R     |
|        |                                           | L               |       |           |         |            |            |           |      |       |
| \$055F | Reserved                                  |                 | R     | R         | R       | R          | R          | R         | R    | R     |
|        |                                           | r               |       |           |         |            |            |           |      |       |
| \$0560 | CAN Transmit 1 Identifier<br>Register 0   | Read:<br>Write: | ID28  | ID27      | ID26    | ID25       | ID24       | ID23      | ID22 | ID21  |
|        | (CT1IDR0) See page 360.                   | Reset:          |       |           |         | Unaffected | d by reset |           |      |       |
| \$0561 | CAN Transmit 1 Identifier<br>Register 1   | Read:<br>Write: | ID20  | ID19      | ID16    | SRR(1)     | IDE(1)     | ID17      | ID16 | ID15  |
|        | (CT1IDR1) See page 360.                   | Reset:          |       |           |         | Unaffected | d by reset |           | I    |       |
| \$0562 | CAN Transmit 1 Identifier<br>Register 2   | Read:<br>Write: | ID14  | ID13      | ID12    | ID11       | ID10       | ID9       | ID8  | ID7   |
|        | (CT1IDR2) See page 360.                   | Reset:          |       |           |         | Unaffected | d by reset |           |      |       |
| \$0563 | CAN Transmit 1 Identifier<br>Register 3   | Read:<br>Write: | ID6   | ID5       | ID4     | ID3        | ID2        | ID1       | ID0  | RTR   |
|        | (CT1IDR3) See page 360.                   | Reset:          |       |           |         | Unaffected | d by reset |           | I    |       |
| \$0564 | CAN Transmit 1 Data Segment<br>Register 0 | Read:<br>Write: | DB7   | DB6       | DB5     | DB4        | DB3        | DB2       | DB1  | DB0   |
|        | (CT1DSR0) See page 361.                   | Reset:          |       |           |         | Unaffected | d by reset |           | _    |       |
| \$0565 | CAN Transmit 1 Data Segment<br>Register 1 | Read:<br>Write: | DB7   | DB6       | DB5     | DB4        | DB3        | DB2       | DB1  | DB0   |
|        | (CT1DSR1) See page 361.                   | Reset:          |       |           |         | Unaffected | d by reset |           |      |       |
| \$0566 | CAN Transmit 1 Data Segment               | Read:<br>Write: | DB7   | DB6       | DB5     | DB4        | DB3        | DB2       | DB1  | DB0   |
|        | (CTIDSK2) See page 301.                   | Reset:          |       |           |         | Unaffected | d by reset |           |      |       |
|        |                                           |                 | R     | = Reserve | ed      | U = Una    | affected   |           |      |       |
|        |                                           |                 | 01-1  |           | D-1- D- |            | (01        | 40 . ( 40 | 2    |       |

Figure 2-2. Control, Status, and Data Registers (Sheet 13 of 18)

| Addr.  | Register Name                              |                 | Bit 7 | 6           | 5   | 4          | 3          | 2   | 1   | Bit 0 |
|--------|--------------------------------------------|-----------------|-------|-------------|-----|------------|------------|-----|-----|-------|
| \$0567 | CAN Transmit 1 Data Segment<br>Register 3  | Read:<br>Write: | DB7   | DB6         | DB5 | DB4        | DB3        | DB2 | DB1 | DB0   |
|        | (CT1DSR3) See page 361.                    | Reset:          |       |             |     | Unaffected | d by reset |     |     |       |
| \$0568 | CAN Transmit 1 Data Segment<br>Register 4  | Read:<br>Write: | DB7   | DB6         | DB5 | DB4        | DB3        | DB2 | DB1 | DB0   |
|        | (CT1DSR4) See page 361.                    | Reset:          |       | •           |     | Unaffected | d by reset |     |     |       |
| \$0569 | CAN Transmit 1 Data Segment<br>Register 5  | Read:<br>Write: | DB7   | DB6         | DB5 | DB4        | DB3        | DB2 | DB1 | DB0   |
|        | (CT1DSR5) See page 361.                    | Reset:          |       | •           |     | Unaffected | d by reset |     |     |       |
| \$056A | CAN Transmit 1 Data Segment<br>Register 6  | Read:<br>Write: | DB7   | DB6         | DB5 | DB4        | DB3        | DB2 | DB1 | DB0   |
|        | (CT1DSR6) See page 361.                    | Reset:          |       |             |     | Unaffected | d by reset |     |     |       |
| \$056B | CAN Transmit 1 Data<br>Segment Register 7  | Read:<br>Write: | DB7   | DB6         | DB5 | DB4        | DB3        | DB2 | DB1 | DB0   |
|        | (CT1DSR7) See page 361.                    | Reset:          |       | •           |     | Unaffected | d by reset |     |     |       |
| \$056C | CAN Transmit 1 Data<br>Length Register     | Read:<br>Write: | DB7   | DB6         | DB5 | DB4        | DB3        | DB2 | DB1 | DB0   |
|        | (CT1DSR7) See page 361.                    | Reset:          |       |             |     | Unaffected | d by reset |     |     |       |
| \$056D | CAN Transmit 1 Buffer<br>Priority Register | Read:<br>Write: | DB7   | DB6         | DB5 | DB4        | DB3        | DB2 | DB1 | DB0   |
|        | (CT1TBPR) See page 362.                    | Reset:          |       |             |     | Unaffected | d by reset |     |     |       |
| \$056E | Reserved                                   |                 | R     | R           | R   | R          | R          | R   | R   | R     |
|        |                                            |                 |       |             |     |            |            |     |     |       |
| \$056F | Reserved                                   |                 | R     | R           | R   | R          | R          | R   | R   | R     |
|        |                                            |                 | R     | ] = Reserve | ed  | U = Una    | iffected   |     |     |       |

Figure 2-2. Control, Status, and Data Registers (Sheet 14 of 18)

| S0570       CAN Transmit 2 Identify<br>Register 0<br>(CT2IDR0) See page 360.       Read-<br>Write:       ID28       ID27       ID26       ID25       ID24       ID23       ID22       ID21         S0571       CAN Transmit 2 Identify<br>Register 1<br>(CT2IDR1) See page 360.       Read-<br>Reset:       ID20       ID19       ID16       SRR(1)       IDE(1)       ID17       ID16       ID15         S0572       CAN Transmit 2 Identify<br>Register 2<br>(CT2IDR2) See page 360.       Read-<br>Reset:       ID14       ID13       ID12       ID11       ID10       ID9       ID8       ID7         S0573       CAN Transmit 2 Identify<br>Register 3<br>(CT2IDR3) See page 360.       Read-<br>Reset:       ID14       ID13       ID12       ID11       ID10       ID9       ID8       ID7         S0573       CAN Transmit 2 Identify<br>(CT2IDR3) See page 360.       Read-<br>Reset:       ID6       ID5       ID4       ID3       ID2       ID1       ID0       RTR         S0574       CAN Transmit 2 Data Segment<br>(CT2DSR3) See page 361.       Read-<br>Reset:       ID87       DB6       DB5       DB4       DB3       DB2       DB1       DB0         S0575       CAN Transmit 2 Data Segment<br>(CT2DSR3) See page 361.       Read-<br>Reset:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | Addr.  | Register Name           |        | Bit 7 | 6         | 5    | 4          | 3          | 2    | 1    | Bit 0 |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------|-------------------------|--------|-------|-----------|------|------------|------------|------|------|-------|
| Reset:Unaffected by resetS0571CAN Transmit 2 Identifier<br>Register 1<br>(CT2IDR1) See page 360.Read:<br>Write:ID20ID19ID16SR(1)IDE(1)ID17ID16ID15S0572CAN Transmit 2 Identifier<br>Register 2<br>(CT2IDR2) See page 360.Read:<br>Write:ID14ID13ID12ID11ID10ID9ID8ID7S0573CAN Transmit 2 Identifier<br>Register 3<br>(CT2IDR3) See page 360.Read:<br>Write:ID6ID5ID4ID3ID2ID1ID0RTRS0574CAN Transmit 2 Data Segment<br>(CT2DSR0) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0S0575CAN Transmit 2 Data Segment<br>(CT2DSR1) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0S0576CAN Transmit 2 Data Segment<br>(CT2DSR1) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0S0577CAN Transmit 2 Data Segment<br>(CT2DSR3) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0S0578CAN Transmit 2 Data Segment<br>(CT2DSR3) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0S0578CAN Transmit 2 Data Segment<br>Register 4<br>(CT2DSR4) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0S0578<                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | \$0570 | Register 0              |        | ID28  | ID27      | ID26 | ID25       | ID24       | ID23 | ID22 | ID21  |
| CAN Transmit 2 Identifier<br>Register 1<br>(CT2IDR1) See page 360.       ID20       ID19       ID16       SR(1)       IDE(1)       ID17       ID16       ID15         S0571       CAN Transmit 2 Identifier<br>Register 2<br>(CT2IDR2) See page 360.       Read:<br>(CT2IDR2) See page 360.       ID14       ID13       ID12       ID11       ID10       ID9       ID8       ID7         S0572       CAN Transmit 2 Identifier<br>Register 3<br>(CT2IDR3) See page 360.       Read:<br>Write:       ID6       ID5       ID4       ID3       ID2       ID1       ID0       RTR         S0573       CAN Transmit 2 Identifier<br>Register 0<br>(CT2DSR0) See page 361.       Read:<br>Write:       ID6       ID5       ID4       ID3       ID2       ID1       ID0       RTR         S0574       CAN Transmit 2 Data Segment<br>(CT2DSR0) See page 361.       Read:<br>Write:       DB7       DB6       DB5       DB4       DB3       DB2       DB1       DB0         S0576       CAN Transmit 2 Data Segment<br>(CT2DSR1) See page 361.       Read:<br>Read:       DB7       DB6       DB5       DB4       DB3       DB2       DB1       DB0         S0577       CAN Transmit 2 Data Segment<br>Register 4<br>(CT2DSR3) See page 361.       Read:<br>Read:       DB7       D                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |        | (CT2IDR0) See page 360. | Reset: |       |           |      | Unaffected | d by reset |      |      |       |
| Keset:     Unaffected by reset       S0572     CAN Transmit 2 Identifier<br>Register 2     Read:<br>(CT2IDR2) See page 360.<br>(CT2IDR3) See page 360.<br>(CT2DR3) See page 360.<br>(CT2DR3) See page 360.<br>(CT2DSR0) See page 361.     Read:<br>ID6     ID14     ID13     ID12     ID11     ID10     ID9     ID8     ID7       \$0573     CAN Transmit 2 Identifier<br>Register 3     Read:<br>Write:     ID6     ID5     ID4     ID3     ID2     ID1     ID0     RTR       \$0574     CAN Transmit 2 Data Segment<br>Register 1     Read:<br>(CT2DSR1) See page 361.     Read:<br>Read:     DB7     DB6     DB5     DB4     DB3     DB2     DB1     DB0       \$0576     CAN Transmit 2 Data Segment<br>Register 2     Read:<br>(CT2DSR1) See page 361.     Read:<br>Read:     DB7     DB6     DB5     DB4     DB3     DB2     DB1     DB0       \$0576     CAN Transmit 2 Data Segment<br>Register 2     Read:<br>(CT2DSR2) See page 361.     Read:<br>Read:     DB7     DB6     DB5     DB4     DB3     DB2     DB1     DB0       \$0577     CAN Transmit 2 Data Segment<br>Register 3     Read:<br>(CT2DSR3) See page 361.     Read:<br>Read:     DB7     DB6     DB5     DB4     DB3     DB2     DB1     DB0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | \$0571 | Register 1              |        | ID20  | ID19      | ID16 | SRR(1)     | IDE(1)     | ID17 | ID16 | ID15  |
| S0572CAN Transmit 2 identifier<br>Register 2<br>(CT2IDR2) See page 360.ID14ID13ID12ID11ID10ID9ID8ID7S0573CAN Transmit 2 identifier<br>Register 3<br>(CT2IDR3) See page 360.Read:<br>Write:ID6ID5ID4ID3ID2ID1ID0RTRS0573CAN Transmit 2 identifier<br>(CT2IDR3) See page 360.Read:<br>Write:ID6ID5ID4ID3ID2ID1ID0RTRS0574CAN Transmit 2 Data Segment<br>(CT2DSR0) See page 361.Read:<br>Register 0<br>(CT2DSR1) See page 361.DB7DB6DB5DB4DB3DB2DB1DB0S0575CAN Transmit 2 Data Segment<br>(CT2DSR1) See page 361.Read:<br>Register 1<br>(CT2DSR2) See page 361.Read:<br>Read:DB7DB6DB5DB4DB3DB2DB1DB0S0576CAN Transmit 2 Data Segment<br>(CT2DSR2) See page 361.Read:<br>Register 2<br>(CT2DSR2) See page 361.Read:<br>Read:DB7DB6DB5DB4DB3DB2DB1DB0S0576CAN Transmit 2 Data Segment<br>(CT2DSR3) See page 361.Read:<br>Read:DB7DB6DB5DB4DB3DB2DB1DB0S0577CAN Transmit 2 Data Segment<br>(CT2DSR3) See page 361.Read:<br>Read:DB7DB6DB5DB4DB3DB2DB1DB0S0578CAN Transmit 2 Data Segment<br>(CT2DSR4) See page 361.Read:<br>Read:DB7DB6DB5DB4DB3DB2DB1DB0S0578 <td< td=""><td></td><td>(CT2IDR1) See page 360.</td><td>Reset:</td><td></td><td></td><td></td><td>Unaffected</td><td>d by reset</td><td></td><td></td><td></td></td<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |        | (CT2IDR1) See page 360. | Reset: |       |           |      | Unaffected | d by reset |      |      |       |
| Reset:Unaffected by reset\$0573CAN Transmit 2 Identifier<br>Register 3<br>(CT2IDR3) See page 360.Read:<br>Write:ID6ID5ID4ID3ID2ID1ID0RTR\$0574CAN Transmit 2 Data Segment<br>Register 0<br>(CT2DSR0) See page 361.Read:<br>Reset:DB7DB6DB5DB4DB3DB2DB1DB0\$0575CAN Transmit 2 Data Segment<br>(CT2DSR1) See page 361.Read:<br>Register 1<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0\$0576CAN Transmit 2 Data Segment<br>(CT2DSR1) See page 361.Read:<br>Register 2<br>(CT2DSR2) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0\$0577CAN Transmit 2 Data Segment<br>Register 3<br>(CT2DSR2) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0\$0578CAN Transmit 2 Data Segment<br>(CT2DSR3) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0\$0577CAN Transmit 2 Data Segment<br>(CT2DSR3) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0\$0578CAN Transmit 2 Data Segment<br>(CT2DSR4) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0\$0578CAN Transmit 2 Data Segment<br>(CT2DSR4) See page 361.Read:<br>Read:<br>Register 4DB7DB6DB5DB4DB3DB2DB1 <t< td=""><td>\$0572</td><td>Register 2</td><td></td><td>ID14</td><td>ID13</td><td>ID12</td><td>ID11</td><td>ID10</td><td>ID9</td><td>ID8</td><td>ID7</td></t<>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | \$0572 | Register 2              |        | ID14  | ID13      | ID12 | ID11       | ID10       | ID9  | ID8  | ID7   |
| CAN Transmit 2 Data Segment<br>Register 3<br>(CT2DSR0) See page 360.ID6ID5ID4ID3ID2ID1ID0RTR\$0574CAN Transmit 2 Data Segment<br>Register 0<br>(CT2DSR0) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0\$0575CAN Transmit 2 Data Segment<br>Register 1<br>(CT2DSR1) See page 361.Read:<br>Read:<br>Reset:DB7DB6DB5DB4DB3DB2DB1DB0\$0576CAN Transmit 2 Data Segment<br>Register 2<br>(CT2DSR2) See page 361.Read:<br>Read:<br>Read:<br>Register 3<br>(CT2DSR3) See page 361.Read:<br>Read:<br>Read:<br>DB7DB6DB5DB4DB3DB2DB1DB0\$0577CAN Transmit 2 Data Segment<br>Register 3<br>(CT2DSR3) See page 361.Read:<br>Read:<br>Read:<br>Read:<br>Read:<br>DB7DB6DB5DB4DB3DB2DB1DB0\$0578CAN Transmit 2 Data Segment<br>Register 4<br>(CT2DSR4) See page 361.Read:<br>Write:<br>Read:<br>Read:<br>Read:<br>DB7DB6DB5DB4DB3DB2DB1DB0\$0578CAN Transmit 2 Data Segment<br>Register 4<br>(CT2DSR4) See page 361.Read:<br>Write:<br>Read:<br>Read:<br>Read:<br>DB7DB6DB5DB4DB3DB2DB1DB0\$0578CAN Transmit 2 Data Segment<br>Register 4<br>(CT2DSR4) See page 361.Read:<br>Write:<br>Read:<br>Read:<br>Read:<br>Read:<br>Read:<br>Read:<br>Read:<br>Read:<br>Read:<br>Read:<br>Read:<br>Read:<br>Read:<br>Read:<br>Read:<br>Read:<br>Read:<br>Read:<br>Read:<br>Read:<br>Read:<br>Read:<br>Read:                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |        | (CT2IDR2) See page 360. | Reset: |       |           |      | Unaffected | d by reset |      |      |       |
| CAN Transmit 2 Data Segment<br>Register 0<br>(CT2DSR0) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0\$0574CAN Transmit 2 Data Segment<br>Register 1<br>(CT2DSR1) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0\$0575CAN Transmit 2 Data Segment<br>Register 1<br>(CT2DSR1) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0\$0576CAN Transmit 2 Data Segment<br>Register 2<br>(CT2DSR2) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0\$0577CAN Transmit 2 Data Segment<br>Register 3<br>(CT2DSR3) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0\$0578CAN Transmit 2 Data Segment<br>Register 3<br>(CT2DSR3) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0\$0578CAN Transmit 2 Data Segment<br>(CT2DSR3) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0\$0578CAN Transmit 2 Data Segment<br>Register 4<br>(CT2DSR4) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0\$0578CAN Transmit 2 Data Segment<br>Register 4<br>(CT2DSR4) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0\$0578CAN Transmit 2 Data Segment<br>Regist                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | \$0573 | Register 3              |        | ID6   | ID5       | ID4  | ID3        | ID2        | ID1  | ID0  | RTR   |
| CAN Transmit 2 Data Segment<br>Register 0<br>(CT2DSR0) See page 361.DB7DB6DB5DB4DB3DB2DB1DB0\$0575CAN Transmit 2 Data Segment<br>Register 1<br>(CT2DSR1) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0\$0576CAN Transmit 2 Data Segment<br>Register 2<br>(CT2DSR1) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0\$0576CAN Transmit 2 Data Segment<br>Register 2<br>(CT2DSR2) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0\$0577CAN Transmit 2 Data Segment<br>Register 3<br>(CT2DSR3) See page 361.Read:<br>Read:<br>DB7DB6DB5DB4DB3DB2DB1DB0\$0578CAN Transmit 2 Data Segment<br>(CT2DSR3) See page 361.Read:<br>Write:<br>Read:<br>DB7DB6DB5DB4DB3DB2DB1DB0\$0578CAN Transmit 2 Data Segment<br>(CT2DSR4) See page 361.Read:<br>Write:<br>Read:<br>DB7DB6DB5DB4DB3DB2DB1DB0\$0578CAN Transmit 2 Data Segment<br>(CT2DSR4) See page 361.Read:<br>Write:<br>Read:<br>DB7DB6DB5DB4DB3DB2DB1DB0\$0578CAN Transmit 2 Data Segment<br>Register 4<br>(CT2DSR4) See page 361.Read:<br>Read:<br>Read:<br>Read:<br>Read:<br>Read:<br>Read:<br>Read:<br>Read:<br>Read:<br>Read:<br>Read:<br>Read:<br>Read:<br>Read:<br>Read:<br>Read:<br>Read:<br>Read:<br>Read:<br>Read:<br>Read:<br>Read                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |        | (CT2IDR3) See page 360. | Reset: |       |           |      | Unaffected | d by reset |      | 1    |       |
| CAN Transmit 2 Data Segment<br>Register 1<br>(CT2DSR1) See page 361.Read:<br>Write:<br>Reset:DB7DB6DB5DB4DB3DB2DB1DB0\$0575CAN Transmit 2 Data Segment<br>Register 2<br>(CT2DSR2) See page 361.Read:<br>Write:<br>Reset:DB7DB6DB5DB4DB3DB2DB1DB0\$0576CAN Transmit 2 Data Segment<br>Register 3<br>(CT2DSR2) See page 361.Read:<br>Write:<br>Reset:DB7DB6DB5DB4DB3DB2DB1DB0\$0577CAN Transmit 2 Data Segment<br>Register 3<br>(CT2DSR3) See page 361.Read:<br>Write:<br>Reset:DB7DB6DB5DB4DB3DB2DB1DB0\$0578CAN Transmit 2 Data Segment<br>Register 4<br>(CT2DSR4) See page 361.Read:<br>Read:<br>Reset:DB7DB6DB5DB4DB3DB2DB1DB0\$0578CAN Transmit 2 Data Segment<br>Register 4<br>(CT2DSR4) See page 361.Read:<br>Read:<br>Reset:DB6DB5DB4DB3<                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | \$0574 | Register 0              |        | DB7   | DB6       | DB5  | DB4        | DB3        | DB2  | DB1  | DB0   |
| CAN Transmit 2 Data Segment<br>Register 1<br>(CT2DSR1) See page 361.DB7DB6DB5DB4DB3DB2DB1DB0\$0575CAN Transmit 2 Data Segment<br>Register 2<br>(CT2DSR2) See page 361.Write:<br>Reset:B87DB6DB5DB4DB3DB2DB1DB0\$0576CAN Transmit 2 Data Segment<br>Register 2<br>(CT2DSR2) See page 361.Read:<br>Reset:DB7DB6DB5DB4DB3DB2DB1DB0\$0577CAN Transmit 2 Data Segment<br>Register 3<br>(CT2DSR3) See page 361.Read:<br>Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0\$0578CAN Transmit 2 Data Segment<br>Register 4<br>(CT2DSR4) See page 361.Read:<br>Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0\$0578CAN Transmit 2 Data Segment<br>Register 4<br>(CT2DSR4) See page 361.DB7DB6DB5DB4DB3DB2DB1DB0\$0578CAN Transmit 2 Data Segment<br>Register 4<br>(CT2DSR4) See page 361.DB7DB6DB5DB4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |        | (CT2DSR0) See page 361. | Reset: |       |           |      | Unaffected | d by reset |      |      |       |
| Reset:Unaffected by reset\$0576CAN Transmit 2 Data Segment<br>Register 2<br>(CT2DSR2) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0\$0577CAN Transmit 2 Data Segment<br>Register 3<br>(CT2DSR3) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0\$0577CAN Transmit 2 Data Segment<br>Register 3<br>(CT2DSR3) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0\$0578CAN Transmit 2 Data Segment<br>Register 4<br>(CT2DSR4) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0\$0578CAN Transmit 2 Data Segment<br>Register 4<br>(CT2DSR4) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0\$0578CAN Transmit 2 Data Segment<br>Register 4<br>(CT2DSR4) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | \$0575 | Register 1              |        | DB7   | DB6       | DB5  | DB4        | DB3        | DB2  | DB1  | DB0   |
| CAN Transmit 2 Data Segment<br>Register 2<br>(CT2DSR2) See page 361.DB7DB6DB5DB4DB3DB2DB1DB0\$0576(CT2DSR2) See page 361.Write:<br>Reset:Read:<br>DB7DB6DB5DB4DB3DB2DB1DB0\$0577CAN Transmit 2 Data Segment<br>Register 3<br>(CT2DSR3) See page 361.Read:<br>Write:<br>Reset:DB7DB6DB5DB4DB3DB2DB1DB0\$0578CAN Transmit 2 Data Segment<br>Register 4<br>(CT2DSR4) See page 361.Read:<br>Write:<br>DB7DB6DB5DB4DB3DB2DB1DB0\$0578CAN Transmit 2 Data Segment<br>Register 4<br>(CT2DSR4) See page 361.Read:<br>Write:<br>Reset:DB7DB6DB5DB4DB3DB2DB1DB0\$0578CAN Transmit 2 Data Segment<br>Register 4<br>(CT2DSR4) See page 361.Read:<br>Write:<br>Reset:DB7DB6DB5DB4DB3DB2DB1DB0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |        | (CT2DSRT) See page 361. | Reset: |       |           |      | Unaffected | d by reset |      |      |       |
| Kore and a constraint of the con | \$0576 | Register 2              |        | DB7   | DB6       | DB5  | DB4        | DB3        | DB2  | DB1  | DB0   |
| CAN Transmit 2 Data Segment<br>Register 3<br>(CT2DSR3) See page 361.DB7DB6DB5DB4DB3DB2DB1DB0\$0577Register 3<br>(CT2DSR3) See page 361.Write:DB7DB6DB5DB4DB3DB2DB1DB0\$0578CAN Transmit 2 Data Segment<br>Register 4<br>(CT2DSR4) See page 361.Read:<br>Write:DB7DB6DB5DB4DB3DB2DB1DB0\$0578Register 4<br>(CT2DSR4) See page 361.Write:<br>Reset:DB7DB6DB5DB4DB3DB2DB1DB0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |        | (CT2DSR2) See page 361. | Reset: |       |           |      | Unaffected | d by reset |      |      |       |
| Reset:     Unaffected by reset       CAN Transmit 2 Data Segment     Read:     DB7     DB6     DB5     DB4     DB3     DB2     DB1     DB0       \$0578     Register 4<br>(CT2DSR4) See page 361.     Write:     DB7     DB6     DB5     DB4     DB3     DB2     DB1     DB0                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | \$0577 | Register 3              |        | DB7   | DB6       | DB5  | DB4        | DB3        | DB2  | DB1  | DB0   |
| CAN Transmit 2 Data Segment DB7 DB6 DB5 DB4 DB3 DB2 DB1 DB0 (CT2DSR4) See page 361.<br>Reset: Unaffected by reset                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |        | (CT2DSR3) See page 361. | Reset: |       |           |      | Unaffected | d by reset |      | ·    |       |
| Reset: Unaffected by reset                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | \$0578 | Register 4              |        | DB7   | DB6       | DB5  | DB4        | DB3        | DB2  | DB1  | DB0   |
| R = Reserved U = Unaffected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |        | (UTZUSK4) See page 361. | Reset: |       |           |      | Unaffected | d by reset |      |      |       |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |        |                         |        | R     | = Reserve | ed   | U = Una    | affected   |      |      |       |

Figure 2-2. Control, Status, and Data Registers (Sheet 15 of 18)

**Technical Data** 

| Addr.  | Register Name                              |                 | Bit 7 | 6   | 5   | 4          | 3          | 2   | 1    | Bit 0 |
|--------|--------------------------------------------|-----------------|-------|-----|-----|------------|------------|-----|------|-------|
| \$0579 | CAN Transmit 2 Data Segment<br>Register 5  | Read:<br>Write: | DB7   | DB6 | DB5 | DB4        | DB3        | DB2 | DB1  | DB0   |
|        | (CT2DSR5) See page 361.                    | Reset:          |       |     |     | Unaffected | l by reset |     |      |       |
| \$057A | CAN Transmit 2 Data Segment<br>Register 6  | Read:<br>Write: | DB7   | DB6 | DB5 | DB4        | DB3        | DB2 | DB1  | DB0   |
|        | (CT2DSR6) See page 361.                    | Reset:          |       |     |     | Unaffected | l by reset |     |      |       |
| \$057B | CAN Transmit 2 Data Segment<br>Register 7  | Read:<br>Write: | DB7   | DB6 | DB5 | DB4        | DB3        | DB2 | DB1  | DB0   |
|        | (CT2DSR7) See page 361.                    | Reset:          |       |     |     | Unaffected | l by reset |     |      |       |
| \$057C | CAN Transmit 2 Data Length<br>Register     | Read:<br>Write: | DB7   | DB6 | DB5 | DB4        | DB3        | DB2 | DB1  | DB0   |
|        | (CT2DSR7) See page 361.                    | Reset:          |       |     |     | Unaffected | l by reset |     |      |       |
| \$057D | CAN Transmit 2 Buffer Priority<br>Register | Read:<br>Write: | DB7   | DB6 | DB5 | DB4        | DB3        | DB2 | DB1  | DB0   |
|        | (CT2TBPR) See page 362.                    | Reset:          |       | I   |     | Unaffected | l by reset |     |      |       |
| \$057E | Reserved                                   |                 | R     | R   | R   | R          | R          | R   | R    | R     |
|        |                                            |                 |       |     |     |            |            |     |      |       |
| \$057F | Reserved                                   |                 | R     | R   | R   | R          | R          | R   | R    | R     |
|        |                                            |                 |       |     |     |            |            |     |      |       |
| \$FE00 | SIM Break Status Register<br>(SBSR)        | Read:<br>Write: | R     | R   | R   | R          | R          | R   | SBSW | R     |
|        | See page 147.                              | Reset:          |       |     |     |            |            |     | 0    |       |
|        | SIM Reset Status Register                  | Read:           | POR   | PIN | COP | ILOP       | ILAD       | EDC | LVI  | 0     |
| \$FE01 | (SRSR)                                     | Write:          | R     | R   | R   | R          | R          | R   | R    | R     |
|        | See page 149.                              | Reset:          | 1     | U   | 0   | 0          | 0          | U   | U    | 0     |
|        |                                            | -               |       | 1   |     |            |            |     |      |       |

Figure 2-2. Control, Status, and Data Registers (Sheet 16 of 18)

| Addr.        | Register Name                              |                 | Bit 7  | 6         | 5       | 4       | 3        | 2        | 1     | Bit 0 |
|--------------|--------------------------------------------|-----------------|--------|-----------|---------|---------|----------|----------|-------|-------|
| \$FE03       | SIM Break Flag Control<br>Register (SBFCR) | Read:<br>Write: | BCFE   | R         | R       | R       | R        | R        | R     | R     |
|              | See page 150.                              | Reset:          | 0      |           |         |         |          |          |       |       |
| \$FE04       | Reserved                                   |                 | R      | R         | R       | R       | R        | R        | R     | R     |
| $\downarrow$ | $\downarrow$                               |                 |        |           |         |         |          |          |       |       |
| \$FE07       | Reserved                                   |                 | R      | R         | R       | R       | R        | R        | R     | R     |
|              |                                            | L               |        |           |         |         |          |          |       |       |
|              | EDC Control Register                       | Read:           | 0      | R         | 0       | 0       | R        | FDB      | FABH  | FABL  |
| \$FE09       | (EDCR)                                     | Write:          | SFLTB  | ĸ         | R       | R       | ĸ        | FDB      | ГАВП  | FADL  |
|              | See page 100.                              | Reset:          | 1      |           | 0       | 0       | 1        | 0        | 0     | 0     |
| \$FE0C       | Break Address Register High<br>(BRKH)      | Read:<br>Write: | Bit 15 | 14        | 13      | 12      | 11       | 10       | 9     | Bit 8 |
|              | See page 162.                              | Reset:          | 0      | 0         | 0       | 0       | 0        | 0        | 0     | 0     |
| \$FE0D       | Break Address Register Low<br>(BRKL)       | Read:<br>Write: | Bit 7  | 6         | 5       | 4       | 3        | 2        | 1     | Bit 0 |
|              | See page 162.                              | Reset:          | 0      | 0         | 0       | 0       | 0        | 0        | 0     | 0     |
|              | Break Status and Control                   | Read:           | BRKE   | BRKA      | 0       | 0       | 0        | 0        | 0     | 0     |
| \$FE0E       | Register (BRKSCR)                          | Write:          | DKKL   | DKKA      | R       | R       | R        | R        | R     | R     |
|              | See page 161.                              | Reset:          | 0      | 0         | 0       | 0       | 0        | 0        | 0     | 0     |
|              | LVI Status Register                        | Read:           | LVIOUT | 0         | 0       | 0       | 0        | 0        | 0     | 0     |
| \$FE0F       | (LVISR)                                    | Write:          | R      | R         | R       | R       | R        | R        | R     | R     |
|              | See page 153.                              | Reset:          | 0      | 0         | 0       | 0       | 0        | 0        | 0     | 0     |
| \$FE1C       | EEPROM Non-Volatile<br>Register (EENVR)    | Read:<br>Write: | EERA   | R         | R       | R       | EEBP3    | EEBP2    | EEBP1 | EEBP0 |
|              | See page 79.                               | Reset:          | PV     | R         | R       | R       | PV       | PV       | PV    | PV    |
| PV = Pro     | grammed value or 1 in the e                | rased s         | tate.  |           |         |         |          |          |       |       |
|              |                                            |                 | R      | = Reserve | ed      | U = Una | affected |          |       |       |
|              | Eiguro 2-2 Co                              | ntro            | Statu  | e and l   | Data Pa | aistors | (Shaat   | 17 of 19 | 2)    |       |



| Addr.  | Register Name           |        | Bit 7  | 6         | 5     | 4           | 3            | 2     | 1     | Bit 0   |
|--------|-------------------------|--------|--------|-----------|-------|-------------|--------------|-------|-------|---------|
|        | EEPROM Control Register | Read:  | EEBCLK | 0         | EEOFF | EERAS1      | EERAS0       | EELAT | 0     | EEPGM   |
| \$FE1D | (EĔCR)                  | Write: | EEDULK | R         | LEOLL | EERASI      | LEKASU       | EELAI | R     | EEPGINI |
|        | See page 77.            | Reset: | 0      | 0         | 0     | 0           | 0            | 0     | 0     | 0       |
| \$FE1E | Reserved                |        | R      | R         | R     | R           | R            | R     | R     | R       |
|        |                         | L      |        |           |       | 1           | 1            |       |       |         |
|        | EEPROM Array Control    | Read:  | EERA   | R         | R     | R           | EEBP3        | EEBP2 | EEBP1 | EEBP0   |
| \$FE1F | Register (EEACR)        | Write: | R      | R         | R     | R           | R            | R     | R     | R       |
|        | See page 79.            | Reset: | EENVR  | R         | R     | R           | EENVR        | EENVR | EENVR | EENVR   |
|        |                         |        |        |           |       |             |              |       |       |         |
| \$FF80 | Reserved                | [      | R      | R         | R     | R           | R            | R     | R     | R       |
|        |                         | L      |        |           |       | 1           |              |       |       |         |
|        |                         |        |        |           |       |             |              |       |       |         |
|        | COP Control Register    | Read:  |        |           |       | Low byte of | reset vector |       |       |         |
| \$FFFF | (COPCTL)                | Write: |        |           |       | Clear COI   | P counter    |       |       |         |
|        | See page 177.           | Reset: |        |           |       | Unaffected  | d by reset   |       |       |         |
|        |                         | [      | R      | = Reserve | ed    | U = Una     | affected     |       |       |         |
|        | _                       |        |        |           |       | •           |              |       |       |         |

Figure 2-2. Control, Status, and Data Registers (Sheet 18 of 18)

| ]                | Address | Vector                        |
|------------------|---------|-------------------------------|
| -                | \$FFD8  | CAN Transmit Vector (High)    |
|                  | \$FFD9  | CAN Transmit Vector (Low)     |
| Lowest Priority  | \$FFDA  | CAN Receive Vector (High)     |
|                  | \$FFDB  | CAN Receive Vector (Low)      |
|                  | \$FFDC  | CAN Error Vector (High)       |
|                  | \$FFDD  | CAN Error Vector (Low)        |
|                  | \$FFDE  | CAN Wakeup Vector (High)      |
|                  | \$FFDF  | CAN Wakeup Vector (Low)       |
|                  | \$FFE0  | ADC Vector (High)             |
|                  | \$FFE1  | ADC Vector (Low)              |
|                  | \$FFE2  | SCI Transmit Vector (High)    |
|                  | \$FFE3  | SCI Transmit Vector (Low)     |
|                  | \$FFE4  | SCI Receive Vector (High)     |
|                  | \$FFE5  | SCI Receive Vector (Low)      |
|                  | \$FFE6  | SCI Error Vector (High)       |
|                  | \$FFE7  | SCI Error Vector (Low)        |
|                  | \$FFE8  | SPI Transmit Vector (High)    |
|                  | \$FFE9  | SPI Transmit Vector (Low)     |
|                  | \$FFEA  | SPI Receive Vector (High)     |
|                  | \$FFEB  | SPI Receive Vector (Low)      |
|                  | \$FFEC  | TIM B Overflow Vector (High)  |
|                  | \$FFED  | TIM B Overflow Vector (Low)   |
|                  | \$FFEE  | TIM B Channel 1 Vector (High) |
|                  | \$FFEF  | TIM B Channel 1 Vector (Low)  |
|                  | \$FFF0  | TIM B Channel 0 Vector (High) |
|                  | \$FFF1  | TIM B Channel 0 Vector (Low)  |
|                  | \$FFF2  | TIM A Overflow Vector (High)  |
|                  | \$FFF3  | TIM A Overflow Vector (Low)   |
|                  | \$FFF4  | TIM A Channel 1 Vector (High) |
|                  | \$FFF5  | TIM A Channel 1 Vector (Low)  |
|                  | \$FFF6  | TIM A Channel 0 Vector (High) |
|                  | \$FFF7  | TIM A Channel 0 Vector (Low)  |
|                  | \$FFF8  | PLL Vector (High)             |
|                  | \$FFF9  | PLL Vector (Low)              |
|                  | \$FFFA  | IRQ Vector (High)             |
|                  | \$FFFB  | IRQ Vector (Low)              |
|                  | \$FFFC  | SWI Vector (High)             |
| ▼ [              | \$FFFD  | SWI Vector (Low)              |
| Highest Priority | \$FFFE  | Reset Vector (High)           |
| , j              | \$FFFF  | Reset Vector (Low)            |

Table 2-1. Vector Addresses

**Technical Data** 

MOTOROLA

# Section 3. Random-Access Memory (RAM)

### 3.1 Contents

| 3.2 | Introduction           | 63 |
|-----|------------------------|----|
| 3.3 | Functional Description | 63 |

### 3.2 Introduction

This section describes the 768 bytes of random-access memory (RAM).

### 3.3 Functional Description

Addresses \$0040–\$033F are RAM locations. The location of the stack RAM is programmable. The 16-bit stack pointer allows the stack to be anywhere in the 768-byte memory space.

**NOTE:** For correct operation, the stack pointer must point only to RAM locations.

Within page zero are 192 bytes of RAM. Because the location of the stack RAM is programmable, all page zero RAM locations can be used for input/output (I/O) control and user data or code. When the stack pointer is moved from its reset location at \$00FF, direct addressing mode instructions can access all page zero RAM locations efficiently. Page zero RAM, therefore, provides ideal locations for frequently accessed global variables.

Before processing an interrupt, the CPU uses five bytes of the stack to save the contents of the CPU registers.

**NOTE:** For M68HC05, M6805, and M146805 compatibility, the H register is not stacked.

During a subroutine call, the CPU uses two bytes of the stack to store the return address. The stack pointer decrements during pushes and increments during pulls.

**NOTE:** Be careful when using nested subroutines. The CPU could overwrite data in the RAM during a subroutine or during the interrupt stacking operation.

# Section 4. Read-Only Memory (ROM)

### 4.1 Contents

| 4.2 |                        | 35 |
|-----|------------------------|----|
| 4.3 | Functional Description | 35 |

### 4.2 Introduction

This section describes the 24,064 bytes of user read-only memory (ROM), 224 bytes of monitor ROM, and 36 bytes of user vectors.

## 4.3 Functional Description

The user ROM consists of 24,064 bytes of ROM from addresses \$A000–\$FDFF. The monitor ROM is located from \$FE20–\$FEFF. See Figure 2-1. Memory Map.

Twenty of the user vectors, \$FFD8–\$FFFF, are dedicated to user-defined reset and interrupt vectors.

Security has been incorporated into the MC68HC08QA24 to prevent external viewing of the ROM contents. This feature ensures that customer-developed software remains proprietary.<sup>(1)</sup>

<sup>1.</sup> No security feature is absolutely secure. However, Motorola's strategy is to make reading or copying the ROM difficult for unauthorized users.

# Section 5. Mask Options

### 5.1 Contents

| 5.2 | Introduction           | 67              |
|-----|------------------------|-----------------|
| 5.3 | Functional Description | 67              |
| 5.4 | Mask Option Register   | <mark>68</mark> |

## 5.2 Introduction

This section describes use of mask options by custom-masked read-only memory (ROM) and the mask option register (MOR) in the MC68HC08QA24.

### 5.3 Functional Description

The mask options are hard-wired connections, specified at the same time as the ROM code, which allow the user to customize the MCU. The options control the enable or disable ability of these functions:

- ROM security<sup>(1)</sup>
- Resets caused by the low-voltage inhibit (LVI) module
- Power to the LVI module
- Stop mode recovery time (32 CGMXCLK cycles or 4096 CGMXCLK cycles)
- COP timeout period (2<sup>18</sup>–2<sup>4</sup> CGMXCLK cycles or 2<sup>13</sup>–2<sup>4</sup> CGMXCLK cycles)

<sup>1.</sup> No security feature is absolutely secure. However, Motorola's strategy is to make reading or copying the ROM data difficult for unauthorized users.

- STOP instruction
- Computer operating properly module (COP)

The mask option register (\$001F) is used in the initialization of various options. For error-free compatibility with the emulator one time programmable (OTP) M68HC908QA24, a write to \$001F in the MC68HC08QA24has no effect in MCU operation.

## 5.4 Mask Option Register

| Address: | \$001F  |           |        |           |            |      |      |       |
|----------|---------|-----------|--------|-----------|------------|------|------|-------|
|          | Bit 7   | 6         | 5      | 4         | 3          | 2    | 1    | Bit 0 |
| Read:    | LVISTOP | ROMSEC    | LVIRST | LVIPWR    | SSREC      | COPS | STOP | COPD  |
| Write:   | R       | R         | R      | R         | R          | R    | R    | R     |
| Reset:   |         |           |        | Unaffecte | d by reset |      |      |       |
|          | R       | = Reserve | d      |           |            |      |      |       |

#### Figure 5-1. Mask Option Register (MOR)

LVISTOP — LVI Stop Mode Enable Bit

LVISTOP enables the LVI module in stop mode. (See **Section 11.** Low-Voltage Inhibit (LVI).)

1 = LVI enabled during stop mode

0 = LVI disabled during stop mode

**NOTE:** To have the LVI enabled in stop mode, the LVIPWR must be at a logic 0 and the LVISTOP bit must be at a logic 1. Take note that by enabling the LVI in stop mode, the stop I<sub>DD</sub> current will be higher.

ROMSEC - ROM Security Bit

ROMSEC enables the ROM security feature. Setting the ROMSEC bit prevents reading of the ROM contents. Access to the ROM is denied to unauthorized users of customer specified software.

- 1 = ROM security enabled
- 0 = ROM security disabled

LVIRST — Low-Voltage Inhibit Reset Bit

LVIRST enables the reset signal from the LVI module.

(See Section 11. Low-Voltage Inhibit (LVI).)

- 1 = LVI module resets enabled
- 0 = LVI module resets disabled
- LVIPWR— LVI Power Enable Bit

LVIPWR enables the LVI module. (See Section 11. Low-Voltage Inhibit (LVI).)

- 1 = LVI module power enabled
- 0 = LVI module power disabled
- SSREC Short Stop Recovery Bit

SSREC enables the CPU to exit stop mode with a delay of 32 CGMXCLK cycles instead of a 4096-CGMXCLK cycle delay. (See **10.7.2 Stop Mode**.)

1 = Stop mode recovery after 32 CGMXCLK cycles

- 0 = Stop mode recovery after 4096 CGMXCLK cycles
- **NOTE:** If using an external crystal oscillator, do not set the SSREC bit.

COPS— COP Short Timeout Bit

COPS selects the short COP timeout period. (See Section 14. Computer Operating Properly (COP).)

- 1 = COP timeout period is  $2^{13}-2^4$  CGMXCLK cycles.
- 0 = COP timeout period is  $2^{18}-2^4$  CGMXCLK cycles.
- STOP STOP Instruction Enable Bit

STOP enables the STOP instruction.

- 1 = STOP instruction enabled
- 0 = STOP instruction treated as illegal opcode
- COPD COP Disable Bit

COPD disables the COP module. (See Section 14. Computer Operating Properly (COP).)

1 = COP module disabled

0 = COP module enabled

Technical Data

# Section 6. Electrically Erasable Programmable Read-Only Memory (EEPROM)

## 6.1 Contents

| Introduction                            |
|-----------------------------------------|
| Features                                |
| Functional Description                  |
| EEPROM Programming72                    |
| EEPROM Erasing74                        |
| EEPROM Block Protection                 |
| EEPROM Redundant Mode76                 |
| EEPROM Configuration76                  |
| EEPROM Control Register                 |
| EEPROM Non-Volatile Register and EEPROM |
| Array Configuration Register            |
| Low-Power Modes                         |
| 1 Wait Mode                             |
| 2 Stop Mode                             |
|                                         |

## 6.2 Introduction

This section describes the 512 bytes of electrically erasable programmable read-only memory (EEPROM).

MC68HC08QA24

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

### 6.3 Features

EEPROM features include:

- Byte, block, or bulk erasable
- Non-volatile redundant array option
- Non-volatile block protection option
- Non-volatile MCU configuration bits
- On-chip charge pump for programming/erasing

## 6.4 Functional Description

Addresses \$0800–\$09FF are EEPROM locations. The 512 bytes of EEPROM can be programmed or erased without an external voltage supply. The EEPROM has a lifetime of 10,000 write-erase cycles in the non-redundant mode. Reliability (data retention) is further extended if the redundancy option is selected. EEPROM cells are protected with a non-volatile, 128-byte, block protection option. These options are stored in the EEPROM non-volatile register (EENVR) and are loaded into the EEPROM array configuration register (EEACR) after reset or a read of EENVR. The EEPROM array can also be disabled to reduce current.

### 6.4.1 EEPROM Programming

The unprogrammed state is a logic 1. Programming changes the state to a logic 0. Only valid EEPROM bytes in the non-protected blocks and EENVR can be programmed. When the array is configured in the redundant mode, programming the first 256 bytes addresses will also program the last 256 bytes addresses with the same data. Programming the EEPROM in the non-redundant mode is recommended. Program the data to both locations before entering the redundant mode.
Use this step-by-step procedure to program a byte of EEPROM. Refer to **23.6 Control Timing** for timing values.

- Clear EERAS1 and EERAS0 and set EELAT in the EEPROM control register (EECR) (\$FE1D). Set value of t<sub>EEPGM</sub>. (See notes a and b.)
- 2. Write the desired data to any user EEPROM address.
- 3. Set the EEPGM bit. (See note c.)
- 4. Wait for a time,  $t_{EEPGM}$ , to program the byte.
- 5. Clear the EEPGM bit.
- 6. Wait for the programming voltage time to fall, t<sub>EEFPV</sub>.
- 7. Clear EELAT bits. (See note d.)
- 8. Repeat steps 1 through 7 for more EEPROM programming.

Notes:

- a. EERAS1 and EERAS0 must be cleared for programming. Otherwise, the mode will be erase mode.
- b. Setting the EELAT bit configures the address and data buses to latch data for programming the array. Only data with a valid EEPROM address will be latched. If another consecutive valid EEPROM write occurs, this address and data will override the previous address and data. Any attempts to read other EEPROM data will read the latched data. If EELAT is set, other writes to the EECR will be allowed after a valid EEPROM write.
- c. The EEPGM bit cannot be set if the EELAT bit is cleared and a non-EEPROM write has occurred. This is to ensure proper programming sequence. When EEPGM is set, the on-board charge pump generates the program voltage and applies it to the user EEPROM array. When the EEPGM bit is cleared, the program voltage is removed from the array and the internal charge pump is turned off.
- d. Any attempt to clear both EEPGM and EELAT bits with a single instruction will clear only EEPGM to allow time for removal of high voltage from the EEPROM array.

MC68HC08QA24

#### 6.4.2 EEPROM Erasing

The unprogrammed state is a logic 1. Only the valid EEPROM bytes in the non-protected blocks and EENVR can be erased. When the array is configured in the redundant mode, erasing the first 256 bytes (\$0800–\$08FF) will also erase the last 256 bytes (\$0900–\$09FF).

Use this step-by-step procedure to erase EEPROM. Refer to **23.6 Control Timing** for timing values.

- Clear/set EERAS1 and EERAS0 to select byte/block/bulk erase, and set EELAT in EECTL. Set value of t<sub>EEBYT</sub>/t<sub>EEBLOCK</sub>/t<sub>EEBULK</sub>. (See note a.)
- 2. Write any data to the desired address for byte erase, to any address in the desired block for block erase, or to any array address for bulk erase.
- 3. Set the EEPGM bit. (See note b.)
- 4. Wait for a time, t<sub>EEPGM</sub>, to program the byte.
- 5. Clear EEPGM bit.
- 6. Wait for the erasing voltage time, t<sub>EEFPV</sub>, to fall.
- 7. Clear EELAT bits. (See note c.)
- 8. Repeat steps 1 through 7 for more EEPROM byte/block erasing.

EEBPx bit must be cleared to erase EEPROM data in the corresponding block. If any EEBPx is set, the corresponding block cannot be erased and bulk erase mode does not apply.

Notes:

a. Setting the EELAT bit configures the address and data buses to latch data for erasing the array. Only valid EEPROM addresses with their data will be latched. If another consecutive valid EEPROM write occurs, this address and data will override the previous address and data. In block erase mode, any EEPROM address in the block can be used in step 2. All locations within this block will be erased. In bulk erase mode, any EEPROM address can be used to erase the whole EEPROM. EENVR is not affected with block or bulk

**Technical Data** 

MC68HC08QA24

MOTOROLA

erase. Any attempts to read other EEPROM data will read the latched data. If EELAT is set, other writes to the EECR will be allowed after a valid EEPROM write.

- b. To ensure proper erasing sequence, the EEPGM bit cannot be set if the EELAT bit is cleared and a non-EEPROM write has occurred. Once EEPGM is set, the type of erase mode cannot be modified. If EEPGM is set, the on-board charge pump generates the erase voltage and applies it to the user EEPROM array. When the EEPGM bit is cleared, the erase voltage is removed from the array and the internal charge pump is turned off.
- c. Any attempt to clear both EEPGM and EELAT bits with a single instruction will clear only EEPGM to allow time for removal of high voltage from the EEPROM array.

In general, all bits should be erased before being programmed. However, if program/erase cycling is of concern, this procedure can be used to minimize bit cycling in each EEPROM byte. If any bit in a byte must be changed from a 0 to a 1, the byte needs to be erased before programming. **Table 6-1** summarizes the conditions for erasing before programming.

| EEPROM Data<br>To Be Programmed | EEPROM Data<br>Before Programming | Erase Before<br>Programming? |
|---------------------------------|-----------------------------------|------------------------------|
| 0                               | 0                                 | No                           |
| 0                               | 1                                 | No                           |
| 1                               | 0                                 | Yes                          |
| 1                               | 1                                 | No                           |

Table 6-1. EEPROM Program/Erase Cycling Reduction

#### 6.4.3 EEPROM Block Protection

The 512 bytes of EEPROM are divided into four 128-byte blocks. Each of these blocks can be protected separately by the EEBPx bit. Any attempt to program or erase memory locations within the protected block will not allow the program/erase voltage to be applied to the array. **Table 6-2** shows the address ranges within the blocks.

| Block Number (EEBPx) | Address Range |
|----------------------|---------------|
| EEBP0                | \$0800–\$087F |
| EEBP1                | \$0880-\$08FF |
| EEBP2                | \$0900-\$097F |
| EEBP3                | \$0980-\$09FF |

Table 6-2. EEPROM Array Address Blocks

If the EEBPx bit is set, that corresponding address block is protected. These bits are effective after a reset or a read to the EENVR. The block protect configuration can be modified by erasing/programming the corresponding bits in the EENVR register and then reading the EENVR register.

In redundant mode, EEBP3 and EEBP2 will have no meaning.

#### 6.4.4 EEPROM Redundant Mode

To extend the EEPROM data retention, the array can be placed in redundant mode. In this mode, the first 256 bytes of user EEPROM array are mapped to the last 256 bytes. Reading, programming, and erasing of the first 256 EEPROM bytes (\$0800–\$08FF) will physically affect two bytes of EEPROM. Addressing the last 256 bytes will not be recognized. Block protection still applies but EEBP3 and EEBP2 are meaningless.

**NOTE:** Before entering redundant mode, program the EEPROM in non-redundant mode.

#### 6.4.5 EEPROM Configuration

The EENVR contains configurations concerning block protection and redundancy. EENVR is physically located on the bottom of the EEPROM

Technical Data

MC68HC08QA24

MOTOROLA

array. The contents are non-volatile and are not modified by reset. On reset, this special register loads the EEPROM configuration into a corresponding volatile EEACR. Thereafter, all reads to the EENVR will reload EEACR.

The EEPROM configuration can be changed by programming/erasing the EENVR like a normal EEPROM byte. The new array configuration will take effect with a system reset or a read of the EENVR.

#### 6.4.6 EEPROM Control Register

EECR is a read/write register that controls programming/erasing of the array.

Address: \$FE1D



EEBCLK — EEPROM Bus Clock Enable Bit

This read/write bit determines which clock will be used to drive the internal charge pump for programming/erasing. Reset clears this bit.

1 = Bus clock drives charge pump.

0 = Internal RC oscillator drives charge pump.

**NOTE:** Use the internal RC oscillator for applications in the 3- to 5-V range.

EEOFF — EEPROM Power Down Bit

This read/write bit disables the EEPROM module for lower power consumption. Any attempts to access the array will give unpredictable results. Reset clears this bit.

1 = Disable EEPROM array

0 = Enable EEPROM array

MC68HC08QA24

**NOTE:** The EEPROM requires a recovery time to stabilize after clearing the EEOFF bit.

EERAS1 and EERAS0 — EEPROM Erase Bits

These read/write bits set the programming/erasing modes. Reset clears these bits.

| EEBPx | EERAS1 | EERA0 | MODE             |
|-------|--------|-------|------------------|
| 0     | 0      | 0     | Byte program     |
| 0     | 0      | 1     | Byte erase       |
| 0     | 1      | 0     | Block erase      |
| 0     | 1      | 1     | Bulk erase       |
| 1     | Х      | Х     | No erase/program |

Table 6-3. EEPROM Program/Erase Mode Select

X = don't care

EELAT — EEPROM Latch Control Bit

This read/write bit latches the address and data buses for programming the EEPROM array. EELAT cannot be cleared if EEPGM is still set. Reset clears this bit.

- 1 = Buses configured for EEPROM programming
- 0 = Buses configured for normal read operation

EEPGM — EEPROM Program/Erase Enable Bit

This read/write bit enables the internal charge pump and applies the programming/erasing voltage to the EEPROM array if the EELAT bit is set and a write to a valid EEPROM location has occurred. Reset clears the EEPGM bit.

- 1 = EEPROM programming/erasing power switched on
- 0 = EEPROM programming/erasing power switched off
- **NOTE:** Writing logic 0s to both the EELAT and EEPGM bits with a single instruction will clear only EEPGM. This is to allow time for the removal of high voltage.

**Technical Data** 

#### 6.4.7 EEPROM Non-Volatile Register and EEPROM Array Configuration Register

These registers configure the EEPROM array blocks for programming purposes. EEACR loads its contents from the EENVR register at reset and upon any read of the EENVR register.

| Address: | \$FE1F |
|----------|--------|
|          |        |

|        | Bit 7 | 6         | 5 | 4 | 3     | 2     | 1     | Bit 0 |
|--------|-------|-----------|---|---|-------|-------|-------|-------|
| Read:  | EERA  | R         | R | R | EEBP3 | EEBP2 | EEBP1 | EEBP0 |
| Write: | R     | R         | R | R | R     | R     | R     | R     |
| Reset: | EENVR | R         | R | R | EENVR | EENVR | EENVR | EENVR |
|        | R     | = Reserve | d |   |       |       |       |       |



Address: \$FE1C

|        | Bit 7 | 6         | 5 | 4 | 3     | 2     | 1     | Bit 0 |  |  |  |  |  |  |
|--------|-------|-----------|---|---|-------|-------|-------|-------|--|--|--|--|--|--|
| Read:  | EERA  | R         | R | R | FFRP3 | FFRP2 | FFRP1 | FFBP0 |  |  |  |  |  |  |
| Write: | LEIVY | K         | K | K |       |       |       |       |  |  |  |  |  |  |
| Reset: | PV    | R         | R | R | PV    | PV    | PV    | PV    |  |  |  |  |  |  |
|        | R     | = Reserve | d |   |       |       |       |       |  |  |  |  |  |  |

Figure 6-3. EEPROM Non-Volatile Register (EENVR)

EERA — EEPROM Redundant Array Bit

This programmable/eraseable/readable bit in EENVR and read-only bit in EEACR configures the array in redundant mode. Reset loads EERA from EENVR to EEACR.

1 = EEPROM array in redundant mode configuration

0 = EEPROM array in normal mode configuration

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

EEBP3–EEBP0 — EEPROM Block Protection Bits

These programmable/eraseable/readable bits in EENVR and read-only bits in EEACR select blocks of EEPROM array from being programmed or erased. Reset loads EEBP3–EEBP0 from EENVR to EEACR. See **6.4.3 EEPROM Block Protection**.

1 = EEPROM array block protected

0 = EEPROM array block unprotected

#### 6.4.8 Low-Power Modes

This subsection describes the low-power modes.

#### 6.4.8.1 Wait Mode

The WAIT instruction does not affect the EEPROM. It is possible to program the EEPROM while the MCU is in wait mode. However, if the EEPROM is inactive, power can be reduced by setting the EEOFF bit before executing the WAIT instruction.

#### 6.4.8.2 Stop Mode

The STOP instruction reduces the EEPROM power consumption to a minimum. The STOP instruction should not be executed while the high voltage is turned on (EEPGM = 1).

If stop mode is entered while program/erase is in progress, high voltage will be turned off automatically. However, the EEPGM bit will remain set. When stop mode is terminated and if EEPGM is still set, the high voltage will be turned back on automatically. Program/erase time will need to be extended if program/erase is interrupted by entering stop mode.

**NOTE:** The module requires a recovery time to stabilize after leaving stop mode. Attempts to access the array during the recovery time will result in unpredictable behavior.

# Section 7. Central Processor Unit (CPU)

#### 7.1 Contents

| 7.2                                              | Introduction                                                                                                |
|--------------------------------------------------|-------------------------------------------------------------------------------------------------------------|
| 7.3                                              | Features                                                                                                    |
| 7.4<br>7.4.1<br>7.4.2<br>7.4.3<br>7.4.4<br>7.4.5 | CPU Registers.82Accumulator.83Index Register.83Stack Pointer.84Program Counter.85Condition Code Register.86 |
| 7.5                                              | Arithmetic/Logic Unit (ALU)                                                                                 |
| 7.6                                              | CPU During Break Interrupts                                                                                 |
| 7.7                                              | Instruction Set Summary                                                                                     |
| 7.8                                              | Opcode Map                                                                                                  |

#### 7.2 Introduction

This section describes the central processor unit (CPU). The M68HC08 CPU is an enhanced and fully object-code-compatible version of the M68HC05 CPU. The *CPU08 Reference Manual*, Motorola document order number CPU08RM/AD, contains a description of the CPU instruction set, addressing modes, and architecture.

#### 7.3 Features

Features of the CPU include:

- Fully upward, object-code compatibility with the M68HC05 Family
- 16-bit stack pointer with stack manipulation instructions
- 16-bit index register with X-register manipulation instructions
- 8.4-MHz CPU internal bus frequency
- 64-Kbyte program/data memory space
- 16 addressing modes
- Memory-to-memory data moves without using accumulator
- Fast 8-bit by 8-bit multiply and 16-bit by 8-bit divide instructions
- Enhanced binary coded decimal (BCD) data handling
- Modular architecture with expandable internal bus definition for extension of addressing range beyond 64 Kbytes
- Low-power stop mode and wait mode

#### 7.4 CPU Registers

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



Figure 7-1. CPU Registers

#### 7.4.1 Accumulator

The accumulator (A) is a general-purpose 8-bit register. The CPU uses the accumulator to hold operands and the results of arithmetic/logic operations.



Figure 7-2. Accumulator (A)

#### 7.4.2 Index Register

The 16-bit index register (H:X) allows indexed addressing of a 64-Kbyte memory space. H is the upper byte of the index register, and X is the lower byte. H:X is the concatenated 16-bit index register.

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



Figure 7-3. Index Register (H:X)

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

#### 7.4.3 Stack Pointer

The stack pointer (SP) is a 16-bit register that contains the address of the next location on the stack. During a reset, the stack pointer is preset to \$00FF. The reset stack pointer (RSP) instruction sets the least significant byte to \$FF and does not affect the most significant byte. The stack pointer decrements as data is pushed onto the stack and increments as data is pulled from the stack.

In the stack pointer 8-bit offset and 16-bit offset addressing modes, the stack pointer can function as an index register to access data on the stack. The CPU uses the contents of the stack pointer to determine the conditional address of the operand.



**NOTE:** The location of the stack is arbitrary and may be relocated anywhere in RAM. Moving the SP out of page zero (\$0000 to \$00FF) frees direct address (page zero) space. For correct operation, the stack pointer must point only to RAM locations.

#### 7.4.4 Program Counter

The program counter (PC) is a 16-bit register that contains the address of the next instruction or operand to be fetched.

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

During reset, the program counter is loaded with the reset vector address located at \$FFFE and \$FFFF. The vector address is the address of the first instruction to be executed after exiting the reset state.



Figure 7-5. Program Counter (PC)

#### 7.4.5 Condition Code Register

The 8-bit condition code register (CCR) contains the interrupt mask and five flags that indicate the results of the instruction just executed. Bit 6 and bit 5 are set permanently to logic 1. This subsection describes the functions of the condition code register.



Figure 7-6. Condition Code Register (CCR)

#### V — Overflow Flag Bit

The CPU sets the overflow flag when a two's complement overflow occurs. The signed branch instructions BGT, BGE, BLE, and BLT use the overflow flag.

- 1 = Overflow
- 0 = No overflow
- H Half-Carry Flag Bit

The CPU sets the half-carry flag when a carry occurs between accumulator bits 3 and 4 during an add without carry (ADD) or add with carry (ADC) operation. The half-carry flag is required for binary coded decimal (BCD) arithmetic operations. The decimal adjust A (DAA) instruction uses the states of the H and C flags to determine the appropriate correction factor.

- 1 = Carry between bits 3 and 4
- 0 = No carry between bits 3 and 4
- I Interrupt Mask Bit

When the interrupt mask is set, all maskable CPU interrupts are disabled. CPU interrupts are enabled when the interrupt mask is cleared. When a CPU interrupt occurs, the interrupt mask is set automatically after the CPU registers are saved on the stack, but before the interrupt vector is fetched.

- 1 = Interrupts disabled
- 0 = Interrupts enabled

**NOTE:** To maintain M68HC05 compatibility, the upper byte of the index register (H) is not stacked automatically. If the interrupt service routine modifies H, then the user must stack and unstack H using the push H onto stack (PSHH) and pull H from stack (PULH) instructions.

After the I bit is cleared, the highest-priority interrupt request is serviced first.

A return-from-interrupt (RTI) instruction pulls the CPU registers from the stack and restores the interrupt mask from the stack. After any reset, the interrupt mask is set and can be cleared only by the clear interrupt mask software instruction (CLI).

N — Negative Flag Bit

The CPU sets the negative flag when an arithmetic operation, logic operation, or data manipulation produces a negative result, setting bit 7 of the result.

- 1 = Negative result
- 0 = Non-negative result
- Z Zero Flag Bit

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

- 1 = Zero result
- 0 = Non-zero result
- C Carry/Borrow Flag Bit

The CPU sets the carry/borrow flag when an addition operation produces a carry out of bit 7 of the accumulator or when a subtraction operation requires a borrow. Some instructions — such as bit test and branch, shift, and rotate — also clear or set the carry/borrow flag.

- 1 = Carry out of bit 7
- 0 = No carry out of bit 7

## 7.5 Arithmetic/Logic Unit (ALU)

The arithmetic/logic unit (ALU) performs the arithmetic and logic operations defined by the instruction set.

Refer to the *CPU08 Reference Manual*, Motorola document order number CPU08RM/AD, for a description of the instructions and addressing modes and more detail about CPU architecture.

### 7.6 CPU During Break Interrupts

If the break module is enabled, a break interrupt causes the CPU to execute the software interrupt instruction (SWI) at the completion of the current CPU instruction. See **Section 12. Break Module (Break)**. The program counter vectors to \$FFFC-\$FFFD (\$FEFC-\$FEFD in monitor mode).

A return-from-interrupt instruction (RTI) in the break routine ends the break interrupt and returns the MCU to normal operation if the break interrupt has been deasserted.

#### 7.7 Instruction Set Summary

 Table 7-1 provides a summary of the M68HC08 instruction set.

| Source                                                                                                      | Source Operation Description                            |                                                                     |    |    |   | ct<br>CR |    |    | Address<br>Mode                                                                              | Opcode                                           | Operand                                            | Cycles                               |
|-------------------------------------------------------------------------------------------------------------|---------------------------------------------------------|---------------------------------------------------------------------|----|----|---|----------|----|----|----------------------------------------------------------------------------------------------|--------------------------------------------------|----------------------------------------------------|--------------------------------------|
|                                                                                                             |                                                         |                                                                     | V  | н  | I | Ν        | z  | С  | Add<br>Mo                                                                                    | opo                                              | 0<br>D                                             | о<br>С                               |
| ADC #opr<br>ADC opr<br>ADC opr<br>ADC opr,X<br>ADC opr,X<br>ADC opr,X<br>ADC ,X<br>ADC opr,SP<br>ADC opr,SP | Add with Carry                                          | A ← (A) + (M) + (C)                                                 | \$ | \$ | _ | \$       | \$ | \$ | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP1<br>SP2                                          | A9<br>B9<br>C9<br>D9<br>E9<br>F9<br>9EE9<br>9ED9 |                                                    | 2<br>3<br>4<br>4<br>3<br>2<br>4<br>5 |
| ADD #opr<br>ADD opr<br>ADD opr<br>ADD opr,X<br>ADD opr,X<br>ADD opr,SP<br>ADD opr,SP                        | Add without Carry                                       | A ← (A) + (M)                                                       | \$ | \$ | _ | \$       | \$ | \$ | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP1<br>SP2                                          | AB<br>BB<br>CB<br>DB<br>EB<br>FB<br>9EEB<br>9EDB |                                                    | 2<br>3<br>4<br>3<br>2<br>4<br>5      |
| AIS #opr                                                                                                    | Add Immediate Value (Signed) to SP                      | $SP \leftarrow (SP) + (16 \ \ M)$                                   | -  | _  | - | -        | -  | -  | IMM                                                                                          | A7                                               | ii                                                 | 2                                    |
| AIX #opr                                                                                                    | Add Immediate Value (Signed) to H:X                     | H:X ← (H:X) + (16 ≪ M)                                              | -  | -  | - | -        | -  | -  | IMM                                                                                          | AF                                               | ii                                                 | 2                                    |
| AND #opr<br>AND opr<br>AND opr<br>AND opr,X<br>AND opr,X<br>AND ,X<br>AND opr,SP<br>AND opr,SP              | Logical AND                                             | A ← (A) & (M)                                                       | 0  | _  | _ | \$       | \$ | _  | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP1<br>SP2                                          | A4<br>B4<br>C4<br>D4<br>E4<br>F4<br>9EE4<br>9ED4 |                                                    | 2<br>3<br>4<br>4<br>3<br>2<br>4<br>5 |
| ASL opr<br>ASLA<br>ASLX<br>ASL opr,X<br>ASL ,X<br>ASL opr,SP                                                | Arithmetic Shift Left<br>(Same as LSL)                  | C - 0<br>b7 b0                                                      | \$ | _  | _ | \$       | \$ | \$ | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1                                                        | 38<br>48<br>58<br>68<br>78<br>9E68               | dd<br>ff<br>ff                                     | 4<br>1<br>4<br>3<br>5                |
| ASR opr<br>ASRA<br>ASRX<br>ASR opr,X<br>ASR opr,X<br>ASR opr,SP                                             | Arithmetic Shift Right                                  |                                                                     | \$ | _  | _ | \$       | \$ | \$ | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1                                                        | 37<br>47<br>57<br>67<br>77<br>9E67               | dd<br>ff<br>ff                                     | 4<br>1<br>4<br>3<br>5                |
| BCC rel                                                                                                     | Branch if Carry Bit Clear                               | $PC \leftarrow (PC) + 2 + rel ? (C) = 0$                            | -  | -  | - | -        | -  | -  | REL                                                                                          | 24                                               | rr                                                 | 3                                    |
| BCLR n, opr                                                                                                 | Clear Bit n in M                                        | Mn ← 0                                                              | _  | _  | _ | _        | _  | _  | DIR (b0)<br>DIR (b1)<br>DIR (b2)<br>DIR (b3)<br>DIR (b4)<br>DIR (b5)<br>DIR (b6)<br>DIR (b7) | 11<br>13<br>15<br>17<br>19<br>1B<br>1D<br>1F     | dd<br>dd<br>dd<br>dd<br>dd<br>dd<br>dd<br>dd<br>dd | 4<br>4<br>4<br>4<br>4<br>4<br>4<br>4 |
| BCS rel                                                                                                     | Branch if Carry Bit Set (Same as BLO)                   | $PC \leftarrow (PC) + 2 + \mathit{rel} ? (C) = 1$                   | -  | -  | - | -        | -  | -  | REL                                                                                          | 25                                               | rr                                                 | 3                                    |
| BEQ rel                                                                                                     | Branch if Equal                                         | $PC \leftarrow (PC) + 2 + \mathit{rel} ? (Z) = 1$                   | -  | -  | - | -        | -  | -  | REL                                                                                          | 27                                               | rr                                                 | 3                                    |
| BGE opr                                                                                                     | Branch if Greater Than or Equal To<br>(Signed Operands) | $PC \leftarrow (PC) + 2 + \mathit{rel} ? (N \oplus V) = 0$          | -  | -  | - | -        | -  | -  | REL                                                                                          | 90                                               | rr                                                 | 3                                    |
| BGT opr                                                                                                     | Branch if Greater Than (Signed Operands)                | $PC \leftarrow (PC) + 2 + \mathit{rel} ? (Z) \mid (N \oplus V) = 0$ | -  | _  | - | -        | -  | -  | REL                                                                                          | 92                                               | rr                                                 | 3                                    |

# Table 7-1. Instruction Set Summary (Sheet 1 of 7)

MC68HC08QA24

| Source<br>Form                                                                        | Operation                                         | Description                                                         |   |   | ffect on<br>CCR |    |    |    | Address<br>Mode                                                                              | Opcode                                           | Operand                                                                       | Cycles                                    |
|---------------------------------------------------------------------------------------|---------------------------------------------------|---------------------------------------------------------------------|---|---|-----------------|----|----|----|----------------------------------------------------------------------------------------------|--------------------------------------------------|-------------------------------------------------------------------------------|-------------------------------------------|
|                                                                                       |                                                   |                                                                     | ۷ | Н | I               | Ν  | z  | С  | Add                                                                                          | op                                               | 0<br>0                                                                        | Cyc                                       |
| BHCC rel                                                                              | Branch if Half Carry Bit Clear                    | $PC \leftarrow (PC) + 2 + \mathit{rel} ? (H) = 0$                   | - | - | -               | -  | -  | -  | REL                                                                                          | 28                                               | rr                                                                            | 3                                         |
| BHCS rel                                                                              | Branch if Half Carry Bit Set                      | PC ← (PC) + 2 + <i>rel</i> ? (H) = 1                                | - | - | -               | -  | -  | -  | REL                                                                                          | 29                                               | rr                                                                            | 3                                         |
| BHI rel                                                                               | Branch if Higher                                  | $PC \leftarrow (PC) + 2 + \mathit{rel} ? (C) \mid (Z) = 0$          | - | - | -               | -  | -  | -  | REL                                                                                          | 22                                               | rr                                                                            | 3                                         |
| BHS rel                                                                               | Branch if Higher or Same<br>(Same as BCC)         | $PC \leftarrow (PC) + 2 + \mathit{rel} ? (C) = 0$                   | - | _ | -               | -  | -  | _  | REL                                                                                          | 24                                               | rr                                                                            | 3                                         |
| BIH rel                                                                               | Branch if IRQ Pin High                            | $PC \leftarrow (PC) + 2 + rel ? \overline{IRQ} = 1$                 | - | - | -               | -  | -  | -  | REL                                                                                          | 2F                                               | rr                                                                            | 3                                         |
| BIL rel                                                                               | Branch if IRQ Pin Low                             | $PC \leftarrow (PC) + 2 + rel ? \overline{IRQ} = 0$                 | - | - | -               | -  | -  | -  | REL                                                                                          | 2E                                               | rr                                                                            | 3                                         |
| BIT #opr<br>BIT opr<br>BIT opr,<br>BIT opr,X<br>BIT opr,X<br>BIT opr,SP<br>BIT opr,SP | Bit Test                                          | (A) & (M)                                                           | 0 | _ | _               | \$ | \$ | _  | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP1<br>SP2                                          | A5<br>B5<br>C5<br>D5<br>E5<br>F5<br>9EE5<br>9ED5 |                                                                               | 2<br>3<br>4<br>4<br>3<br>2<br>4<br>5      |
| BLE opr                                                                               | Branch if Less Than or Equal To (Signed Operands) | $PC \leftarrow (PC) + 2 + \mathit{rel} ? (Z) \mid (N \oplus V) = 1$ | - | _ | 1               | -  | -  | -  | REL                                                                                          | 93                                               | rr                                                                            | 3                                         |
| BLO rel                                                                               | Branch if Lower (Same as BCS)                     | $PC \leftarrow (PC) + 2 + \mathit{rel} ? (C) = 1$                   | - | - | _               | -  | -  | -  | REL                                                                                          | 25                                               | rr                                                                            | 3                                         |
| BLS rel                                                                               | Branch if Lower or Same                           | $PC \gets (PC) + 2 + \mathit{rel} ? (C) \mid (Z) = 1$               | - | - | -               | -  | -  | -  | REL                                                                                          | 23                                               | rr                                                                            | 3                                         |
| BLT opr                                                                               | Branch if Less Than (Signed Operands)             | $PC \gets (PC) + 2 + \mathit{rel} ? (N \oplus V) = 1$               | - | _ | -               | -  | -  | -  | REL                                                                                          | 91                                               | rr                                                                            | 3                                         |
| BMC rel                                                                               | Branch if Interrupt Mask Clear                    | $PC \leftarrow (PC) + 2 + \mathit{rel} ? (I) = 0$                   | - | - |                 | -  | -  | -  | REL                                                                                          | 2C                                               | rr                                                                            | 3                                         |
| BMI rel                                                                               | Branch if Minus                                   | $PC \leftarrow (PC) + 2 + \mathit{rel} ? (N) = 1$                   | - | - | -               | -  | -  | -  | REL                                                                                          | 2B                                               | rr                                                                            | 3                                         |
| BMS rel                                                                               | Branch if Interrupt Mask Set                      | $PC \leftarrow (PC) + 2 + \mathit{rel} ? (I) = 1$                   | - | - | _               | -  | -  | -  | REL                                                                                          | 2D                                               | rr                                                                            | 3                                         |
| BNE rel                                                                               | Branch if Not Equal                               | $PC \leftarrow (PC) + 2 + \mathit{rel} ? (Z) = 0$                   | - | _ | I               | -  | -  | -  | REL                                                                                          | 26                                               | rr                                                                            | 3                                         |
| BPL rel                                                                               | Branch if Plus                                    | $PC \leftarrow (PC) + 2 + \mathit{rel} ? (N) = 0$                   | - | _ | -               | -  | -  | -  | REL                                                                                          | 2A                                               | rr                                                                            | 3                                         |
| BRA rel                                                                               | Branch Always                                     | $PC \gets (PC) + 2 + \mathit{rel}$                                  | - | - | -               | -  | -  | -  | REL                                                                                          | 20                                               | rr                                                                            | 3                                         |
| BRCLR n,opr,rel                                                                       | Branch if Bit <i>n</i> in M Clear                 | PC ← (PC) + 3 + <i>rel</i> ? (Mn) = 0                               | _ | _ | _               | _  | _  | \$ | DIR (b0)<br>DIR (b1)<br>DIR (b2)<br>DIR (b3)<br>DIR (b4)<br>DIR (b5)<br>DIR (b6)<br>DIR (b7) | 01<br>03<br>05<br>07<br>09<br>0B<br>0D<br>0F     | dd rr<br>dd rr<br>dd rr<br>dd rr<br>dd rr<br>dd rr<br>dd rr<br>dd rr          | ភភភភភភភភភ                                 |
| BRN rel                                                                               | Branch Never                                      | $PC \gets (PC) + 2$                                                 | - | - | _               | -  | -  | -  | REL                                                                                          | 21                                               | rr                                                                            | 3                                         |
| BRSET n,opr,rel                                                                       | Branch if Bit <i>n</i> in M Set                   | PC ← (PC) + 3 + <i>rel</i> ? (Mn) = 1                               | _ | _ | _               | _  | _  | \$ | DIR (b0)<br>DIR (b1)<br>DIR (b2)<br>DIR (b3)<br>DIR (b4)<br>DIR (b5)<br>DIR (b6)<br>DIR (b7) | 00<br>02<br>04<br>06<br>08<br>0A<br>0C<br>0E     | dd rr<br>dd rr<br>dd rr<br>dd rr<br>dd rr<br>dd rr<br>dd rr<br>dd rr<br>dd rr | 55555555<br>55555555555555555555555555555 |

| Source<br>Form                                                                                        | Operation                     | Description                                                                                                                                                                                                                                                                                                                                   |    | Ef |   | ct<br>CR |    | _  | Address<br>Mode                                                                              | Opcode                                           | Operand                                            | Cycles                               |
|-------------------------------------------------------------------------------------------------------|-------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|---|----------|----|----|----------------------------------------------------------------------------------------------|--------------------------------------------------|----------------------------------------------------|--------------------------------------|
|                                                                                                       |                               |                                                                                                                                                                                                                                                                                                                                               | V  | Н  | I | Ν        | z  | С  | Ado<br>Ado                                                                                   | do                                               | do                                                 | о<br>С                               |
| BSET n,opr                                                                                            | Set Bit <i>n</i> in M         | Mn ← 1                                                                                                                                                                                                                                                                                                                                        |    | -  | _ | -        | _  | _  | DIR (b0)<br>DIR (b1)<br>DIR (b2)<br>DIR (b3)<br>DIR (b4)<br>DIR (b5)<br>DIR (b6)<br>DIR (b7) | 10<br>12<br>14<br>16<br>18<br>1A<br>1C<br>1E     | dd<br>dd<br>dd<br>dd<br>dd<br>dd<br>dd<br>dd<br>dd | 4<br>4<br>4<br>4<br>4<br>4<br>4<br>4 |
| BSR rel                                                                                               | Branch to Subroutine          | $\begin{array}{c} PC \leftarrow (PC) + 2;  push \; (PCL) \\ SP \leftarrow (SP) - 1;  push \; (PCH) \\ SP \leftarrow (SP) - 1 \\ PC \leftarrow (PC) + \mathit{rel} \end{array}$                                                                                                                                                                | _  | _  | _ | _        | _  | _  | REL                                                                                          | AD                                               | rr                                                 | 4                                    |
| CBEQ opr,rel<br>CBEQA #opr,rel<br>CBEQX #opr,rel<br>CBEQ opr,X+,rel<br>CBEQ X+,rel<br>CBEQ opr,SP,rel | Compare and Branch if Equal   | $\begin{array}{l} PC \leftarrow (PC) + 3 + rel ? (A) - (M) = \$00 \\ PC \leftarrow (PC) + 3 + rel ? (A) - (M) = \$00 \\ PC \leftarrow (PC) + 3 + rel ? (X) - (M) = \$00 \\ PC \leftarrow (PC) + 3 + rel ? (A) - (M) = \$00 \\ PC \leftarrow (PC) + 2 + rel ? (A) - (M) = \$00 \\ PC \leftarrow (PC) + 4 + rel ? (A) - (M) = \$00 \end{array}$ | _  | _  | _ | _        | _  | _  | DIR<br>IMM<br>IMM<br>IX1+<br>IX+<br>SP1                                                      | 31<br>41<br>51<br>61<br>71<br>9E61               | dd rr<br>ii rr<br>ii rr<br>ff rr<br>rr<br>ff rr    | 544546                               |
| CLC                                                                                                   | Clear Carry Bit               | $C \leftarrow 0$                                                                                                                                                                                                                                                                                                                              | -  | -  | - | -        | -  | 0  | INH                                                                                          | 98                                               |                                                    | 1                                    |
| CLI                                                                                                   | Clear Interrupt Mask          | $I \leftarrow 0$                                                                                                                                                                                                                                                                                                                              | -  | -  | 0 | -        | -  | -  | INH                                                                                          | 9A                                               |                                                    | 2                                    |
| CLR opr<br>CLRA<br>CLRX<br>CLRH<br>CLR opr,X<br>CLR ,X<br>CLR ,X<br>CLR opr,SP                        | Clear                         | $\begin{array}{c} M \leftarrow \$00\\ A \leftarrow \$00\\ X \leftarrow \$00\\ H \leftarrow \$00\\ M \leftarrow \$00\\ M \leftarrow \$00\\ M \leftarrow \$00\\ M \leftarrow \$00 \end{array}$                                                                                                                                                  | 0  | _  | _ | 0        | 1  | -  | DIR<br>INH<br>INH<br>INH<br>IX1<br>IX<br>SP1                                                 | 3F<br>4F<br>5F<br>8C<br>6F<br>7F<br>9E6F         | dd<br>ff<br>ff                                     | 3<br>1<br>1<br>3<br>2<br>4           |
| CMP #opr<br>CMP opr<br>CMP opr,<br>CMP opr,X<br>CMP opr,X<br>CMP ,X<br>CMP opr,SP<br>CMP opr,SP       | Compare A with M              | (A) – (M)                                                                                                                                                                                                                                                                                                                                     | \$ | _  | _ | \$       | \$ | \$ | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP1<br>SP2                                          | A1<br>B1<br>C1<br>E1<br>F1<br>9EE1<br>9ED1       | ii<br>dd<br>hh II<br>ee ff<br>ff<br>ee ff          | 2<br>3<br>4<br>4<br>3<br>2<br>4<br>5 |
| COM opr<br>COMA<br>COMX<br>COM opr,X<br>COM opr,SP                                                    | Complement (One's Complement) | $\begin{array}{c} M \leftarrow (\overline{M}) = \$FF - (M) \\ A \leftarrow (\overline{A}) = \$FF - (M) \\ X \leftarrow (X) = \$FF - (M) \\ M \leftarrow (\underline{M}) = \$FF - (M) \\ M \leftarrow (\underline{M}) = \$FF - (M) \\ M \leftarrow (M) = \$FF - (M) \\ M \leftarrow (M) = \$FF - (M) \end{array}$                              | 0  | _  | _ | \$       | \$ | 1  | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1                                                        | 33<br>43<br>53<br>63<br>73<br>9E63               | dd<br>ff<br>ff                                     | 4<br>1<br>4<br>3<br>5                |
| CPHX #opr<br>CPHX opr                                                                                 | Compare H:X with M            | (H:X) – (M:M + 1)                                                                                                                                                                                                                                                                                                                             | \$ | -  | - | \$       | \$ | \$ | IMM<br>DIR                                                                                   | 65<br>75                                         | ii ii+1<br>dd                                      | 3<br>4                               |
| CPX #opr<br>CPX opr<br>CPX opr<br>CPX ,X<br>CPX opr,X<br>CPX opr,X<br>CPX opr,SP<br>CPX opr,SP        | Compare X with M              | (X) – (M)                                                                                                                                                                                                                                                                                                                                     | \$ | _  | _ | \$       | \$ | \$ | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP1<br>SP2                                          | A3<br>B3<br>C3<br>D3<br>E3<br>F3<br>9EE3<br>9ED3 | ii<br>dd<br>hh II<br>ee ff<br>ff<br>ee ff          | 2<br>3<br>4<br>3<br>2<br>4<br>5      |
| DAA                                                                                                   | Decimal Adjust A              | (A) <sub>10</sub>                                                                                                                                                                                                                                                                                                                             | U  | -  | - | \$       | \$ | \$ | INH                                                                                          | 72                                               |                                                    | 2                                    |

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

| Source<br>Form                                                                                           | Operation                        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |    | Ef |   | ct<br>CR |    |    | Address<br>Mode                                     | Opcode                                           | Operand                                      | sels                                 |
|----------------------------------------------------------------------------------------------------------|----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|---|----------|----|----|-----------------------------------------------------|--------------------------------------------------|----------------------------------------------|--------------------------------------|
| Form                                                                                                     | •                                |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | ۷  | Н  | I | Ν        | Z  | С  | Adc<br>Mog                                          | odo                                              | ope                                          | Cycles                               |
| DBNZ opr,rel<br>DBNZA rel<br>DBNZX rel<br>DBNZ opr,X,rel<br>DBNZ X,rel<br>DBNZ opr,SP,rel                | Decrement and Branch if Not Zero | $\begin{array}{l} A \leftarrow (A) - 1 \text{ or } M \leftarrow (M) - 1 \text{ or } X \leftarrow (X) - 1 \\ PC \leftarrow (PC) + 3 + \mathit{rel} ? (\mathit{result}) \neq 0 \\ PC \leftarrow (PC) + 2 + \mathit{rel} ? (\mathit{result}) \neq 0 \\ PC \leftarrow (PC) + 2 + \mathit{rel} ? (\mathit{result}) \neq 0 \\ PC \leftarrow (PC) + 3 + \mathit{rel} ? (\mathit{result}) \neq 0 \\ PC \leftarrow (PC) + 2 + \mathit{rel} ? (\mathit{result}) \neq 0 \\ PC \leftarrow (PC) + 4 + \mathit{rel} ? (\mathit{result}) \neq 0 \end{array}$ | _  | _  | _ | _        | _  | _  | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1               | 3B<br>4B<br>5B<br>6B<br>7B<br>9E6B               | dd rr<br>rr<br>fr<br>ff rr<br>ff rr<br>ff rr | 5<br>3<br>3<br>5<br>4<br>6           |
| DEC opr<br>DECA<br>DECX<br>DEC opr,X<br>DEC ,X<br>DEC opr,SP                                             | Decrement                        | $\begin{array}{c} M \leftarrow (M) - 1 \\ A \leftarrow (A) - 1 \\ X \leftarrow (X) - 1 \\ M \leftarrow (M) - 1 \\ M \leftarrow (M) - 1 \\ M \leftarrow (M) - 1 \end{array}$                                                                                                                                                                                                                                                                                                                                                                   | \$ | _  | _ | \$       | \$ | _  | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1               | 3A<br>4A<br>5A<br>6A<br>7A<br>9E6A               | dd<br>ff<br>ff                               | 4<br>1<br>4<br>3<br>5                |
| DIV                                                                                                      | Divide                           | $A \leftarrow (H:A)/(X)$<br>H $\leftarrow$ Remainder                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | -  | -  | - | -        | \$ | \$ | INH                                                 | 52                                               |                                              | 7                                    |
| EOR #opr<br>EOR opr<br>EOR opr<br>EOR opr,X<br>EOR opr,X<br>EOR ,X<br>EOR opr,SP<br>EOR opr,SP           | Exclusive OR M with A            | $A \gets (A \oplus M)$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 0  | _  | _ | \$       | \$ | _  | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP1<br>SP2 | A8<br>B8<br>C8<br>D8<br>E8<br>F8<br>9EE8<br>9ED8 | ii<br>dd<br>hh II<br>ee ff<br>ff<br>ee ff    | 2<br>3<br>4<br>3<br>2<br>4<br>5      |
| INC opr<br>INCA<br>INCX<br>INC opr,X<br>INC ,X<br>INC opr,SP                                             | Increment                        | $\begin{array}{c} M \leftarrow (M) + 1 \\ A \leftarrow (A) + 1 \\ X \leftarrow (X) + 1 \\ M \leftarrow (M) + 1 \\ M \leftarrow (M) + 1 \\ M \leftarrow (M) + 1 \end{array}$                                                                                                                                                                                                                                                                                                                                                                   | \$ | _  | _ | \$       | \$ | _  | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1               | 3C<br>4C<br>5C<br>6C<br>7C<br>9E6C               | dd<br>ff<br>ff                               | 4<br>1<br>4<br>3<br>5                |
| JMP opr<br>JMP opr<br>JMP opr,X<br>JMP opr,X<br>JMP ,X                                                   | Jump                             | $PC \gets Jump \; Address$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | _  | -  | _ | _        | -  | -  | DIR<br>EXT<br>IX2<br>IX1<br>IX                      | BC<br>CC<br>DC<br>EC<br>FC                       | dd<br>hh II<br>ee ff<br>ff                   | 2<br>3<br>4<br>3<br>2                |
| JSR opr<br>JSR opr<br>JSR opr,X<br>JSR opr,X<br>JSR ,X                                                   | Jump to Subroutine               | $\begin{array}{l} PC \leftarrow (PC) + n  (n = 1, 2,  \mathrm{or}  3) \\ Push  (PCL);  SP \leftarrow (SP) - 1 \\ Push  (PCH);  SP \leftarrow (SP) - 1 \\ PC \leftarrow Unconditional  Address \end{array}$                                                                                                                                                                                                                                                                                                                                    | _  | _  | _ | _        | _  | -  | DIR<br>EXT<br>IX2<br>IX1<br>IX                      | BD<br>CD<br>DD<br>ED<br>FD                       | dd<br>hh II<br>ee ff<br>ff                   | 4<br>5<br>6<br>5<br>4                |
| LDA #opr<br>LDA opr<br>LDA opr<br>LDA opr,X<br>LDA opr,X<br>LDA,X<br>LDA opr,SP<br>LDA opr,SP            | Load A from M                    | A ← (M)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0  | _  | _ | \$       | \$ | _  | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP1<br>SP2 | A6<br>B6<br>C6<br>E6<br>F6<br>9EE6<br>9ED6       |                                              | 2<br>3<br>4<br>3<br>2<br>4<br>5      |
| LDHX #opr<br>LDHX opr                                                                                    | Load H:X from M                  | H:X ← (M:M + 1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 0  | -  | - | \$       | \$ | -  | IMM<br>DIR                                          | 45<br>55                                         | ii jj<br>dd                                  | 3<br>4                               |
| LDX #opr<br>LDX opr<br>LDX opr<br>LDX opr,X<br>LDX opr,X<br>LDX ,X<br>LDX ,X<br>LDX opr,SP<br>LDX opr,SP | Load X from M                    | X ← (M)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | 0  | _  | _ | \$       | \$ | _  | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP1<br>SP2 | AE<br>BE<br>CE<br>DE<br>EE<br>FE<br>9EEE<br>9EDE | ii<br>dd<br>hh II<br>ee ff<br>ff<br>ee ff    | 2<br>3<br>4<br>4<br>3<br>2<br>4<br>5 |

**Technical Data** 

MOTOROLA

| Source<br>Form                                                                       | Operation                           | Description                                                                                                                                                                                           |    | Ef | Effect or<br>CCR |    |    |    |                                                     |                                                  |                            |                                 | Address<br>Mode | Opcode | Operand | Cycles |
|--------------------------------------------------------------------------------------|-------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|------------------|----|----|----|-----------------------------------------------------|--------------------------------------------------|----------------------------|---------------------------------|-----------------|--------|---------|--------|
| 1 Onn                                                                                |                                     |                                                                                                                                                                                                       | V  | Н  | I                | Ν  | Z  | С  | Add                                                 | odo                                              | ope                        | о<br>С                          |                 |        |         |        |
| LSL opr<br>LSLA<br>LSLX<br>LSL opr,X<br>LSL ,X<br>LSL opr,SP                         | Logical Shift Left<br>(Same as ASL) | C-0<br>b7 b0                                                                                                                                                                                          | \$ | -  |                  | \$ | \$ | €  | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1               | 38<br>48<br>58<br>68<br>78<br>9E68               | dd<br>ff<br>ff             | 4<br>1<br>4<br>3<br>5           |                 |        |         |        |
| LSR opr<br>LSRA<br>LSRX<br>LSR opr,X<br>LSR ,X<br>LSR opr,SP                         | Logical Shift Right                 |                                                                                                                                                                                                       | \$ | _  | _                | 0  | \$ | \$ | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1               | 34<br>44<br>54<br>64<br>74<br>9E64               | dd<br>ff<br>ff             | 4<br>1<br>4<br>3<br>5           |                 |        |         |        |
| MOV opr,opr<br>MOV opr,X+<br>MOV #opr,opr<br>MOV X+,opr                              | Move                                | $\begin{array}{l} (M)_{Destination} \leftarrow (M)_{Source} \\ H:X \leftarrow (H:X) + 1 \; (IX+D, DIX+) \end{array}$                                                                                  | 0  | _  | _                | \$ | \$ | _  | DD<br>DIX+<br>IMD<br>IX+D                           | 4E<br>5E<br>6E<br>7E                             | dd dd<br>dd<br>ii dd<br>dd | 5<br>4<br>4<br>4                |                 |        |         |        |
| MUL                                                                                  | Unsigned multiply                   | $X:A \leftarrow (X) \times (A)$                                                                                                                                                                       | -  | 0  | -                | -  | -  | 0  | INH                                                 | 42                                               |                            | 5                               |                 |        |         |        |
| NEG opr<br>NEGA<br>NEGX<br>NEG opr,X<br>NEG opr,SP                                   | Negate (Two's Complement)           | $\begin{array}{l} M \leftarrow -(M) = \$00 - (M) \\ A \leftarrow -(A) = \$00 - (A) \\ X \leftarrow -(X) = \$00 - (X) \\ M \leftarrow -(M) = \$00 - (M) \\ M \leftarrow -(M) = \$00 - (M) \end{array}$ | \$ | _  | _                | \$ | \$ | \$ | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1               | 30<br>40<br>50<br>60<br>70<br>9E60               | dd<br>ff<br>ff             | 4<br>1<br>4<br>3<br>5           |                 |        |         |        |
| NOP                                                                                  | No Operation                        | None                                                                                                                                                                                                  | -  | -  | -                | -  | -  | -  | INH                                                 | 9D                                               |                            | 1                               |                 |        |         |        |
| NSA                                                                                  | Nibble Swap A                       | A ← (A[3:0]:A[7:4])                                                                                                                                                                                   | -  | -  | -                | -  | -  | -  | INH                                                 | 62                                               |                            | 3                               |                 |        |         |        |
| ORA #opr<br>ORA opr<br>ORA opr<br>ORA opr,X<br>ORA opr,X<br>ORA opr,SP<br>ORA opr,SP | Inclusive OR A and M                | A ← (A)   (M)                                                                                                                                                                                         | 0  | _  |                  | \$ | ¢  | _  | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP1<br>SP2 | AA<br>BA<br>CA<br>DA<br>EA<br>FA<br>9EEA<br>9EDA |                            | 2<br>3<br>4<br>3<br>2<br>4<br>5 |                 |        |         |        |
| PSHA                                                                                 | Push A onto Stack                   | $Push\:(A);SP \leftarrow (SP) - 1$                                                                                                                                                                    | -  | -  | -                | -  | -  | -  | INH                                                 | 87                                               |                            | 2                               |                 |        |         |        |
| PSHH                                                                                 | Push H onto Stack                   | $Push\:(H);SP\leftarrow(SP)-1$                                                                                                                                                                        | -  | -  | -                | -  | -  | -  | INH                                                 | 8B                                               |                            | 2                               |                 |        |         |        |
| PSHX                                                                                 | Push X onto Stack                   | $Push\:(X);SP\leftarrow(SP)-1$                                                                                                                                                                        | -  | -  | -                | -  | -  | -  | INH                                                 | 89                                               |                            | 2                               |                 |        |         |        |
| PULA                                                                                 | Pull A from Stack                   | $SP \leftarrow (SP + 1); Pull (A)$                                                                                                                                                                    | -  | -  | -                | -  | -  | -  | INH                                                 | 86                                               |                            | 2                               |                 |        |         |        |
| PULH                                                                                 | Pull H from Stack                   | $SP \leftarrow (SP + 1); Pull (H)$                                                                                                                                                                    | -  | -  | -                | -  | -  | -  | INH                                                 | 8A                                               |                            | 2                               |                 |        |         |        |
| PULX                                                                                 | Pull X from Stack                   | $SP \leftarrow (SP + 1); Pull (X)$                                                                                                                                                                    | -  | -  | -                | -  | -  | -  | INH                                                 | 88                                               |                            | 2                               |                 |        |         |        |
| ROL opr<br>ROLA<br>ROLX<br>ROL opr,X<br>ROL ,X<br>ROL opr,SP                         | Rotate Left through Carry           | b7 b0                                                                                                                                                                                                 | \$ | _  | _                | \$ | \$ | \$ | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1               | 39<br>49<br>59<br>69<br>79<br>9E69               | dd<br>ff<br>ff             | 4<br>1<br>4<br>3<br>5           |                 |        |         |        |
| ROR opr<br>RORA<br>RORX<br>ROR opr,X<br>ROR ,X<br>ROR opr,SP                         | Rotate Right through Carry          |                                                                                                                                                                                                       | \$ | _  | _                | \$ | \$ | \$ | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1               | 36<br>46<br>56<br>66<br>76<br>9E66               | dd<br>ff<br>ff             | 4<br>1<br>4<br>3<br>5           |                 |        |         |        |

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

MC68HC08QA24

| Source<br>Form                                                                                         | Operation                       | Description                                                                                                                                                                                                                                                                                                                                                              |    | Ef | CCR |    |    |     |                                                     |                                                  |                                     | Opcode                               | Operand | Cycles |
|--------------------------------------------------------------------------------------------------------|---------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|----|-----|----|----|-----|-----------------------------------------------------|--------------------------------------------------|-------------------------------------|--------------------------------------|---------|--------|
| Form                                                                                                   |                                 |                                                                                                                                                                                                                                                                                                                                                                          | V  | Н  | I   | Ν  | Z  | С   | Mod                                                 | obdo                                             | do                                  | о<br>С                               |         |        |
| RSP                                                                                                    | Reset Stack Pointer             | -                                                                                                                                                                                                                                                                                                                                                                        | -  | -  | -   | -  | -  | INH | 9C                                                  |                                                  | 1                                   |                                      |         |        |
| RTI                                                                                                    | Return from Interrupt           | $\begin{array}{c} SP \leftarrow (SP) + 1;  Pull  (CCR) \\ SP \leftarrow (SP) + 1;  Pull  (A) \\ SP \leftarrow (SP) + 1;  Pull  (X) \\ SP \leftarrow (SP) + 1;  Pull  (PCH) \\ SP \leftarrow (SP) + 1;  Pull  (PCL) \end{array}$                                                                                                                                          | \$ | \$ | \$  | \$ | \$ | \$  | INH                                                 | 80                                               |                                     | 7                                    |         |        |
| RTS                                                                                                    | Return from Subroutine          | $\begin{array}{l} SP \leftarrow SP + 1; Pull \ (PCH) \\ SP \leftarrow SP + 1; \ Pull \ (PCL) \end{array}$                                                                                                                                                                                                                                                                | -  | -  | -   | -  | -  | -   | INH                                                 | 81                                               |                                     | 4                                    |         |        |
| SBC #opr<br>SBC opr<br>SBC opr<br>SBC opr,X<br>SBC opr,X<br>SBC,X<br>SBC,X<br>SBC opr,SP<br>SBC opr,SP | Subtract with Carry             | $A \gets (A) - (M) - (C)$                                                                                                                                                                                                                                                                                                                                                | \$ | _  | _   | \$ | \$ | \$  | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP1<br>SP2 | A2<br>B2<br>C2<br>D2<br>E2<br>F2<br>9EE2<br>9ED2 |                                     | 2<br>3<br>4<br>4<br>3<br>2<br>4<br>5 |         |        |
| SEC                                                                                                    | Set Carry Bit                   | C ← 1                                                                                                                                                                                                                                                                                                                                                                    | -  | -  | -   | -  | -  | 1   | INH                                                 | 99                                               |                                     | 1                                    |         |        |
| SEI                                                                                                    | Set Interrupt Mask              | I ← 1                                                                                                                                                                                                                                                                                                                                                                    | -  | -  | 1   | -  | -  | -   | INH                                                 | 9B                                               |                                     | 2                                    |         |        |
| STA opr<br>STA opr<br>STA opr,X<br>STA opr,X<br>STA ,X<br>STA opr,SP<br>STA opr,SP                     | Store A in M                    | M ← (A)                                                                                                                                                                                                                                                                                                                                                                  | 0  | _  | _   | \$ | \$ | _   | DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP1<br>SP2        | B7<br>C7<br>D7<br>E7<br>F7<br>9EE7<br>9ED7       | dd<br>hh II<br>ee ff<br>ff<br>ee ff | 3<br>4<br>3<br>2<br>4<br>5           |         |        |
| STHX opr                                                                                               | Store H:X in M                  | $(M{:}M+1) \leftarrow (H{:}X)$                                                                                                                                                                                                                                                                                                                                           | 0  | -  | -   | \$ | \$ | -   | DIR                                                 | 35                                               | dd                                  | 4                                    |         |        |
| STOP                                                                                                   | Enable IRQ Pin; Stop Oscillator | $I \leftarrow 0$ ; Stop Oscillator                                                                                                                                                                                                                                                                                                                                       | -  | -  | 0   | -  | -  | -   | INH                                                 | 8E                                               |                                     | 1                                    |         |        |
| STX opr<br>STX opr<br>STX opr,X<br>STX opr,X<br>STX opr,X<br>STX opr,SP<br>STX opr,SP                  | Store X in M                    | M ← (X)                                                                                                                                                                                                                                                                                                                                                                  | 0  | _  | _   | \$ | \$ | _   | DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP1<br>SP2        | BF<br>CF<br>DF<br>EF<br>FF<br>9EEF<br>9EDF       | dd<br>hh II<br>ee ff<br>ff<br>ee ff | 3<br>4<br>3<br>2<br>4<br>5           |         |        |
| SUB #opr<br>SUB opr<br>SUB opr,X<br>SUB opr,X<br>SUB opr,X<br>SUB ,X<br>SUB opr,SP<br>SUB opr,SP       | Subtract                        | $A \gets (A) - (M)$                                                                                                                                                                                                                                                                                                                                                      | \$ | _  | _   | \$ | \$ | \$  | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP1<br>SP2 | A0<br>B0<br>C0<br>D0<br>E0<br>F0<br>9EE0<br>9ED0 |                                     | 2<br>3<br>4<br>4<br>3<br>2<br>4<br>5 |         |        |
| swi                                                                                                    | Software Interrupt              | $\begin{array}{c} PC \leftarrow (PC) + 1;  Push  (PCL) \\ SP \leftarrow (SP) - 1;  Push  (PCH) \\ SP \leftarrow (SP) - 1;  Push  (X) \\ SP \leftarrow (SP) - 1;  Push  (A) \\ SP \leftarrow (SP) - 1;  Push  (CCR) \\ SP \leftarrow (SP) - 1; 1 \leftarrow 1 \\ PCH \leftarrow Interrupt  Vector  High  Byte \\ PCL \leftarrow Interrupt  Vector  Low  Byte \end{array}$ | _  | _  | 1   | _  | _  | _   | INH                                                 | 83                                               |                                     | 9                                    |         |        |
| ТАР                                                                                                    | Transfer A to CCR               | $CCR \leftarrow (A)$                                                                                                                                                                                                                                                                                                                                                     | \$ | \$ | \$  | \$ | \$ | \$  | INH                                                 | 84                                               |                                     | 2                                    |         |        |
| TAX                                                                                                    | Transfer A to X                 | $X \gets (A)$                                                                                                                                                                                                                                                                                                                                                            | -  | -  | -   | -  | -  | -   | INH                                                 | 97                                               |                                     | 1                                    |         |        |

**Technical Data** 

MOTOROLA

| Source                                                                                                                                                                                                                  | Operation                                                                                               | on                   | Effect on<br>CCR |   |   |   |                                         |                                    | Mode<br>Opcode | Operand               | Cvcles |   |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------|----------------------|------------------|---|---|---|-----------------------------------------|------------------------------------|----------------|-----------------------|--------|---|
| Form                                                                                                                                                                                                                    | •                                                                                                       | •                    |                  | V | Н | I | Ν                                       | z                                  | Address        |                       | Ope    |   |
| TPA                                                                                                                                                                                                                     | Transfer CCR to A                                                                                       | $A \gets (CCR$       | )                | - | - | - | -                                       | -                                  | – INH          | 85                    |        | 1 |
| TST opr<br>TSTA<br>TSTX<br>TST opr,X<br>TST ,X<br>TST opr,SP                                                                                                                                                            | or (M) – \$00                                                                                           | 0                    | _                | _ | ¢ | ¢ | – DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1 | 3D<br>4D<br>5D<br>6D<br>7D<br>9E6D | dd<br>ff<br>ff | 3<br>1<br>3<br>2<br>4 |        |   |
| TSX                                                                                                                                                                                                                     | Transfer SP to H:X         H:X ← (SP) + 1         -         -         -         -         -         INH |                      |                  |   |   |   |                                         |                                    |                |                       |        |   |
| ТХА                                                                                                                                                                                                                     | Transfer X to AA $\leftarrow$ (X)                                                                       |                      |                  |   |   |   |                                         |                                    |                |                       |        | 1 |
| TXS                                                                                                                                                                                                                     | Transfer H:X to SP                                                                                      | $(SP) \gets (H{:}X)$ | – 1              | - | - | - | -                                       | -                                  | – INH          | 94                    |        | 2 |
| TXATransfer X to A $A \leftarrow (X)$ $                                                                                                                                                                    -$ <td></td> |                                                                                                         |                      |                  |   |   |   |                                         |                                    |                |                       |        |   |

#### Table 7-1. Instruction Set Summary (Sheet 7 of 7)

# 7.8 Opcode Map

#### The opcode map is provided in Table 7-2.

MC68HC08QA24

Central Processor Unit (CPU)

**Technical Data** 

|            |                      |                     |                    |                    |                     |                          |                     | lable              | 7-2. U             | pcou                    | e iviap           |                   |                   |                   |                   |                   |                   |                   |                  |
|------------|----------------------|---------------------|--------------------|--------------------|---------------------|--------------------------|---------------------|--------------------|--------------------|-------------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|
|            | Bit Mani             | pulation            | Branch             |                    |                     | Read-Mo                  | dify-Write          |                    |                    | Control Register/Memory |                   |                   |                   |                   |                   |                   |                   |                   |                  |
|            | DIR                  | DIR                 | REL                | DIR                | INH                 | INH                      | IX1                 | SP1                | IX                 | INH                     | INH               | IMM               | DIR               | EXT               | IX2               | SP2               | IX1               | SP1               | IX               |
| MSB<br>LSB | 0                    | 1                   | 2                  | 3                  | 4                   | 5                        | 6                   | 9E6                | 7                  | 8                       | 9                 | Α                 | в                 | с                 | D                 | 9ED               | E                 | 9EE               | F                |
| 0          | 5<br>BRSET0<br>3 DIR | 4<br>BSET0<br>2 DIR |                    |                    | 1<br>NEGA<br>1 INH  | 1<br>NEGX<br>1 INH       |                     |                    | 3<br>NEG<br>1 IX   | 7<br>RTI<br>1 INH       |                   |                   | 3<br>SUB<br>2 DIR | 4<br>SUB<br>3 EXT |                   | 5<br>SUB<br>4 SP2 | 3<br>SUB<br>2 IX1 | 4<br>SUB<br>3 SP1 | 2<br>SUB<br>1 IX |
| 1          | 5<br>BRCLR0<br>3 DIR | 4<br>BCLR0<br>2 DIR |                    | 5<br>CBEQ<br>3 DIR | 4<br>CBEQA<br>3 IMM |                          | 5<br>CBEQ<br>3 IX1+ | 6<br>CBEQ<br>4 SP1 |                    | 4<br>RTS<br>1 INH       | BLT<br>2 REL      | 2<br>CMP<br>2 IMM | 3<br>CMP<br>2 DIR | 4<br>CMP<br>3 EXT | 4<br>CMP<br>3 IX2 | 5<br>CMP<br>4 SP2 | 3<br>CMP<br>2 IX1 | 4<br>CMP<br>3 SP1 | 2<br>CMP<br>1 IX |
| 2          |                      | 4<br>BSET1<br>2 DIR |                    |                    | 5<br>MUL<br>1 INH   | 7<br>DIV<br>1 INH        | 3<br>NSA<br>1 INH   |                    | 2<br>DAA<br>1 INH  |                         | BGT<br>2 REL      | 2<br>SBC<br>2 IMM | 3<br>SBC<br>2 DIR | 3 EXT             | 4<br>SBC<br>3 IX2 | 5<br>SBC<br>4 SP2 | 3<br>SBC<br>2 IX1 | 4<br>SBC<br>3 SP1 |                  |
| 3          | 5<br>BRCLR1<br>3 DIR | 4<br>BCLR1<br>2 DIR | 3<br>BLS<br>2 REL  |                    | 1<br>COMA<br>1 INH  | 1<br>COMX<br>1 INH       | 4<br>COM<br>2 IX1   | 5<br>COM<br>3 SP1  | 3<br>COM<br>1 IX   |                         | BLE<br>2 REL      |                   |                   | 4<br>CPX<br>3 EXT |                   | 5<br>CPX<br>4 SP2 |                   | 4<br>CPX<br>3 SP1 |                  |
| 4          | -                    | 4<br>BSET2<br>2 DIR | BCC<br>2 REL       | 4<br>LSR<br>2 DIR  | 1<br>LSRA<br>1 INH  | 1<br>LSRX<br>1 INH       | 4<br>LSR<br>2 IX1   | 5<br>LSR<br>3 SP1  | 3<br>LSR<br>1 IX   | 2<br>TAP<br>1 INH       | 2<br>TXS<br>1 INH |                   | 3<br>AND<br>2 DIR | 4<br>AND<br>3 EXT | 4<br>AND<br>3 IX2 | 5<br>AND<br>4 SP2 | 3<br>AND<br>2 IX1 | 4<br>AND<br>3 SP1 |                  |
| 5          | 3 DIR                | 4<br>BCLR2<br>2 DIR |                    |                    | 3<br>LDHX<br>3 IMM  | 4<br>LDHX<br>2 DIR       |                     |                    | 4<br>CPHX<br>2 DIR | 1<br>TPA<br>1 INH       | TSX<br>1 INH      |                   |                   |                   |                   | 5<br>BIT<br>4 SP2 |                   | 4<br>BIT<br>3 SP1 |                  |
| 6          | -                    | 4<br>BSET3<br>2 DIR | 3<br>BNE<br>2 REL  | 4<br>ROR<br>2 DIR  | 1<br>RORA<br>1 INH  | 1<br>RORX<br>1 INH       | 4<br>ROR<br>2 IX1   | 5<br>ROR<br>3 SP1  | 3<br>ROR<br>1 IX   | 2<br>PULA<br>1 INH      |                   | 2<br>LDA<br>2 IMM | 3<br>LDA<br>2 DIR | 4<br>LDA<br>3 EXT | 4<br>LDA<br>3 IX2 | 5<br>LDA<br>4 SP2 | 3<br>LDA<br>2 IX1 | 4<br>LDA<br>3 SP1 | 2<br>LDA<br>1 IX |
| 7          | 5<br>BRCLR3<br>3 DIR | 4<br>BCLR3<br>2 DIR | 3<br>BEQ<br>2 REL  | 4<br>ASR<br>2 DIR  | 1<br>ASRA<br>1 INH  | 1<br>ASRX<br>1 INH       | 4<br>ASR<br>2 IX1   | 5<br>ASR<br>3 SP1  | 3<br>ASR<br>1 IX   | 2<br>PSHA<br>1 INH      | 1<br>TAX<br>1 INH |                   | 3<br>STA<br>2 DIR | 4<br>STA<br>3 EXT | 4<br>STA<br>3 IX2 | 5<br>STA<br>4 SP2 | 3<br>STA<br>2 IX1 | 4<br>STA<br>3 SP1 | 2<br>STA<br>1 IX |
| 8          | 5<br>BRSET4<br>3 DIR | 4<br>BSET4<br>2 DIR | 3<br>BHCC<br>2 REL | 4<br>LSL<br>2 DIR  | 1<br>LSLA<br>1 INH  | 1<br>LSLX<br>1 INH       | 4<br>LSL<br>2 IX1   | 5<br>LSL<br>3 SP1  | 3<br>LSL<br>1 IX   | 2<br>PULX<br>1 INH      | 1<br>CLC<br>1 INH | 2<br>EOR<br>2 IMM | 3<br>EOR<br>2 DIR | 4<br>EOR<br>3 EXT | 4<br>EOR<br>3 IX2 | 5<br>EOR<br>4 SP2 | 3<br>EOR<br>2 IX1 | 4<br>EOR<br>3 SP1 | 2<br>EOR<br>1 IX |
| 9          | 5<br>BRCLR4<br>3 DIR | 4<br>BCLR4<br>2 DIR | 3<br>BHCS<br>2 REL | 4<br>ROL<br>2 DIR  | 1<br>ROLA<br>1 INH  | 1<br>ROLX<br>1 INH       | 4<br>ROL<br>2 IX1   | 5<br>ROL<br>3 SP1  | 3<br>ROL<br>1 IX   | 2<br>PSHX<br>1 INH      | 1<br>SEC<br>1 INH | 2<br>ADC<br>2 IMM | 3<br>ADC<br>2 DIR | 4<br>ADC<br>3 EXT | 4<br>ADC<br>3 IX2 | 5<br>ADC<br>4 SP2 | ADC<br>2 IX1      | 4<br>ADC<br>3 SP1 | 2<br>ADC<br>1 IX |
| Α          | 5<br>BRSET5<br>3 DIR | 4<br>BSET5<br>2 DIR | 3<br>BPL<br>2 REL  | 4<br>DEC<br>2 DIR  | 1<br>DECA<br>1 INH  | 1<br>DECX<br>1 INH       | 4<br>DEC<br>2 IX1   | 5<br>DEC<br>3 SP1  | 3<br>DEC<br>1 IX   | 2<br>PULH<br>1 INH      | 2<br>CLI<br>1 INH | 2<br>ORA<br>2 IMM | 3<br>ORA<br>2 DIR | 4<br>ORA<br>3 EXT | 4<br>ORA<br>3 IX2 | 5<br>ORA<br>4 SP2 | 3<br>ORA<br>2 IX1 | 4<br>ORA<br>3 SP1 | 2<br>ORA<br>1 IX |
| В          | 5<br>BRCLR5<br>3 DIR | 4<br>BCLR5<br>2 DIR |                    | 5<br>DBNZ<br>3 DIR | 3<br>DBNZA<br>2 INH | 3<br>DBNZX<br>2 INH<br>1 | 5<br>DBNZ<br>3 IX1  | 6<br>DBNZ<br>4 SP1 | 4<br>DBNZ<br>2 IX  | 2<br>PSHH<br>1 INH      | 2<br>SEI<br>1 INH | 2<br>ADD<br>2 IMM | 3<br>ADD<br>2 DIR | 4<br>ADD<br>3 EXT | 4<br>ADD<br>3 IX2 | 5<br>ADD<br>4 SP2 | 3<br>ADD<br>2 IX1 | 4<br>ADD<br>3 SP1 |                  |
| с          | 5<br>BRSET6<br>3 DIR | 4<br>BSET6<br>2 DIR | 3<br>BMC<br>2 REL  | 4<br>INC<br>2 DIR  | INCA                | 1<br>INCX<br>1 INH       | INĊ                 | 5<br>INC<br>3 SP1  | 3<br>INC<br>1 IX   | 1<br>CLRH<br>1 INH      | 1<br>RSP<br>1 INH |                   | 2<br>JMP<br>2 DIR | 3<br>JMP<br>3 EXT | 4<br>JMP<br>3 IX2 |                   | 3<br>JMP<br>2 IX1 |                   | 2<br>JMP<br>1 IX |
| D          |                      | 4<br>BCLR6<br>2 DIR |                    | TST<br>2 DIR       | 1<br>TSTA<br>1 INH  | 1<br>TSTX<br>1 INH       | 3<br>TST<br>2 IX1   | 4<br>TST<br>3 SP1  | 2<br>TST<br>1 IX   |                         | 1<br>NOP<br>1 INH |                   | 4<br>JSR<br>2 DIR | JSR<br>3 EXT      | 6<br>JSR<br>3 IX2 |                   | 5<br>JSR<br>2 IX1 |                   | 4<br>JSR<br>1 IX |
| E          |                      | 4<br>BSET7<br>2 DIR |                    |                    | 5<br>MOV<br>3 DD    | 4<br>MOV<br>2 DIX+       | 4<br>MOV<br>3 IMD   |                    | 4<br>MOV<br>2 IX+D | 1<br>STOP<br>1 INH      | *                 | 2<br>LDX<br>2 IMM |                   | 4<br>LDX<br>3 EXT |                   | 5<br>LDX<br>4 SP2 |                   | 4<br>LDX<br>3 SP1 |                  |
| F          | 5<br>BRCLR7<br>3 DIR | 4<br>BCLR7<br>2 DIR | BIH                | 3<br>CLR<br>2 DIR  | 1<br>CLRA<br>1 INH  | 1<br>CLRX<br>1 INH       | 3<br>CLR<br>2 IX1   | 4<br>CLR<br>3 SP1  | 2<br>CLR<br>1 IX   | 1<br>WAIT<br>1 INH      | 1<br>TXA<br>1 INH | 2<br>AIX<br>2 IMM | 3<br>STX<br>2 DIR | 4<br>STX<br>3 EXT | 4<br>STX<br>3 IX2 | 5<br>STX<br>4 SP2 | 3<br>STX<br>2 IX1 | 4<br>STX<br>3 SP1 | STX<br>1 IX      |

MOTOROLA

IX Indexed, No Offset IX1 Indexed, 8-Bit Offset IX2 Indexed, 16-Bit Offset IMD Immediate-Direct DIX+ Direct-Indexed EXT Extended DD Direct-Direct IX+D Indexed-Direct

**REL** Relative

- SP1 Stack Pointer, 8-Bit Offset SP2 Stack Pointer, 16-Bit Offset IX+ Indexed, No Offset with

- Post Increment IX1+ Indexed, 1-Byte Offset with Post Increment

LSB

Low Byte of Opcode in Hexadecimal

MSB

0

0 High Byte of Opcode in Hexadecimal

5 Cycles BRSET0 Opcode Mnemonic 3 DIR Number of Bytes / Addressing Mode

\*Pre-byte for stack pointer indexed instructions

INH Inherent IMM Immediate DIR Direct

# Section 8. Error Detection Central Processor Unit (EDC)

#### 8.1 Contents

| 8.2 | Introduction             |
|-----|--------------------------|
| 8.3 | Features                 |
| 8.4 | Functional Description98 |
| 8.5 | FLT Pin                  |
| 8.6 | EDC Control Register     |

#### 8.2 Introduction

This section describes the error detection central processor unit (EDC, version 0) which is based on the CPU08, version A. The M68HC08 CPU is an enhanced and fully object-code-compatible version of the M68HC05 CPU. The error detection CPU is a duplicate CPU which runs synchronously with the primary CPU. The EDC operates on all data in parallel with the primary CPU, executing all of the same instruction flows. In addition to the duplicate CPU, the EDC contains circuits for comparing address and data with the primary CPU. If either the address or data values do not match, an internal reset is asserted.

MC68HC08QA24

## 8.3 Features

Features of the EDC include:

- Separate compare of data, low address byte, high address byte
- Control register bits for forcing mismatch conditions for testing
- Output pin active on EDC reset only; cleared by software or power-on reset (POR)

## 8.4 Functional Description

The EDC performs a cycle-by-cycle compare of address and data information. In the event that the address or the data generated by the duplicate CPU does not match the value on the internal bus, then an internal reset occurs. This reset functions in the same manner as all other internal resets in the HC08 (see **10.4.2 Active Resets from Internal Sources**) except that the FLT pin is asserted. This pin remains active low until it is cleared by software.

The block diagram for the EDC, in **Figure 8-1**, shows that the compare is done in three segments:

- Address low (lower byte of address)
- Address high (upper byte of address)
- Data

These circuits perform a compare of the address and data values generated by the duplicate CPU with the values on the internal bus on every machine cycle.

On a read cycle, the duplicate CPU latches data provided by the data buffers. No data compare happens on read cycles since the EDC data bus is driven with the same value as the system data bus. On write cycles, the data buffers are three-stated and the data circuit compares the value being written by the duplicate CPU to that being written by the primary CPU.

**NOTE:** It is necessary to initialize all CPU internal registers before any of those registers are output from the CPU by an instruction or by stacking. This

**Technical Data** 

is because the internal registers such as the accumulator are not initialized by reset so the EDC CPU and the primary CPU may have different values upon power-up.



Figure 8-1. EDC Block Diagram

## 8.5 FLT Pin

This pin is unaffected by all resets except for the error detect reset. On the occurrence of a mismatch between the CPU and the EDC on any address or data, the pin is driven to a logic 0 and remains low until it is cleared by storing a 0 to bit 7of the EDC control register.

### 8.6 EDC Control Register

The control register for the EDC is shown in **Figure 8-2**. The bits in this register are used to simulate an error condition in each of the compare circuits. When a write to the register is done, it is followed by an internal reset if the data to any of the three control bits is a logic 1.



#### SFLTP — Set FLT Pin

This bit always reads as a 0. A logic 1 is set on the occurrence of an error detect reset. It is cleared by writing a 0.

#### FDB — Force Data Bus Bit

Writing a 1 to this bit forces the output of the data bus compare to generate a reset. The bit will be set on failure to compare data.

- 1 = Generate reset
- 0 = No reset

#### FABH — Force Address Bus High Bit

Writing a 1 to this bit forces the output of the address bus high compare to generate a reset. The bit will be set on failure to compare high address.

1 = Generate reset 0 = No reset

#### FABL — Force Address Bus Low Bit

Writing a 1 to this bit forces the output of the address bus low compare to generate a reset. The bit will be set on failure to compare low address.

1 = Generate reset

0 = No reset

MC68HC08QA24

**Technical Data** 

# Section 9. Clock Generator Module (CGM)

## 9.1 Contents

| 9.2                                                                         | Introduction                                                                                                                                                                                                                                                                                                                           |
|-----------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9.3                                                                         | Features                                                                                                                                                                                                                                                                                                                               |
| 9.4<br>9.4.1<br>9.4.2<br>9.4.2<br>9.4.2<br>9.4.2<br>9.4.2<br>9.4.2<br>9.4.2 | Phase-Locked Loop Circuit (PLL)107Circuits107Acquisition and Tracking Modes109Manual and Automatic PLL Bandwidth Modes109Programming the PLL111Special Programming Exceptions113                                                                                                                                                       |
| 9.4.3<br>9.4.4                                                              |                                                                                                                                                                                                                                                                                                                                        |
| 9.5<br>9.5.1<br>9.5.2<br>9.5.3<br>9.5.4<br>9.5.5<br>9.5.6<br>9.5.7<br>9.5.8 | Crystal Amplifier Output Pin (OSC2)       .115         External Filter Capacitor Pin (CGMXFC)       .115         Analog Power Pin (V <sub>DDA</sub> )       .116         Oscillator Enable Signal (SIMOSCEN)       .116         Crystal Output Frequency Signal (CGMXCLK)       .116         CGM Base Clock Output (CGMOUT)       .116 |
| 9.6<br>9.6.1<br>9.6.2<br>9.6.3                                              | PLL Bandwidth Control Register                                                                                                                                                                                                                                                                                                         |
| 9.7                                                                         | Interrupts                                                                                                                                                                                                                                                                                                                             |
| 9.8                                                                         | Special Modes                                                                                                                                                                                                                                                                                                                          |

MC68HC08QA24

| 9.8.1  | Wait Mode                              |
|--------|----------------------------------------|
| 9.8.2  | Stop Mode                              |
| 9.9 C  | GM During Break Interrupts             |
| 9.10 A | cquisition/Lock Time Specifications    |
| 9.10.1 | Acquisition/Lock Time Definitions      |
| 9.10.2 | Parametric Influences on Reaction Time |
| 9.10.3 | Choosing a Filter Capacitor            |

#### 9.2 Introduction

This section describes the clock generator module (CGM). The CGM generates the crystal clock signal, CGMXCLK, which operates at the frequency of the crystal. The CGM also generates the base clock signal, CGMOUT, from which the system integration module (SIM) derives the system clocks. CGMOUT is based on either the crystal clock divided by two or the phase-locked loop (PLL) clock, CGMVCLK, divided by two. The PLL is a frequency generator designed for use with 1-MHz to 16-MHz crystals or ceramic resonators. The PLL can generate an 8-MHz bus frequency without using a 32-MHz crystal.

#### 9.3 Features

Features of the CGM include:

- PLL with output frequency in integer multiples of the crystal reference
- Programmable hardware voltage-controlled oscillator (VCO) for low-jitter operation
- Automatic bandwidth control mode for low-jitter operation
- Automatic frequency lock detector
- CPU interrupt on entry or exit from locked condition

## 9.4 Functional Description

The CGM consists of three major submodules:

- Crystal oscillator circuit The crystal oscillator circuit generates the constant crystal frequency clock, CGMXCLK.
- Phase-locked loop (PLL) The PLL generates the programmable VCO frequency clock CGMVCLK.
- Base clock selector circuit This software-controlled circuit selects either CGMXCLK divided by two or the VCO clock, CGMVCLK, divided by two as the base clock, CGMOUT. The SIM derives the system clocks from CGMOUT.

**Figure 9-1** shows the structure of the CGM. **Figure 9-2** shows a summary of the input/output (I/O) registers.

#### 9.4.1 Crystal Oscillator Circuit

The crystal oscillator circuit consists of an inverting amplifier and an external crystal. The OSC1 pin is the input to the amplifier and the OSC2 pin is the output. The SIMOSCEN signal from the system integration module (SIM) enables the crystal oscillator circuit.

CGMXCLK can be used by other modules which require precise timing for operation. The duty cycle of CGMXCLK is not guaranteed to be 50 percent and depends on external factors, including the crystal and related external components.

An externally generated clock also can feed the OSC1 pin of the crystal oscillator circuit. Connect the external clock to the OSC1 pin and let the OSC2 pin float.

MC68HC08QA24

# **Clock Generator Module (CGM)**



Figure 9-1. CGM Block Diagram

**Technical Data** 

| Addr.  | Register Name                            |                 | Bit 7 | 6         | 5     | 4    | 3    | 2    | 1    | Bit 0 |
|--------|------------------------------------------|-----------------|-------|-----------|-------|------|------|------|------|-------|
|        |                                          | Read:           | PLLIE | PLLF      | PLLON | BCS  | 1    | 1    | 1    | 1     |
| \$001C | PLL Control Register<br>(PCTL)           | Write:          | FLLIC | R         | TLEON | DCS  | R    | R    | R    | R     |
|        | · · ·                                    | Reset:          | 0     | 0         | 1     | 0    | 1    | 1    | 1    | 1     |
|        |                                          | Read:           | AUTO  | LOCK      | ACQ   | XLD  | 0    | 0    | 0    | 0     |
| \$001D | PLL Bandwidth Control<br>Register (PBWC) | Write:          | 7010  | R         | AUQ   | ALD  | R    | R    | R    | R     |
|        | •                                        | Reset:          | 0     | 0         | 0     | 0    | 0    | 0    | 0    | 0     |
| \$001E | DLL Drogramming Dogistor                 | Read:<br>Write: | MUL7  | MUL6      | MUL5  | MUL4 | VRS7 | VRS6 | VRS5 | VRS4  |
|        | F                                        | Reset:          | 0     | 1         | 1     | 0    | 0    | 1    | 1    | 0     |
|        |                                          |                 | R     | = Reserve | ed    |      |      |      |      |       |

Figure 9-2. CGM I/O Register Summary

#### 9.4.2 Phase-Locked Loop Circuit (PLL)

The PLL is a frequency generator that can operate in either acquisition mode or tracking mode, depending on the accuracy of the output frequency. The PLL can change between acquisition and tracking modes either automatically or manually. Refer to **23.9 CGM Operating Conditions** for operating frequencies while reading this section.

#### 9.4.2.1 Circuits

The PLL consists of these circuits:

- Voltage-controlled oscillator (VCO)
- Modulo VCO frequency divider
- Phase detector
- Loop filter
- Lock detector

The operating range of the VCO is programmable for a wide range of frequencies and for maximum immunity to external noise, including supply and CGMXFC noise. For maximum immunity guidelines, refer to:

- Designing for Electromagnetic Compatibility (EMC) with HCMOS Microcontrollers, Motorola document order number AN1050/D
- Designing for Electromagnetic Compatibility with Single-Chip Microcontrollers, Motorola document order number AN1263

These application notes on electromagnetic compatibility are available from local Motorola sales offices.) The VCO frequency is bound to a range from roughly one-half to twice the center-of-range frequency,  $f_{VRS}$ . Modulating the voltage on the CGMXFC pin changes the frequency within this range. By design,  $f_{VRS}$  is equal to the nominal center-of-range frequency,  $f_{NOM}$ , 4.9152 MHz times a linear factor (L) or  $f_{NOM}$ .

CGMXCLK is the PLL reference clock which runs at the crystal frequency,  ${\rm f}_{\rm XCLK},$ 

The VCO's output clock, CGMVCLK, running at a frequency  $f_{VCLK}$  is fed back through a programmable modulo divider. The modulo divider reduces the VCO clock by a factor, N (see **9.4.2.4 Programming the PLL**). The divider's output is the VCO feedback clock, CGMVDV, running at a frequency equal to  $f_{VCLK}/N$ . See **23.9 CGM Operating Conditions** for more information.

The phase detector then compares the VCO feedback clock (CGMVDV) with the reference clock (CGMXCLK). A correction pulse is generated based on the phase difference between the two signals. The loop filter then slightly alters the dc voltage on the external capacitor connected to CGMXFC, based on the width and direction of the correction pulse. The filter can make fast or slow corrections, depending on its mode, described in **9.4.2.2 Acquisition and Tracking Modes**. The value of the external capacitor and the reference frequency determines the speed of the corrections and the stability of the PLL.

The lock detector compares the frequencies of the VCO feedback clock, CGMVDV, and the reference clock, CGMXCLK. Therefore, the speed of the lock detector is directly proportional to the reference frequency,  $f_{XCLK}$ . The circuit determines the mode of the PLL and the lock condition based on this comparison.
### 9.4.2.2 Acquisition and Tracking Modes

The PLL filter is manually or automatically configurable into one of two operating modes:

- Acquisition mode In acquisition mode, the filter can make large frequency corrections to the VCO (see 23.11 CGM Acquisition/Lock Time Information). This mode is used at PLL startup or when the PLL has suffered a severe noise hit and the VCO frequency is far off the desired frequency. When in acquisition mode, the ACQ bit is clear in the PLL bandwidth control register (see 9.6.2 PLL Bandwidth Control Register).
- Tracking mode In tracking mode, the filter makes only small corrections to the frequency of the VCO (see 23.11 CGM Acquisition/Lock Time Information). PLL jitter is much lower in tracking mode, but the response to noise is also slower. The PLL enters tracking mode when the VCO frequency is nearly correct, such as when the PLL is selected as the base clock source (see 9.4.3 Base Clock Selector Circuit). The PLL is automatically in tracking mode when not in acquisition mode or when the ACQ bit is set.

### 9.4.2.3 Manual and Automatic PLL Bandwidth Modes

The PLL can change the bandwidth or operational mode of the loop filter manually or automatically.

In automatic bandwidth control mode (AUTO = 1), the lock detector automatically switches between acquisition and tracking modes. Automatic bandwidth control mode also is used to determine when the VCO clock, CGMVCLK, is safe to use as the source for the base clock, CGMOUT. (See **9.6.2 PLL Bandwidth Control Register**.) If PLL interrupts are enabled, the software can wait for a PLL interrupt request and then check the LOCK bit. If interrupts are disabled, software can poll the LOCK bit continuously (during PLL startup, usually) or at periodic intervals. In either case, when the LOCK bit is set, the VCO clock is safe to use as the source for the base clock. (See **9.4.3 Base Clock Selector Circuit**.) If the VCO is selected as the source for the base clock and the LOCK bit is clear, the PLL has suffered a severe noise hit and the

MC68HC08QA24

software must take appropriate action, depending on the application. See **9.7 Interrupts** for information and precautions on using interrupts.

These conditions apply when the PLL is in automatic bandwidth control mode:

- The ACQ bit is a read-only indicator of the mode of the filter. See 9.6.2 PLL Bandwidth Control Register and 9.4.2.2 Acquisition and Tracking Modes.
- The ACQ bit is set when the VCO frequency is within a certain tolerance, Δ<sub>TRK</sub>, and is cleared when the VCO frequency is out of a certain tolerance, Δ<sub>UNT</sub>. See 9.10 Acquisition/Lock Time Specifications for more information.
- The LOCK bit is a read-only indicator of the locked state of the PLL.
- The LOCK bit is set when the VCO frequency is within a certain tolerance,  $\Delta_{Lock}$ , and is cleared when the VCO frequency is out of a certain tolerance,  $\Delta_{UNL}$ . See 9.10 Acquisition/Lock Time Specifications for more information.
- CPU interrupts can occur if enabled (PLLIE = 1) when the PLL's lock condition changes, toggling the LOCK bit. (See 9.6.1 PLL Control Register.)

The PLL also can operate in manual mode (AUTO = 0). Manual mode is used by systems that do not require an indicator of the lock condition for proper operation. Such systems typically operate well below  $f_{BUSMAX}$  and require fast startup.

These conditions apply when in manual mode:

- ACQ is a writable control bit that controls the mode of the filter. Before turning on the PLL in manual mode, the ACQ bit must be clear.
- Before entering tracking mode (ACQ = 1), software must wait a given time, t<sub>ACQ</sub> (see 9.10 Acquisition/Lock Time Specifications), after turning on the PLL by setting PLLON in the PLL control register (PCTL).

110

- Software must wait a given time, t<sub>AL</sub>, after entering tracking mode before selecting the PLL as the clock source to CGMOUT (BCS = 1).
- The LOCK bit is disabled.
- CPU interrupts from the CGM are disabled.

### 9.4.2.4 Programming the PLL

Use this procedure to program the PLL:

1. Choose the desired bus frequency, f<sub>BUSDES</sub>.

Example:  $f_{BUSDES} = 8 MHz$ 

2. Calculate the desired VCO frequency, f<sub>VCLKDES</sub>.

 $f_{VCLKDES} = 4 \times f_{BUSDES}$ Example:  $f_{VCLKDES} = 4 \times 8$  MHz = 32 MHz

- 3. Using a reference frequency, f<sub>XCLK</sub>, equal to the crystal frequency, calculate the VCO frequency multiplier, N.
- **NOTE:** The round function means that the result is rounded to the nearest integer.

$$N = round\left(\frac{f_{VCLKDES}}{f_{xCLK}}\right)$$

Example: = 
$$\frac{32 \text{ MHz}}{4 \text{ MHz}}$$
 = 8 MHz

4. Calculate the VCO frequency, f<sub>VCLK</sub>.

$$f_{VCLK} = N \times f_{xCLK}$$

Example: 
$$f_{VCLK} = 8 \times 4$$
 MHz = 32 MHz

MC68HC08QA24

5. Calculate the bus frequency,  $f_{BUS}$ , and compare  $f_{BUS}$  with  $f_{BUSDES}$ . If the calculated  $f_{BUS}$  is not within the tolerance limits of your application, select another  $f_{BUSDES}$  or another  $f_{XCLK}$ .

$$f_{BUS} = \frac{f_{VCLK}}{4}$$

Example: 
$$f_{BUS} = \frac{32 \text{ MHz}}{4} = 8 \text{ MHz}$$

 Using the value 4.9152 MHz for f<sub>NOM</sub>, calculate the VCO linear range multiplier, L. The linear range multiplier controls the frequency range of the PLL.

$$L = round \left(\frac{f_{VCLK}}{f_{NOM}}\right)$$

Example: L = 
$$\frac{32 \text{ MHz}}{4.9152 \text{ MHz}}$$
 = 7

 Calculate the VCO center-of-range frequency, f<sub>VRS</sub>. The center-of-range frequency is the midpoint between the minimum and maximum frequencies attainable by the PLL.

$$f_{VRS} = L \times f_{NOM}$$
 Example:  $f_{VRS} = 7 \times 4.9152 \text{ MHz} = 34.4 \text{ MHz}$ 

**NOTE:** Exceeding the recommended maximum bus frequency or VCO frequency can crash the MCU.

For proper operation,

$$|f_{\text{VRS}} - f_{\text{VCLK}}| \leq \frac{f_{\text{NOM}}}{2}$$

MC68HC08QA24

112

- 8. Program the PLL registers accordingly:
  - a. In the upper four bits of the PLL programming register (PPG), program the binary equivalent of N.
  - b. In the lower four bits of the PLL programming register (PPG), program the binary equivalent of L.

### 9.4.2.5 Special Programming Exceptions

The programming method described in **9.4.2.4 Programming the PLL** does not account for two possible exceptions. A value of 0 for N or L is meaningless when used in the equations given. To account for these exceptions:

- A 0 value for N is interpreted exactly the same as a value of 1.
- A 0 value for L disables the PLL and prevents its selection as the source for the base clock. (See 9.4.3 Base Clock Selector Circuit.)

#### 9.4.3 Base Clock Selector Circuit

This circuit is used to select either the crystal clock (CGMXCLK) or the VCO clock (CGMVCLK) as the source of the base clock (CGMOUT). The two input clocks go through a transition control circuit that waits up to three CGMXCLK cycles and three CGMVCLK cycles to change from one clock source to the other. During this time, CGMOUT is held in stasis. The output of the transition control circuit is then divided by two to correct the duty cycle. Therefore, the bus clock frequency, which is one-half of the base clock frequency, is one-fourth the frequency of the selected clock (CGMXCLK or CGMVCLK).

The BCS bit in the PLL control register (PCTL) selects which clock drives CGMOUT. The VCO clock cannot be selected as the base clock source if the PLL is not turned on. The PLL cannot be turned off if the VCO clock is selected. The PLL cannot be turned on or off simultaneously with the selection or deselection of the VCO clock. The VCO clock also cannot be selected as the base clock source if the factor L is programmed to a 0. This value would set up a condition inconsistent with the operation of

the PLL, so that the PLL would be disabled and the crystal clock would be forced as the source of the base clock.

### 9.4.4 CGM External Connections

In its typical configuration, the CGM requires seven external components. Five of these are for the crystal oscillator and two are for the PLL.

The crystal oscillator is normally connected in a Pierce oscillator configuration, as shown in **Figure 9-3**. **Figure 9-3** shows only the logical representation of the internal components and may not represent actual circuitry. The oscillator configuration uses five components:

- 1. Crystal, X<sub>1</sub>
- 2. Fixed capacitor, C1
- 3. Tuning capacitor, C2, can also be a fixed capacitor
- 4. Feedback resistor, R<sub>B</sub>
- 5. Series resistor, R<sub>S</sub>, optional

The series resistor  $(R_S)$  is included in the diagram to follow strict Pierce oscillator guidelines and may not be required for all ranges of operation, especially with high-frequency crystals. Refer to the crystal manufacturer's data for more information.

Figure 9-3 also shows the external components for the PLL:

- Bypass capacitor, C<sub>BYP</sub>
- Filter capacitor, C<sub>F</sub>

Routing should be done with great care to minimize signal cross talk and noise. See **9.10 Acquisition/Lock Time Specifications** for routing information and more information on the filter capacitor's value and its effects on PLL performance.



\*R<sub>s</sub> can be 0 (shorted) when used with higher-frequency crystals. Refer to manufacturer's data.

### Figure 9-3. CGM External Connections

### 9.5 I/O Signals

This section describes the CGM input/output (I/O) signals.

### 9.5.1 Crystal Amplifier Input Pin (OSC1)

The OSC1 pin is an input to the crystal oscillator amplifier.

### 9.5.2 Crystal Amplifier Output Pin (OSC2)

The OSC2 pin is the output of the crystal oscillator inverting amplifier.

### 9.5.3 External Filter Capacitor Pin (CGMXFC)

The CGMXFC pin is required by the loop filter to filter out phase corrections. A small external capacitor is connected to this pin.

**NOTE:** To prevent noise problems,  $C_F$  should be placed as close to the CGMXFC pin as possible, with minimum routing distances and no routing of other signals across the  $C_F$  connection.

MC68HC08QA24

### 9.5.4 Analog Power Pin (V<sub>DDA</sub>)

 $V_{DDA}$  is a power pin used by the analog portions of the PLL. Connect the  $V_{DDA}$  pin to the same voltage potential as the  $V_{DD}$  pin.

**NOTE:** Route V<sub>DDA</sub> carefully for maximum noise immunity and place bypass capacitors as close as possible to the package.

### 9.5.5 Oscillator Enable Signal (SIMOSCEN)

The SIMOSCEN signal comes from the system integration module (SIM) and enables the oscillator and PLL.

### 9.5.6 Crystal Output Frequency Signal (CGMXCLK)

CGMXCLK is the crystal oscillator output signal. It runs at the full speed of the crystal,  $f_{XCLK}$ , and comes directly from the crystal oscillator circuit. **Figure 9-3** shows only the logical relation of CGMXCLK to OSC1 and OSC2 and may not represent the actual circuitry. The duty cycle of CGMXCLK is unknown and may depend on the crystal and other external factors. Also, the frequency and amplitude of CGMXCLK can be unstable at startup.

### 9.5.7 CGM Base Clock Output (CGMOUT)

CGMOUT is the clock output of the CGM. This signal goes to the SIM, which generates the MCU clocks. CGMOUT is a 50 percent duty cycle clock running at twice the bus frequency. CGMOUT is software programmable to be either the oscillator output, CGMXCLK, divided by two or the VCO clock, CGMVCLK, divided by two.

### 9.5.8 CGM CPU Interrupt (CGMINT)

CGMINT is the interrupt signal generated by the PLL lock detector.

### 9.6 CGM Registers

These registers control and monitor operation of the CGM:

- PLL control register (PCTL) described in 9.6.1 PLL Control Register
- PLL bandwidth control register (PBWC) described in 9.6.2 PLL Bandwidth Control Register
- PLL programming register (PPG) described in 9.6.3 PLL Programming Register

Figure 9-4 is a summary of the CGM registers.



NOTES:

1. When AUTO = 0, PLLIE is forced to logic 0 and is read-only.

2. When AUTO = 0, PLLF and LOCK read as logic 0.

3. When AUTO = 1,  $\overline{ACQ}$  is read-only.

4. When PLLON = 0 or VRS[7:4] = \$0, BCS is forced to logic 0 and is read-only.

5. When PLLON = 1, the PLL programming register is read-only.

6. When BCS = 1, PLLON is forced set and is read-only.

### Figure 9-4. CGM I/O Register Summary

### 9.6.1 PLL Control Register

The PLL control register (PCTL) contains the interrupt enable and flag bits, the on/off switch, and the base clock selector bit.



PLLIE — PLL Interrupt Enable Bit

This read/write bit enables the PLL to generate an interrupt request when the LOCK bit toggles, setting the PLL flag, PLLF. When the AUTO bit in the PLL bandwidth control register (PBWC) is clear, PLLIE cannot be written and reads as logic 0. Reset clears the PLLIE bit.

1 = PLL interrupts enabled

0 = PLL interrupts disabled

PLLF — PLL Flag Bit

This read-only bit is set whenever the LOCK bit toggles. PLLF generates an interrupt request if the PLLIE bit also is set. PLLF always reads as logic 0 when the AUTO bit in the PLL bandwidth control register (PBWC) is clear. Clear the PLLF bit by reading the PLL control register. Reset clears the PLLF bit.

- 1 = Change in lock condition
- 0 = No change in lock condition
- **NOTE:** Do not inadvertently clear the PLLF bit. Any read or read-modify-write operation on the PLL control register clears the PLLF bit.

PLLON — PLL On Bit

This read/write bit activates the PLL and enables the VCO clock, CGMVCLK. PLLON cannot be cleared if the VCO clock is driving the base clock, CGMOUT (BCS = 1). (See **9.4.3 Base Clock Selector Circuit**.) Reset sets this bit so that the loop can stabilize as the MCU is powering up.

1 = PLL on

$$0 = PLL off$$

BCS — Base Clock Select Bit

This read/write bit selects either the crystal oscillator output, CGMXCLK, or the VCO clock, CGMVCLK, as the source of the CGM output, CGMOUT. CGMOUT frequency is one-half the frequency of the selected clock. BCS cannot be set while the PLLON bit is clear. After toggling BCS, it may take up to three CGMXCLK and three CGMVCLK cycles to complete the transition from one source clock to the other. During the transition, CGMOUT is held in stasis. (See 9.4.3 Base Clock Selector Circuit.) Reset and the STOP instruction clear the BCS bit.

1 = CGMVCLK divided by two drives CGMOUT.

0 = CGMXCLK divided by two drives CGMOUT.

**NOTE:** PLLON and BCS have built-in protection that prevents the base clock selector circuit from selecting the VCO clock as the source of the base clock if the PLL is off. Therefore, PLLON cannot be cleared when BCS is set, and BCS cannot be set when PLLON is clear. If the PLL is off (PLLON = 0), selecting CGMVCLK requires two writes to the PLL control register. (See 9.4.3 Base Clock Selector Circuit.)

PCTL[3:0] — Reserved bits

These bits provide no function and always read as logic 1s.

### 9.6.2 PLL Bandwidth Control Register

The PLL bandwidth control register (PBWC):

- Selects automatic or manual (software-controlled) bandwidth control mode
- Indicates when the PLL is locked
- In automatic bandwidth control mode, indicates when the PLL is in acquisition or tracking mode

In manual operation, forces the PLL into acquisition or tracking mode.

Address: \$001D





### AUTO — Automatic Bandwidth Control Bit

This read/write bit selects automatic or manual bandwidth control. When initializing the PLL for manual operation (AUTO = 0), clear the  $\overline{\text{ACQ}}$  bit before turning on the PLL. Reset clears the AUTO bit.

1 = Automatic bandwidth control

0 = Manual bandwidth control

LOCK — Lock Indicator Bit

When the AUTO bit is set, LOCK is a read-only bit that becomes set when the VCO clock, CGMVCLK, is locked (running at the programmed frequency). When the AUTO bit is clear, LOCK reads as logic 0 and has no meaning. Reset clears the LOCK bit.

- 1 = VCO frequency correct or locked
- 0 = VCO frequency incorrect or unlocked

### ACQ — Acquisition Mode Bit

When the AUTO bit is set,  $\overline{ACQ}$  is a read-only bit that indicates whether the PLL is in acquisition mode or tracking mode. When the AUTO bit is clear,  $\overline{ACQ}$  is a read/write bit that controls whether the PLL is in acquisition or tracking mode.

In automatic bandwidth control mode (AUTO = 1), the last-written value from manual operation is stored in a temporary location and is recovered when manual operation resumes. Reset clears this bit, enabling acquisition mode.

- 1 = Tracking mode
- 0 = Acquisition mode

XLD — Crystal Loss Detect Bit

When the VCO output (CGMVCLK) is driving CGMOUT, this read/write bit can indicate whether the crystal reference frequency is active or not. To check the status of the crystal reference, follow these steps:

- 1. Write a logic 1 to XLD.
- 2. Wait N  $\times$  4 cycles. (N is the VCO frequency multiplier.)
- 3. Read XLD.

The crystal loss detect function works only when the BCS bit is set, selecting CGMVCLK to drive CGMOUT. When BCS is clear, XLD always reads as logic 0.

- 1 = Crystal reference not active
- 0 = Crystal reference active

PBWC3–PBWC0 — Reserved for Test

These bits enable test functions not available in user mode. To ensure software portability from development systems to user applications, software should write 0s to PBWC3–PBWC0 whenever writing to PBWC.

### 9.6.3 PLL Programming Register

The PLL programming register (PPG) contains the programming information for the modulo feedback divider and the programming information for the hardware configuration of the VCO.



Figure 9-7. PLL Programming Register (PPG)

MUL7-MUL4 — Multiplier Select Bits

These read/write bits control the modulo feedback divider that selects the VCO frequency multiplier, N. (See **9.4.2 Phase-Locked Loop Circuit (PLL)**.) A value of \$0 in the multiplier select bits configures the modulo feedback divider the same as a value of \$1. Reset initializes these bits to \$6 to give a default multiply value of 6.

 Table 9-1. VCO Frequency Multiplier (N) Selection

| MUL7–MUL4 | VCO Frequency Multiplier (N) |
|-----------|------------------------------|
| 0000      | 1                            |
| 0001      | 1                            |
| 0010      | 2                            |
| 0011      | 3                            |
| Ļ         |                              |
| 1101      | 13                           |
| 1110      | 14                           |
| 1111      | 15                           |

MOTOROLA

**NOTE:** The multiplier select bits have built-in protection that prevents them from being written when the PLL is on (PLLON = 1).

VRS7–VRS4 — VCO Range Select Bits

These read/write bits control the hardware center-of-range linear multiplier L, which controls the hardware center-of-range frequency,  $f_{VRS}$ , (see 9.4.2 Phase-Locked Loop Circuit (PLL).) VRS7–VRS4 cannot be written when the PLLON bit in the PLL control register (PCTL) is set. (See 9.4.2.5 Special Programming Exceptions.) A value of \$0 in the VCO range selects bits disables the PLL and clears the BCS bit in the PCTL. (See 9.4.3 Base Clock Selector Circuit and 9.4.2.5 Special Programming Exceptions for more information.) Reset initializes the bits to \$6 to give a default range multiply value of 6.

**NOTE:** The VCO range select bits have built-in protection that prevents them from being written when the PLL is on (PLLON = 1) and prevents selection of the VCO clock as the source of the base clock (BCS = 1) if the VCO range select bits are all clear.

The VCO range select bits must be programmed correctly. Incorrect programming can result in failure of the PLL to achieve lock.

### 9.7 Interrupts

When the AUTO bit is set in the PLL bandwidth control register (PBWC), the PLL can generate a CPU interrupt request every time the LOCK bit changes state. The PLLIE bit in the PLL control register (PCTL) enables CPU interrupts from the PLL. PLLF, the interrupt flag in the PCTL, becomes set whether interrupts are enabled or not. When the AUTO bit is clear, CPU interrupts from the PLL are disabled and PLLF reads as logic 0.

Software should read the LOCK bit after a PLL interrupt request to see if the request was due to an entry into lock or an exit from lock. When the PLL enters lock, the VCO clock, CGMVCLK, divided by two can be selected as the CGMOUT source by setting BCS in the PCTL. When the PLL exits lock, the VCO clock frequency is corrupt, and appropriate

MC68HC08QA24

precautions should be taken. If the application is not frequency sensitive, interrupts should be disabled to prevent PLL interrupt service routines from impeding software performance or from exceeding stack limitations.

**NOTE:** Software can select the CGMVCLK divided by two as the CGMOUT source even if the PLL is not locked (LOCK = 0). Therefore, software should make sure the PLL is locked before setting the BCS bit.

### 9.8 Special Modes

The WAIT and STOP instructions put the MCU in low powerconsumption standby modes.

### 9.8.1 Wait Mode

The WAIT instruction does not affect the CGM. Before entering wait mode, software can disengage and turn off the PLL by clearing the BCS and PLLON bits in the PLL control register (PCTL). Less power-sensitive applications can disengage the PLL without turning it off. Applications that require the PLL to wake the MCU from wait mode also can deselect the PLL output without turning off the PLL.

### 9.8.2 Stop Mode

When the STOP instruction executes, the SIM drives the SIMOSCEN signal low, disabling the CGM and holding low all CGM outputs (CGMXCLK, CGMOUT, and CGMINT).

If the STOP instruction is executed with the VCO clock (CGMVCLK) divided by two driving CGMOUT, the PLL automatically clears the BCS bit in the PLL control register (PCTL), thereby selecting the crystal clock (CGMXCLK) divided by two as the source of CGMOUT. When the MCU recovers from STOP, the crystal clock divided by two drives CGMOUT and BCS remains clear.

MC68HC08QA24

### 9.9 CGM During Break Interrupts

The system integration module (SIM) controls whether status bits in other modules can be cleared during the break state. The BCFE bit in the SIM break flag control register (SBFCR) enables software to clear status bits during the break state. (See **10.8.3 SIM Break Flag Control Register**.)

To allow software to clear status bits during a break interrupt, write a logic 1 to the BCFE bit. If a status bit is cleared during the break state, it remains cleared when the MCU exits the break state.

To protect the PLLF bit during the break state, write a logic 0 to the BCFE bit. With BCFE at logic 0 (its default state), software can read and write the PLL control register during the break state without affecting the PLLF bit.

### 9.10 Acquisition/Lock Time Specifications

The acquisition and lock times of the PLL are, in many applications, the most critical PLL design parameters. Proper design and use of the PLL ensures the highest stability and lowest acquisition/lock times.

### 9.10.1 Acquisition/Lock Time Definitions

Typical control systems refer to the acquisition time or lock time as the reaction time, within specified tolerances, of the system to a step input. In a PLL, the step input occurs when the PLL is turned on or when it suffers a noise hit. The tolerance is usually specified as a percent of the step input or when the output settles to the desired value plus or minus a percent of the frequency change. Therefore, the reaction time is constant in this definition, regardless of the size of the step input. For example, consider a system with a 5 percent acquisition time tolerance. If a command instructs the system to change from 0 Hz to 1 MHz, the acquisition time is the time taken for the frequency to reach 1 MHz  $\pm$ 50 kHz. Fifty kHz = 5 percent of the 1-MHz step input. If the system is operating at 1 MHz and suffers a -100 kHz noise hit, the

acquisition time is the time taken to return from 900 kHz to 1 MHz  $\pm 5$  kHz. Five kHz = 5 percent of the 100-kHz step input.

Other systems refer to acquisition and lock times as the time the system takes to reduce the error between the actual output and the desired output to within specified tolerances. Therefore, the acquisition or lock time varies according to the original error in the output. Minor errors may not even be registered. Typical PLL applications prefer to use this definition because the system requires the output frequency to be within a certain tolerance of the desired frequency regardless of the size of the initial error.

The discrepancy in these definitions makes it difficult to specify an acquisition or lock time for a typical PLL. Therefore, the definitions for acquisition and lock times for this module are:

- Acquisition time, t<sub>ACQ</sub>, is the time the PLL takes to reduce the error between the actual output frequency and the desired output frequency to less than the tracking mode entry tolerance, Δ<sub>TRK</sub>. Acquisition time is based on an initial frequency error, [(f<sub>DES</sub> f<sub>ORIG</sub>)/f<sub>DES</sub>], of not more than ±100 percent. In automatic bandwidth control mode (see 9.4.2.3 Manual and Automatic PLL Bandwidth Modes), acquisition time expires when the ACQ bit becomes set in the PLL bandwidth control register (PBWC).
- Lock time, t<sub>Lock</sub>, is the time the PLL takes to reduce the error between the actual output frequency and the desired output frequency to less than the lock mode entry tolerance, Δ<sub>Lock</sub>. Lock time is based on an initial frequency error, [(f<sub>DES</sub> f<sub>ORIG</sub>)/f<sub>DES</sub>], of not more than ±100 percent. In automatic bandwidth control mode, lock time expires when the LOCK bit becomes set in the PLL bandwidth control register (PBWC). (See 9.4.2.3 Manual and Automatic PLL Bandwidth Modes.)

Obviously, the acquisition and lock times can vary according to how large the frequency error is and may be shorter or longer in many cases.

#### 9.10.2 Parametric Influences on Reaction Time

Acquisition and lock times are designed to be as short as possible while still providing the highest possible stability. These reaction times are not constant, however. Many factors directly and indirectly affect the acquisition time.

The most critical parameter which affects the PLL reaction times is the reference frequency,  $f_{XCLK}$ . This frequency is the input to the phase detector and controls how often the PLL makes corrections. For stability, the corrections must be small compared to the desired frequency, so several corrections are required to reduce the frequency error. Therefore, the slower the reference the longer it takes to make these corrections. This parameter is also under user control via the choice of an external crystal frequency.

Another critical parameter is the external filter capacitor. The PLL modifies the voltage on the VCO by adding or subtracting charge from this capacitor. Therefore, the rate at which the voltage changes for a given frequency error (thus change in charge) is proportional to the capacitor size. The size of the capacitor also is related to the stability of the PLL. If the capacitor is too small, the PLL cannot make small enough adjustments to the voltage and the system cannot lock. If the capacitor is too large, the PLL may not be able to adjust the voltage in a reasonable time. (See 9.10.3 Choosing a Filter Capacitor.)

Also important is the operating voltage potential applied to the PLL analog portion potential ( $V_{DDA}/V_{DDAREF}$ ). Typically,  $V_{DDA}/V_{DDAREF}$  is at the same potential as  $V_{DD}$ . The power supply potential alters the characteristics of the PLL. A fixed value is best. Variable supplies, such as batteries, are acceptable if they vary within a known range at very slow speeds. Noise on the power supply is not acceptable, because it causes small frequency errors which continually change the acquisition time of the PLL.

Temperature and processing also can affect acquisition time because the electrical characteristics of the PLL change. The part operates as specified as long as these influences stay within the specified limits. External factors, however, can cause drastic changes in the operation of the PLL. These factors include noise injected into the PLL through the

filter capacitor, filter capacitor leakage, stray impedances on the circuit board, and even humidity or circuit board contamination.

### 9.10.3 Choosing a Filter Capacitor

As described in **9.10.2 Parametric Influences on Reaction Time**, the external filter capacitor,  $C_F$ , is critical to the stability and reaction time of the PLL. The PLL is also dependent on reference frequency,  $f_{RDV}$ , and supply voltage,  $V_{DD}$ . The value of the capacitor, therefore, must be chosen with supply potential and reference frequency in mind. For proper operation, the external filter capacitor must be chosen according to the following equation. Refer to **9.4.2 Phase-Locked Loop Circuit (PLL)** for the value of  $f_{XCLK}$  and **23.10 CGM Component Information** for the value of  $C_{Fact}$ .

$$C_{F} = C_{Fact} \left( \frac{V_{DDA}}{f_{XCLK}} \right)$$

For the value of  $V_{DDA}$ , choose the voltage potential at which the MCU is operating. If the power supply is variable, choose a value near the middle of the range of possible supply values.

This equation does not always yield a commonly available capacitor size, so round to the nearest available size. If the value is between two different sizes, choose the higher value for better stability. Choosing the lower size may seem attractive for acquisition time improvement, but the PLL can become unstable. Also, always choose a capacitor with a tight tolerance ( $\pm 20$  percent or better) and low dissipation.

**Technical Data** 

128

# Section 10. System Integration Module (SIM)

### **10.1 Contents**

| 10.2 In              | troduction                                                 |
|----------------------|------------------------------------------------------------|
| 10.3 SI<br>10.3.1    | M Bus Clock Control and Generation                         |
| 10.3.2<br>10.3.3     | Clock Startup from POR or LVI Reset                        |
| 10.4 Re<br>10.4.1    | eset and System Initialization                             |
| 10.4.2<br>10.4.2.1   | Active Resets from Internal Sources                        |
| 10.4.2.2<br>10.4.2.3 | Computer Operating Properly (COP) Reset                    |
| 10.4.2.4<br>10.4.2.5 | Illegal Address Reset                                      |
| 10.5 SI<br>10.5.1    | M Counter                                                  |
| 10.5.2<br>10.5.3     | SIM Counter During Stop Mode Recovery                      |
| 10.6 Pr              | ogram Exception Control                                    |
| 10.6.1<br>10.6.1.1   | Interrupts                                                 |
| 10.6.1.2<br>10.6.2   | SWI Instruction                                            |
| 10.6.3<br>10.6.4     | Break Interrupts143Status Flag Protection in Break Mode144 |
| 10.7 Lo              | w-Power Modes                                              |
| 10.7.1               | Stop Mode                                                  |

| 10.8   | SIM Registers                   | .147 |
|--------|---------------------------------|------|
| 10.8.1 | SIM Break Status Register       | .147 |
| 10.8.2 | SIM Reset Status Register       | .148 |
| 10.8.3 | SIM Break Flag Control Register | .150 |

### **10.2 Introduction**

This section describes the system integration module (SIM), which supports up to 24 external and/or internal interrupts. The SIM is a system state controller that coordinates CPU and exception timing. Together with the central processor unit (CPU), the SIM controls all MCU activities. A block diagram of the SIM is shown in **Figure 10-1**. **Figure 10-2** is a summary of the SIM input/output (I/O) registers.

The SIM is responsible for:

- Bus clock generation and control for CPU and peripherals:
  - Stop/wait/reset/break entry and recovery
  - Internal clock control
- Master reset control, including power-on reset (POR) and computer operating properly (COP) timeout
- Interrupt control:
  - Acknowledge timing
  - Arbitration control timing
  - Vector address generation
- CPU enable/disable timing
- Modular architecture expandable to 128 interrupt sources



Figure 10-1. SIM Block Diagram

MC68HC08QA24

MOTOROLA

# System Integration Module (SIM)

| Addr.                       | Register Name                                      | Bit 7 | 6   | 5   | 4    | 3    | 2   | 1    | Bit 0 |
|-----------------------------|----------------------------------------------------|-------|-----|-----|------|------|-----|------|-------|
| \$FE00                      | Read<br>SIM Break Status Register<br>(SBSR)        | R     | R   | R   | R    | R    | R   | SBSW | R     |
|                             | Rese                                               | :     |     |     |      |      |     | 0    |       |
|                             | Read                                               | : POR | PIN | COP | ILOP | ILAD | EDC | LVI  | 0     |
| \$FE01                      | SIM Reset Status Register<br>(SRSR)                | R     | R   | R   | R    | R    | R   | R    | R     |
|                             | Rese                                               | : 1   | U   | 0   | 0    | 0    | U   | U    | 0     |
| \$FE03                      | Read<br>SIM Break Flag Control<br>Register (SBFCR) | BCFE  | R   | R   | R    | R    | R   | R    | R     |
|                             | Rese                                               | : 0   |     |     |      |      |     |      |       |
| R = Reserved U = Unaffected |                                                    |       |     |     |      |      |     |      |       |

Figure 10-2. SIM I/O Register Summary

 Table 10-1 shows the internal signal names used in this section.

| Signal Name | Description                                                                                 |  |  |  |
|-------------|---------------------------------------------------------------------------------------------|--|--|--|
| CGMXCLK     | Buffered version of OSC1 from clock generator module (CGM)                                  |  |  |  |
| CGMVCLK     | PLL output                                                                                  |  |  |  |
| CGMOUT      | PLL-based or OSC1-based clock output from CGM module<br>(Bus clock = CGMOUT divided by two) |  |  |  |
| IAB         | Internal address bus                                                                        |  |  |  |
| IDB         | Internal data bus                                                                           |  |  |  |
| PORRST      | Signal from the power-on reset module to the SIM                                            |  |  |  |
| IRST        | Internal reset signal                                                                       |  |  |  |
| R/W         | Read/write signal                                                                           |  |  |  |

**Technical Data** 

MC68HC08QA24

### **10.3 SIM Bus Clock Control and Generation**

The bus clock generator provides system clock signals for the CPU and peripherals on the MCU. The system clocks are generated from an incoming clock, CGMOUT, as shown in **Figure 10-3**. This clock can come from either an external oscillator or from the on-chip PLL. (See **Section 9. Clock Generator Module (CGM)**.)

### 10.3.1 Bus Timing

In user mode, the internal bus frequency is either the crystal oscillator output (CGMXCLK) divided by four or the PLL output (CGMVCLK) divided by four. (See Section 9. Clock Generator Module (CGM).)

### 10.3.2 Clock Startup from POR or LVI Reset

When the power-on reset (POR) module or the low-voltage inhibit (LVI) module generates a reset, the clocks to the CPU and peripherals are inactive and held in an inactive phase until after 4096 CGMXCLK cycles. The  $\overline{\text{RST}}$  pin is driven low by the SIM during this entire period. The bus clocks start upon completion of the timeout.



Figure 10-3. CGM Clock Signals

### 10.3.3 Clocks in Stop Mode and Wait Mode

Upon exit from stop mode by an interrupt, break, or reset, the SIM allows CGMXCLK to clock the SIM counter. The CPU and peripheral clocks do not become active until after the stop delay timeout. This timeout is selectable as 4096 or 32 CGMXCLK cycles. (See **10.7.2 Stop Mode**.)

In wait mode, the CPU clocks are inactive. However, some modules can be programmed to be active in wait mode. Refer to the wait mode subsection of each module to see if the module is active or inactive in wait mode.

### 10.4 Reset and System Initialization

The MCU has these reset sources:

- Power-on reset module (POR)
- External reset pin (RST)
- Computer operating properly module (COP)
- Low-voltage inhibit module (LVI)
- Illegal opcode
- Illegal address
- Error detect CPU (EDC)

Each of these resets produces the vector \$FFFE-FFF (\$FEFE-FEFF in monitor mode) and asserts the internal reset signal (IRST). IRST causes all registers to be returned to their default values and all modules to be returned to their reset states.

An internal reset clears the SIM counter (see **10.5 SIM Counter**), but an external reset does not. Each of the resets sets a corresponding bit in the SIM reset status register (SRSR). (See **10.8 SIM Registers**.)

### **10.4.1 External Pin Reset**

Pulling the asynchronous RST pin low halts all processing. The PIN bit of the SIM reset status register (SRSR) is set as long as RST is held low for a minimum of 67 CGMXCLK cycles, assuming that neither the POR nor the LVI was the source of the reset. See Table 10-2 for details. Figure 10-4 shows the relative timing.

| Reset Type | Number of Cycles Required to Set PIN |  |  |  |  |
|------------|--------------------------------------|--|--|--|--|
| POR/LVI    | 4163 (4096 + 64 + 3)                 |  |  |  |  |
| All Others | 67 (64 + 3)                          |  |  |  |  |



Figure 10-4. External Reset Timing

### **10.4.2 Active Resets from Internal Sources**

All internal reset sources actively pull the RST pin low for 32 CGMXCLK cycles to allow resetting of external peripherals. The internal reset signal IRST continues to be asserted for an additional 32 cycles. See Figure 10-5. An internal reset can be caused by an illegal address, illegal opcode, COP timeout, LVI, or POR. (See Figure 10-6.) Note that for LVI or POR resets, the SIM cycles through 4096 CGMXCLK cycles during which the SIM forces the RST pin low. The internal reset signal then follows the sequence from the falling edge of RST shown in Figure 10-5.

The COP reset is asynchronous to the bus clock.

The active reset feature allows the part to issue a reset to peripherals and other chips within a system built around the MCU.



Figure 10-6. Sources of Internal Reset

### 10.4.2.1 Power-On Reset

When power is first applied to the MCU, the power-on reset module (POR) generates a pulse to indicate that power-on has occurred. The external reset pin ( $\overline{\text{RST}}$ ) is held low while the SIM counter counts out 4096 CGMXCLK cycles. Another 64 CGMXCLK cycles later, the CPU and memories are released from reset to allow the reset vector sequence to occur.

At power-on, these events occur:

- A POR pulse is generated.
- The internal reset signal is asserted.
- The SIM enables CGMOUT.
- Internal clocks to the CPU and modules are held inactive for 4096 CGMXCLK cycles to allow stabilization of the oscillator.
- The RST pin is driven low during the oscillator stabilization time.
- The POR bit of the SIM reset status register (SRSR) is set and all other bits in the register are cleared.



Figure 10-7. POR Recovery

### 10.4.2.2 Computer Operating Properly (COP) Reset

The overflow of the COP counter causes an internal reset and sets the COP bit in the SIM reset status register (SRSR) if the COPD bit in the CONFIG register (\$001F) is at logic 0. (See Section 14. Computer Operating Properly (COP).)

### 10.4.2.3 Illegal Opcode Reset

The SIM decodes signals from the CPU to detect illegal instructions. An illegal instruction sets the ILOP bit in the SIM reset status register (SRSR) and causes a reset.

**NOTE:** A \$9E opcode (pre-byte for SP instructions) followed by an \$8E opcode (stop instruction) generates a stop mode recovery reset.

If the stop enable bit, STOP, in the CONFIG register (\$001F) is logic 0, the SIM treats the STOP instruction as an illegal opcode and causes an illegal opcode reset.

#### 10.4.2.4 Illegal Address Reset

An opcode fetch from an unmapped address generates an illegal address reset. The SIM verifies that the CPU is fetching an opcode prior to asserting the ILAD bit in the SIM reset status register (SRSR) and resetting the MCU. A data fetch from an unmapped address does not generate a reset.

### 10.4.2.5 Low-Voltage Inhibit (LVI) Reset

The low-voltage inhibit (LVI) module asserts its output to the SIM when the V<sub>DD</sub> voltage falls to the V<sub>LVII</sub> voltage. The LVI bit in the SIM reset status register (SRSR) is set and a chip reset is asserted if the LVIPWRD and LVIRSTD bits in the CONFIG register are at logic 0. The RST pin will be held low until the SIM counts 4096 CGMXCLK cycles after V<sub>DD</sub> rises above V<sub>LVIR</sub>. Another 64 CGMXCLK cycles later, the CPU is released from reset to allow the reset vector sequence to occur. (See Section 11. Low-Voltage Inhibit (LVI).)

**Technical Data** 

MC68HC08QA24

### 10.5 SIM Counter

The SIM counter is used by the power-on reset module (POR) and in stop mode recovery to allow the oscillator time to stabilize before enabling the internal bus (IBUS) clocks. The SIM counter also serves as a prescaler for the computer operating properly (COP) module. The SIM counter overflow supplies the clock for the COP module. The SIM counter is 12 bits long and is clocked by the falling edge of CGMXCLK.

### 10.5.1 SIM Counter During Power-On Reset

The power-on reset module (POR) detects power applied to the MCU. At power-on, the POR circuit asserts the signal PORRST. Once the SIM is initialized, it enables the clock generation module (CGM) to drive the bus clock state machine.

### 10.5.2 SIM Counter During Stop Mode Recovery

The SIM counter also is used for stop mode recovery. The STOP instruction clears the SIM counter. After an interrupt, break, or reset, the SIM senses the state of the short stop recovery bit, SSREC, in the CONFIG register (\$001F). If the SSREC bit is a logic 1, then the stop recovery is reduced from the normal delay of 4096 CGMXCLK cycles down to 32 CGMXCLK cycles. This is ideal for applications using canned oscillators that do not require long startup times from stop mode. External crystal applications should use the full stop recovery time, that is, with SSREC cleared.

### **10.5.3 SIM Counter and Reset States**

External reset has no effect on the SIM counter. (See **10.7.2 Stop Mode** for details.) The SIM counter is free-running after all reset states. (See **10.4.2 Active Resets from Internal Sources** for counter control and internal reset recovery sequences.)

MC68HC08QA24

## **10.6 Program Exception Control**

Normal, sequential program execution can be changed in three different ways:

- 1. Interrupts:
  - Maskable hardware CPU interrupts
  - Non-maskable software interrupt instruction (SWI)
- 2. Reset
- 3. Break interrupts

#### 10.6.1 Interrupts

At the beginning of an interrupt, the CPU saves the CPU register contents on the stack and sets the interrupt mask (I bit) to prevent additional interrupts. At the end of an interrupt, the return-from-interrupt (RTI) instruction recovers the CPU register contents from the stack so that normal processing can resume. Figure 10-8 shows interrupt entry timing.

Figure 10-10 shows interrupt recovery timing.

Interrupts are latched, and arbitration is performed in the SIM at the start of interrupt processing. The arbitration result is a constant that the CPU uses to determine which vector to fetch. Once an interrupt is latched by the SIM, no other interrupt can take precedence, regardless of priority, until the latched interrupt is serviced or the I bit is cleared. (See Figure 10-9.)

| Module<br>Interrup1                   |                                                                                                                              |  |  |  |  |  |
|---------------------------------------|------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| I BIT                                 |                                                                                                                              |  |  |  |  |  |
| IAB                                   | UMMY     SP     SP-1     SP-2     SP-3     SP-4     VECTH     VECTL     START ADDR                                           |  |  |  |  |  |
| IDB                                   | X     DUMMY     Y     PC-1[7:0]     Y     PC-1[15:8]     X     X     A     Y     CCR     Y     V     DATA L     X     OPCODE |  |  |  |  |  |
| R/W                                   |                                                                                                                              |  |  |  |  |  |
| Figure 10-8. Hardware Interrupt Entry |                                                                                                                              |  |  |  |  |  |
|                                       |                                                                                                                              |  |  |  |  |  |



Figure 10-9. Interrupt Processing

MC68HC08QA24

| MODULE |                                                                                                                                                 |      |
|--------|-------------------------------------------------------------------------------------------------------------------------------------------------|------|
| I BIT  |                                                                                                                                                 |      |
| IAB    | X         X         SP - 4         X         SP - 2         X         SP - 1         X         SP         PC         Y         PC + 1         Y | _XX_ |
| IDB    | CCR X A X X PC-1[15:8] PC-1[7:0] OPCODE OPERAND                                                                                                 | X    |
| R/W    | у                                                                                                                                               |      |

### Figure 10-10. Hardware Interrupt Recovery

#### 10.6.1.1 Hardware Interrupts

A hardware interrupt does not stop the current instruction. Processing of a hardware interrupt begins after completion of the current instruction. When the current instruction is complete, the SIM checks all pending hardware interrupts. If interrupts are not masked (I bit clear in the condition code register) and if the corresponding interrupt enable bit is set, the SIM proceeds with interrupt processing; otherwise, the next instruction is fetched and executed.

If more than one interrupt is pending at the end of an instruction execution, the highest priority interrupt is serviced first. **Figure 10-11** demonstrates what happens when two interrupts are pending. If an interrupt is pending upon exit from the original interrupt service routine, the pending interrupt is serviced before the LDA instruction is executed.

The LDA opcode is prefetched by both the INT1 and INT2 RTI instructions. However, in the case of the INT1 RTI prefetch, this is a redundant operation.

**NOTE:** To maintain compatibility with the M68HC05, M6805, and M146805 Families, the H register is not pushed on the stack during interrupt entry. If the interrupt service routine modifies the H register or uses the indexed addressing mode, software should save the H register and then restore it prior to exiting the routine.



Figure 10-11. Interrupt Recognition Example

### 10.6.1.2 SWI Instruction

The SWI instruction is a non-maskable instruction that causes an interrupt regardless of the state of the interrupt mask (I bit) in the condition code register.

**NOTE:** A software interrupt pushes PC onto the stack. A software interrupt does **not** push PC – 1, as a hardware interrupt does.

### 10.6.2 Reset

All reset sources always have higher priority than interrupts and cannot be arbitrated.

### 10.6.3 Break Interrupts

The break module can stop normal program flow at a software-programmable break point by asserting its break interrupt output. (See **Section 12. Break Module (Break)**.) The SIM puts the CPU into the break state by forcing it to the SWI vector location. Refer to the break interrupt subsection of each module to see how the break state affects each module.

MC68HC08QA24

### 10.6.4 Status Flag Protection in Break Mode

The SIM controls whether status flags contained in other modules can be cleared during break mode. The user can select to protect flags from being cleared by properly initializing the break clear flag enable bit (BCFE) in the SIM break flag control register (SBFCR). (See **10.8.3 SIM Break Flag Control Register**.)

Protecting flags in break mode ensures that set flags will not be cleared while in break mode. This protection allows registers to be freely read and written during break mode without losing status flag information.

Setting the BCFE bit enables the clearing mechanisms. Once cleared in break mode, a flag remains cleared even when break mode is exited. Status flags with a 2-step clearing mechanism — for example, a read of one register followed by the read or write of another — are protected, even when the first step is accomplished prior to entering break mode. Upon leaving break mode, execution of the second step will clear the flag as usual.

### 10.7 Low-Power Modes

Executing the WAIT or STOP instruction puts the MCU in a low powerconsumption mode for standby situations. The SIM holds the CPU in a non-clocked state. The operation of each of these modes is described in this section. Both STOP and WAIT clear the interrupt mask (I) in the condition code register, allowing interrupts to occur.

### 10.7.1 Wait Mode

In wait mode, the CPU clocks are inactive while one set of peripheral clocks continues to run. **Figure 10-12** shows the timing for wait mode entry.

A module that is active during wait mode can wake up the CPU with an interrupt if the interrupt is enabled. Stacking for the interrupt begins one cycle after the WAIT instruction during which the interrupt occurred. Refer to the wait mode subsection of each module to see if the module is active or inactive in wait mode. Some modules can be programmed to be active in wait mode.

Technical Data

MC68HC08QA24
Wait mode also can be exited by a reset or break. A break interrupt during wait mode sets the SIM break stop/wait bit, SBSW, in the SIM break status register (SBSR). If the COP disable bit, COPD, in the configuration register (\$001F) is logic 0, then the computer operating properly module (COP) is enabled and remains active in wait mode.

| IAB | WAIT ADDR | WAIT ADDR + 1    | SAME   | X    | SAME |
|-----|-----------|------------------|--------|------|------|
| IDB | PREVIOU   | JS DATA X NEXT ( | DPCODE | SAME | SAME |
| R/W |           | у                |        |      |      |

Note: Previous data can be operand data or the WAIT opcode, depending on the last instruction.

Figure 10-12. Wait Mode Entry Timing

### Figure 10-13 and Figure 10-14 show the timing for WAIT recovery.



Note: EXITSTOPWAIT =  $\overline{RST}$  pin or CPU interrupt or break interrupt

## Figure 10-13. Wait Recovery from Interrupt or Break



Figure 10-14. Wait Recovery from Internal Reset

MC68HC08QA24

#### 10.7.2 Stop Mode

In stop mode, the SIM counter is reset and the system clocks are disabled. An interrupt request from a module can cause an exit from stop mode. Stacking for interrupts begins after the selected stop recovery time has elapsed. Reset or break also causes an exit from stop mode.

The SIM disables the clock generator module outputs (CGMOUT and CGMXCLK) in stop mode, stopping the CPU and peripherals. Stop recovery time is selectable using the short stop recovery (SSREC) bit in the CONFIG register (\$001F). If SSREC is set, stop recovery is reduced from the normal delay of 4096 CGMXCLK cycles down to 32. This is ideal for applications using canned oscillators that do not require long startup times from stop mode.

**NOTE:** External crystal applications should use the full stop recovery time by clearing the SSREC bit.

A break interrupt during stop mode sets the SIM break stop/wait bit (SBSW) in the SIM break status register (SBSR).

The SIM counter is held in reset from the execution of the STOP instruction until the beginning of stop recovery. It is then used to time the recovery period. **Figure 10-15** shows stop mode entry timing.



Note: Previous data can be operand data or the STOP opcode, depending on the last instruction.

Figure 10-15. Stop Mode Entry Timing



Figure 10-16. Stop Mode Recovery from Interrupt or Break

## 10.8 SIM Registers

The SIM has three memory mapped registers.

### 10.8.1 SIM Break Status Register

The SIM break status register contains a flag to indicate that a break caused an exit from stop mode or wait mode.





SBSW — SIM Break Stop/Wait Bit

This status bit is useful in applications requiring a return to wait mode or stop mode after exiting from a break interrupt. Clear SBSW by writing a logic 0 to it. Reset clears SBSW.

1 = Stop mode or wait mode exited by break interrupt

0 = Stop mode or wait mode not exited by break interrupt

MOTOROLA

SBSW can be read within the break state SWI routine. The user can modify the return address on the stack by subtracting one from it. The following code is an example of this. Writing 0 to the SBSW bit clears it.

This code works if the H register has been pushed onto the stack in the break service routine software. This code should be executed at the end of the break service routine software.

| HIBYTE | EQU         | 5                 |                                                      |
|--------|-------------|-------------------|------------------------------------------------------|
| LOBYTE | EQU         | 6                 |                                                      |
|        | If not      | SBSW, do RTI      |                                                      |
|        | BRCLR       | SBSW,SBSR, RETURN | ;See if wait mode or stop mode was exited by ;break. |
|        | TST         | LOBYTE, SP        | ;If RETURNLO is not zero,                            |
|        | BNE         | DOLO              | ;then just decrement low byte.                       |
|        | DEC         | HIBYTE, SP        | ;Else deal with high byte, too.                      |
| DOLO   | DEC         | LOBYTE, SP        | ;Point to WAIT/STOP opcode.                          |
| RETURN | PULH<br>RTI |                   | Restore H register.                                  |

#### 10.8.2 SIM Reset Status Register

This register contains seven flags that show the source of the last reset. All flag bits are automatically cleared following a read of the register. The register is initialized on power-up as shown with the POR bit set and all other bits cleared. However, since the POR circuit releases the part at a lower voltage than the LVI trip point, the LVI bit may also be set when first reading the register after a power-up. Also, during a POR or any other internal reset, the RST pin is pulled low. After the pin is released, it will be sampled 32 XCLK cycles later. If the pin is not above a V<sub>IH</sub> at that time then the PIN bit in the SRSR may be set in addition to whatever other bits are set.

Address: \$FE01

|        | Bit 7 | 6         | 5   | 4          | 3    | 2   | 1   | Bit 0 |
|--------|-------|-----------|-----|------------|------|-----|-----|-------|
| Read:  | POR   | PIN       | COP | ILOP       | ILAD | EDC | LVI | 0     |
| Write: | R     | R         | R   | R          | R    | R   | R   | R     |
| POR:   | 1     | U         | 0   | 0          | 0    | U   | U   | 0     |
|        | R     | = Reserve | d   | U = Unaffe | cted |     |     |       |

Figure 10-18. SIM Reset Status Register (SRSR)

- POR Power-On Reset Bit
  - 1 = A POR has occurred.
  - 0 = Read of SRSR
- PIN External Reset Bit
  - 1 = An external reset has occurred since the last read of the SRSR.
  - 0 = Read of SRSR
- COP Computer Operating Properly Reset Bit
  - 1 = A COP reset has occurred since the last read of the SRSR.
  - 0 = POR or read of SRSR
- ILOP Illegal Opcode Reset Bit
  - 1 = An illegal opcode reset has occurred since the last read of the SRSR.
  - 0 = POR or read of SRSR
- ILAD Illegal Address Reset Bit (opcode fetches only)
  - 1 = An illegal address reset has occurred since the last read of the SRSR.
  - 0 = POR or read of SRSR
- EDC Error Detect CPU Reset Bit
  - 1 = An EDC reset has occurred since the last read of the SRSR.
  - 0 = POR or read of SRSR
- LVI Low-Voltage Inhibit Reset Bit
  - 1 = An LVI reset has occurred since the last read of the SRSR.
  - 0 = Read of SRSR

#### 10.8.3 SIM Break Flag Control Register

The SIM break control register contains a bit that enables software to clear status bits while the MCU is in a break state.





### BCFE — Break Clear Flag Enable Bit

In some module registers, this read/write bit will enable software to clear status bits by accessing status registers only while the MCU is in a break state. To clear status bits during the break state, the BCFE bit must be set. This operation is important for modules with status bits which can be cleared only by being read. See the register descriptions in each module for additional details.

- 1 = Status bits clearable during break
- 0 = Status bits not clearable during break

# Section 11. Low-Voltage Inhibit (LVI)

## **11.1 Contents**

| 11.2 Introduction                                                                                                        |
|--------------------------------------------------------------------------------------------------------------------------|
| 11.3 Features                                                                                                            |
| 11.4Functional Description15211.4.1Polled LVI Operation15311.4.2Forced Reset Operation15311.4.3False Reset Protection153 |
| 11.5 LVI Status Register153                                                                                              |
| 11.6 LVI Interrupts154                                                                                                   |
| 11.7 Wait Mode                                                                                                           |
| 11.8 Stop Mode                                                                                                           |

## **11.2 Introduction**

This section describes the low-voltage inhibit (LVI) module, which monitors the voltage on the  $V_{DD}$  pin and can force a reset when the  $V_{DD}$  voltage falls to the LVI trip voltage.

# **11.3 Features**

Features of the LVI module include:

- Programmable LVI reset
- Programmable power consumption
- Digital filtering of V<sub>DD</sub> pin level

## **11.4 Functional Description**

**Figure 11-1** shows the structure of the LVI module. The LVI is enabled out of reset. The LVI module contains a bandgap reference circuit and comparator. The LVI power bit, LVIPWR, enables the LVI to monitor  $V_{DD}$ voltage. The LVI reset bit, LVIRST, enables the LVI module to generate a reset when  $V_{DD}$  falls below a voltage, LVI<sub>TRIPF</sub>, and remains at or below that level for nine or more consecutive CPU cycles. LVISTOP enables the LVI module during stop mode. This will ensure that when the STOP instruction is implemented, the LVI will continue to monitor the voltage level on  $V_{DD}$ . LVIPWR, LVISTOP, and LVIRST are in the mask option register (MOR) (\$001F). See **5.4 Mask Option Register**. Once an LVI reset occurs, the MCU remains in reset until  $V_{DD}$  rises above a voltage, LVI<sub>TRIPR</sub>.  $V_{DD}$  must be above LVI<sub>TRIPR</sub> for only one CPU cycle to bring the MCU out of reset. (See **11.4.2 Forced Reset Operation**.) The output of the comparator controls the state of the LVIOUT flag in the LVI status register (LVISR).

An LVI reset also drives the RST pin low to provide low-voltage protection to external peripheral devices.



Figure 11-1. LVI Module Block Diagram

### 11.4.1 Polled LVI Operation

In applications that can operate at  $V_{DD}$  levels below the  $LVI_{TRIPF}$  level, software can monitor  $V_{DD}$  by polling the LVIOUT bit. In the configuration register, the LVIPWR bit must be at logic 0 to enable the LVI module, and the LVIRST bit must be at logic 1 to disable LVI resets.

### 11.4.2 Forced Reset Operation

In applications that require  $V_{DD}$  to remain above the  $LVI_{TRIPF}$  level, enabling LVI resets allows the LVI module to reset the MCU when  $V_{DD}$ falls to the  $LVI_{TRIPF}$  level and remains at or below that level for nine or more consecutive CPU cycles. In the configuration register, the LVIPWR and LVIRST bits must be at logic 0 to enable the LVI module and to enable LVI resets.

### 11.4.3 False Reset Protection

The V<sub>DD</sub> pin level is digitally filtered to reduce false resets due to power supply noise. For the LVI module to reset the MCU, V<sub>DD</sub> must remain at or below the LVI<sub>TRIPF</sub> level for nine or more consecutive CPU cycles. V<sub>DD</sub> must be above LVI<sub>TRIPR</sub> for only one CPU cycle to bring the MCU out of reset.

## 11.5 LVI Status Register

The LVI status register (LVISR) flags  $V_{DD}$  voltages below the LVI<sub>TRIPF</sub> level.

| Address | \$FE0F |                      |          |          |         |                     |    |       |
|---------|--------|----------------------|----------|----------|---------|---------------------|----|-------|
|         | Bit 7  | 6                    | 5        | 4        | 3       | 2                   | 1  | Bit 0 |
| Read:   | LVIOUT | 0                    | 0        | 0        | 0       | 0                   | 0  | 0     |
| Write:  | R      | R                    | R        | R        | R       | R                   | R  | R     |
| Reset:  | 0      | 0                    | 0        | 0        | 0       | 0                   | 0  | 0     |
|         | R      | = Reserve            | ed       |          |         |                     |    |       |
|         | F      | igure 1 <sup>°</sup> | 1-2. LVI | Status I | Registe | <sup>,</sup> (LVISR | 2) |       |

LVIOUT — LVI Output Bit

This read-only flag becomes set when the  $V_{DD}$  voltage falls below the  $LVI_{TRIPF}$  voltage for 32 to 40 CGMXCLK cycles. (See **Table 11-1**.) Reset clears the LVIOUT bit.

| V <sub>DD</sub><br>at Level:                                     | For Number of<br>CGMXCLK Cycles:  | LVIOUT         |
|------------------------------------------------------------------|-----------------------------------|----------------|
| $V_{DD} > LVI_{TRIPR}$                                           | Any                               | 0              |
| $V_{DD} < LVI_{TRIPF}$                                           | < 32 CGMXCLK cycles               | 0              |
| $V_{DD}$ < LVI <sub>TRIPF</sub>                                  | Between 32 & 40<br>CGMXCLK cycles | 0 or 1         |
| $V_{DD} < LVI_{TRIPF}$                                           | > 40 CGMXCLK cycles               | 1              |
| LVI <sub>TRIPF</sub> < V <sub>DD</sub> <<br>LVI <sub>TRIPR</sub> | Any                               | Previous value |

Table 11-1. LVIOUT Bit Indication

## 11.6 LVI Interrupts

The LVI module does not generate interrupt requests.

## 11.7 Wait Mode

The WAIT instruction puts the MCU in low power-consumption standby mode.

With the LVIPWR bit in the configuration register programmed to logic 0, the LVI module is active after a WAIT instruction.

With the LVIRST bit in the configuration register programmed to logic 0, the LVI module can generate a reset and bring the MCU out of wait mode.

**Technical Data** 

## 11.8 Stop Mode

The STOP instruction puts the MCU in low power-consumption mode.

With the LVISTOP and LVIPWR bits in the configuration register programmed to a logic 0, the LVI module will be active after a STOP instruction. Due to the fact that the CPU clocks are disabled during stop mode, the LVI trip must bypass the digital filter to generate a reset and bring the MCU out of stop.

With the LVIPWR bit in the configuration register programmed to logic 0 and the LVISTOP bit at a logic 1, the LVI module will be inactive after a STOP instruction.

MC68HC08QA24

# Section 12. Break Module (Break)

## 12.1 Contents

| 12.2 Introduction            |
|------------------------------|
| 12.3 Features                |
| 12.4Functional Description   |
| 12.5Break Module Registers   |
| 12.6         Low-Power Modes |

# **12.2 Introduction**

This section describes the break module (break). The break module can generate a break interrupt that stops normal program flow at a defined address to enter a background program.

## 12.3 Features

Features of the break module include:

- Accessible input/output (I/O) registers during the break interrupt
- CPU-generated break interrupts
- Software-generated break interrupts
- COP disabling during break interrupts

# **12.4 Functional Description**

When the internal address bus matches the value written in the break address registers, the break module issues a breakpoint signal ( $\overline{BKPT}$ ) to the SIM. The SIM then causes the CPU to load the instruction register with a software interrupt instruction (SWI) after completion of the current CPU instruction. The program counter vectors to \$FFFC and \$FFFD (\$FEFC and \$FEFD in monitor mode).

These events can cause a break interrupt to occur:

- A CPU-generated address (the address in the program counter) matches the contents of the break address registers.
- Software writes a logic 1 to the BRKA bit in the break status and control register.

When a CPU-generated address matches the contents of the break address registers, the break interrupt begins after the CPU completes its current instruction. A return-from-interrupt instruction (RTI) in the break routine ends the break interrupt and returns the MCU to normal operation. **Figure 12-1** shows the structure of the break module.



Figure 12-1. Break Module Block Diagram

| Addr.  | Register Name                                 |                 | Bit 7  | 6         | 5  | 4  | 3  | 2  | 1 | Bit 0 |
|--------|-----------------------------------------------|-----------------|--------|-----------|----|----|----|----|---|-------|
| \$FE0C | EOC Break Address Register High               |                 | Bit 15 | 14        | 13 | 12 | 11 | 10 | 9 | Bit 8 |
|        | · · ·                                         | Reset:          | 0      | 0         | 0  | 0  | 0  | 0  | 0 | 0     |
| \$FE0D | Break Address Register Low<br>(BRKL)          | Read:<br>Write: | Bit 7  | 6         | 5  | 4  | 3  | 2  | 1 | Bit 0 |
|        |                                               | Reset:          | 0      | 0         | 0  | 0  | 0  | 0  | 0 | 0     |
|        |                                               | Read:           | BRKE   | BRKA      | 0  | 0  | 0  | 0  | 0 | 0     |
| \$FE0E | Break Status and Control<br>Register (BRKSCR) | Write:          | DKKE   | DKNA      | R  | R  | R  | R  | R | R     |
|        | •                                             | Reset:          | 0      | 0         | 0  | 0  | 0  | 0  | 0 | 0     |
|        |                                               | [               | R      | = Reserve | ed | _  |    |    |   |       |

Figure 12-2. Break I/O Register Summary

### **12.4.1 Flag Protection During Break Interrupts**

The system integration module (SIM) controls whether module status bits can be cleared during the break state. The BCFE bit in the SIM break flag control register (SBFCR) enables software to clear status bits during the break state. (See **10.8.3 SIM Break Flag Control Register** and the **Break Interrupts** subsection for each module.)

#### 12.4.2 CPU During Break Interrupts

The CPU starts a break interrupt by:

- Loading the instruction register with the SWI instruction
- Loading the program counter with \$FFFC-\$FFFD (\$FEFC-\$FEFD in monitor mode)

The break interrupt begins after completion of the CPU instruction in progress. If the break address register match occurs on the last cycle of a CPU instruction, the break interrupt begins immediately.

#### 12.4.3 TIM During Break Interrupts

A break interrupt stops the timer counter.

#### 12.4.4 COP During Break Interrupts

The COP is disabled during a break interrupt when  $V_{DD} + V_{HI}$  is present on the  $\overline{RST}$  pin. For  $V_{HI}$ , see 23.5 DC Electrical Characteristics.

## 12.5 Break Module Registers

Three registers control and monitor operation of the break module:

- 1. Break status and control register (BRKSCR)
- 2. Break address register high (BRKH)
- 3. Break address register low (BRKL)

#### 12.5.1 Break Status and Control Register

The break status and control register contains break module enable and status bits.

| Address: | \$FE0E |           |   |   |   |   |   |       |
|----------|--------|-----------|---|---|---|---|---|-------|
|          | Bit 7  | 6         | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| Read:    | BRKE   | BRKA      | 0 | 0 | 0 | 0 | 0 | 0     |
| Write:   | DKKE   |           | R | R | R | R | R | R     |
| Reset:   | 0      | 0         | 0 | 0 | 0 | 0 | 0 | 0     |
|          | R      | = Reserve | d |   |   |   |   |       |



BRKE — Break Enable Bit

This read/write bit enables breaks on break address register matches. Clear BRKE by writing a logic 0 to bit 7. Reset clears the BRKE bit.

- 1 = Breaks enabled on 16-bit address match
- 0 = Breaks disabled on 16-bit address match
- BRKA Break Active Bit

This read/write status and control bit is set when a break address match occurs. Writing a logic 1 to BRKA generates a break interrupt. Clear BRKA by writing a logic 0 to it before exiting the break routine. Reset clears the BRKA bit.

- 1 = Break address match
- 0 = No break address match

### 12.5.2 Break Address Registers

The break address registers contain the high and low bytes of the desired breakpoint address. Reset clears the break address registers.



Figure 12-4. Break Address Register (BRKH)



Figure 12-5. Break Address Register (BRKL)

## **12.6 Low-Power Modes**

The WAIT and STOP instructions put the MCU in low powerconsumption standby modes.

#### 12.6.1 Wait Mode or Stop Mode

A break interrupt causes exit from wait mode or stop mode and sets the SBSW bit in the SIM break status register. (See **10.8 SIM Registers**.)

Technical Data

# Section 13. Monitor ROM (MON)

## 13.1 Contents

| 13.2   | Introduction             |
|--------|--------------------------|
| 13.3   | Features                 |
| 13.4   | Functional Description   |
| 13.4.1 | Entering Monitor Mode166 |
| 13.4.2 | Data Format167           |
| 13.4.3 | Echoing                  |
| 13.4.4 | Break Signal             |
| 13.4.5 | Commands                 |
| 13.4.6 | Baud Rate                |
|        |                          |

# **13.2 Introduction**

This section describes the monitor ROM (MON). The monitor ROM allows complete testing of the MCU through a single-wire interface with a host computer.

## **13.3 Features**

Features of the monitor ROM include:

- Normal user-mode pin functionality
- One pin dedicated to serial communication between monitor ROM and host computer
- Standard mark/space non-return-to-zero (NRZ) communication with host computer
- 4800 baud–28.8 Kbaud communication with host computer
- Execution of code in RAM or ROM

## **13.4 Functional Description**

Monitor ROM receives and executes commands from a host computer. Figure 13-1 shows a sample circuit used to enter monitor mode and communicate with a host computer via a standard RS-232 interface.

While simple monitor commands can access any memory address, the MC68HC08QA24has a ROM security feature that requires proper procedures to be followed before the ROM can be accessed. Access to the ROM is denied to unauthorized users of customer-specified software.

In monitor mode, the MCU can execute host-computer code in RAM while all MCU pins except PTA0 retain normal operating mode functions. All communication between the host computer and the MCU is through the PTA0 pin. A level-shifting and multiplexing interface is required between PTA0 and the host computer. PTA0 is used in a wired-OR configuration and requires a pullup resistor.



Figure 13-1. Monitor Mode Circuit

#### 13.4.1 Entering Monitor Mode

 Table 13-1 shows the pin conditions for entering monitor mode.

| IRQ Pin                                             | PTC0 Pin | PTC1 Pin | PTA0 Pin | PTC3 Pin | Mode    | CGMOUT                                                   | Bus<br>Frequency |
|-----------------------------------------------------|----------|----------|----------|----------|---------|----------------------------------------------------------|------------------|
| V <sub>DD</sub> +<br>V <sub>HI</sub> <sup>(1)</sup> | 1        | 0        | 1        | 1        | Monitor | $\frac{\text{CGMXCLK}}{2}$ or $\frac{\text{CGMVCLK}}{2}$ | CGMOUT<br>2      |
| V <sub>DD</sub> +<br>V <sub>HI</sub> <sup>(1)</sup> | 1        | 0        | 1        | 0        | Monitor | CGMXCLK                                                  | CGMOUT<br>2      |

Table 13-1. Mode Selection

1. For V<sub>HI</sub>, see 23.5 DC Electrical Characteristics and 23.2 Maximum Ratings.

Enter monitor mode by either

- Executing a software interrupt instruction (SWI) or
- Applying a logic 0 and then a logic 1 to the RST pin

The MCU sends a break signal (10 consecutive logic 0s) to the host computer, indicating that it is ready to receive a command. The break signal also provides a timing reference to allow the host to determine the necessary baud rate.

Monitor mode uses alternate vectors for reset, SWI, and break interrupt. The alternate vectors are in the \$FE page instead of the \$FF page and allow code execution from the internal monitor firmware instead of user code. The COP module is disabled in monitor mode as long as  $V_{DD} + V_{HI}$  (see 23.5 DC Electrical Characteristics) is applied to either the IRQ pin or the RST pin. (See Section 10. System Integration Module (SIM) for more information on modes of operation.)

**NOTE:** Holding the PTC3 pin low when entering monitor mode causes a bypass of a divide-by-two stage at the oscillator. The CGMOUT frequency is equal to the CGMXCLK frequency, and the OSC1 input directly generates internal bus clocks. In this case, the OSC1 signal must have a 50 percent duty cycle at maximum bus frequency.

 Table 13-2 is a summary of the differences between user mode and monitor mode.

|         | Functions                      |                         |                        |                         |                        |                       |                      |  |  |  |  |  |
|---------|--------------------------------|-------------------------|------------------------|-------------------------|------------------------|-----------------------|----------------------|--|--|--|--|--|
| Modes   | СОР                            | Reset<br>Vector<br>High | Reset<br>Vector<br>Low | Break<br>Vector<br>High | Break<br>Vector<br>Low | SWI<br>Vector<br>High | SWI<br>Vector<br>Low |  |  |  |  |  |
| User    | Enabled                        | \$FFFE                  | \$FFFF                 | \$FFFC                  | \$FFFD                 | \$FFFC                | \$FFFD               |  |  |  |  |  |
| Monitor | onitor Disabled <sup>(1)</sup> |                         | \$FEFF                 | \$FEFC                  | \$FEFD                 | \$FEFC                | \$FEFD               |  |  |  |  |  |

1. If the high voltage ( $V_{DD} + V_{HI}$ ) is removed from the  $\overline{IRQ}/V_{PP}$  pin while in monitor mode, the SIM asserts its COP enable output. The COP is a mask option enabled or disabled by the COPD bit in the configuration register. (See 23.5 DC Electrical Characteristics.)

#### 13.4.2 Data Format

Communication with the monitor ROM is in standard non-return-to-zero (NRZ) mark/space data format. (See Figure 13-2 and Figure 13-3.)

The data transmit and receive rate can be anywhere from 4800 baud to 28.8 Kbaud. Transmit and receive baud rates must be identical.



Figure 13-2. Monitor Data Format



Figure 13-3. Sample Monitor Waveforms

## 13.4.3 Echoing

As shown in **Figure 13-4**, the monitor ROM immediately echoes each received byte back to the PTA0 pin for error checking.

Any result of a command appears after the echo of the last byte of the command.



Figure 13-4. Read Transaction

#### 13.4.4 Break Signal

A start bit followed by nine low bits is a break signal. (See Figure 13-5.) When the monitor receives a break signal, it drives the PTA0 pin high for the duration of two bits before echoing the break signal.



Figure 13-5. Break Transaction

#### 13.4.5 Commands

The monitor ROM uses these commands:

- READ, read memory
- WRITE, write memory
- IREAD, indexed read
- IWRITE, indexed write
- READSP, read stack pointer
- RUN, run user program

A sequence of IREAD or IWRITE commands can access a block of memory sequentially over the full 64-Kbyte memory map.

### Table 13-3. READ (Read Memory) Command

| Description    | Read byte from memory                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Operand        | Specifies 2-byte address in high byte:low byte order                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Data Returned  | Returns contents of specified address                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| Opcode         | \$4A                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| Command Sequer | READ X READ ADDR. HIGH ADDR. HIGH ADDR. LOW AD |

| OperandSpeData ReturnedNonOpcode\$49Command Sequence | e            | ddress in high by | yte:low byte o | rder; low byte | e followed b | y data byte |
|------------------------------------------------------|--------------|-------------------|----------------|----------------|--------------|-------------|
| Opcode \$49                                          |              |                   |                |                |              |             |
| · · · · · · · · · · · · · · · · · · ·                |              |                   |                |                |              |             |
| Command Sequence                                     |              |                   |                |                |              |             |
|                                                      | ITE ADDR. HI | GH X ADDR. HIGH   | ADDR. LOW      | ADDR. LOW      | DATA X       | DATA X      |

# Table 13-4. WRITE (Write Memory) Command

# Table 13-5. IREAD (Indexed Read) Command

| Description   | Read next 2 bytes in memory from last address accessed      |  |  |  |
|---------------|-------------------------------------------------------------|--|--|--|
| Operand       | Specifies 2-byte address in high byte:low byte order        |  |  |  |
| Data Returned | Returns contents of next two addresses                      |  |  |  |
| Opcode        | \$1A                                                        |  |  |  |
| Command Seque | nce                                                         |  |  |  |
|               | SENT TO<br>MONITOR<br>IREAD / IREAD / DATA / DATA /<br>ECHO |  |  |  |



#### Table 13-6. IWRITE (Indexed Write) Command

## Table 13-7. READSP (Read Stack Pointer) Command

| Description    | Reads stack pointer                                        |
|----------------|------------------------------------------------------------|
| Operand        | None                                                       |
| Data Returned  | Returns stack pointer in high byte:low byte order          |
| Opcode         | \$0C                                                       |
| Command Sequer | nce                                                        |
|                | SENT TO<br>MONITOR<br>READSP READSP SP HIGH SP LOW<br>ECHO |
|                | ECHO RESULT                                                |

| Description   | Executes RTI instruction |
|---------------|--------------------------|
| Operand       | None                     |
| Data Returned | None                     |
| Opcode        | \$28                     |
| Command Seque | nce                      |
|               | SENT TO<br>MONITOR       |

#### Table 13-8. RUN (Run User Program) Command

#### 13.4.6 Baud Rate

With a 4.9152-MHz crystal and the PTC3 pin at logic 1 during reset, data is transferred between the monitor and host at 4800 baud. If the PTC3 pin is at logic 0 during reset, the monitor baud rate is 9600. When the CGM output, CGMOUT, is driven by the PLL, the baud rate is determined by the MUL7–MUL4 bits in the PLL programming register (PPG). (See Section 9. Clock Generator Module (CGM).)

#### Table 13-9. Monitor Baud Rate Selection

|                                | VCO Frequency Multiplier (N) |      |        |        |        |        |
|--------------------------------|------------------------------|------|--------|--------|--------|--------|
|                                | 1                            | 2    | 3      | 4      | 5      | 6      |
| Monitor baud rate (4.9152 MHz) | 4800                         | 9600 | 14,400 | 19,200 | 24,000 | 28,800 |
| Monitor baud rate (4.194 MHz)  | 4096                         | 8192 | 12,288 | 16,384 | 20,480 | 24,576 |

172

# Section 14. Computer Operating Properly (COP)

## 14.1 Contents

| 14.2 Introduction                                                                                                                                                                                                                                                                                                                |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 14.3 Functional Description174                                                                                                                                                                                                                                                                                                   |
| 14.4       I/O Signals       176         14.4.1       CGMXCLK.       176         14.4.2       STOP Instruction       176         14.4.3       COPCTL Write       176         14.4.4       Internal Reset Resources       176         14.4.5       Reset Vector Fetch       176         14.4.6       COPD (COP Disable)       176 |
| 14.4.7 COPS (COP Short Timeout)                                                                                                                                                                                                                                                                                                  |
| 14.5 COP Control Register                                                                                                                                                                                                                                                                                                        |
| 14.6 Interrupts177                                                                                                                                                                                                                                                                                                               |
| 14.7 Monitor Mode                                                                                                                                                                                                                                                                                                                |
| 14.8         Low-Power Modes         178           14.8.1         Wait Mode         178           14.8.2         Stop Mode         178                                                                                                                                                                                           |
| 14.9 COP Module During Break Interrupts                                                                                                                                                                                                                                                                                          |

## 14.2 Introduction

This section describes the computer operating properly (COP) module, a free-running counter that generates a reset if allowed to overflow. The COP module helps software recover from runaway code. Prevent a COP reset by periodically clearing the COP counter.

MC68HC08QA24

# 14.3 Functional Description

Figure 14-1 shows the structure of the COP module.



#### Note:

1. See 10.4.2 Active Resets from Internal Sources.



The COP counter is a free-running 6-bit counter preceded by the 12-bit system integration module (SIM) counter. COP timeouts are determined strictly by the clock generator module (CGM) crystal oscillator clock signal (CGMXCLK), not the CGMOUT signal (see Figure 9-1. CGM Block Diagram).

If not cleared by software, the COP counter overflows and generates an asynchronous reset after  $(2^{13} - 2^4)$  or  $(2^{18} - 2^4)$  CGMXCLK cycles, depending upon COPS bit in the mask option register (MOR) (\$001F) (see **5.4 Mask Option Register**). With a 4.194-MHz crystal and the COPS bit in the MOR (\$001F) set to a logic 1, the COP timeout period is approximately 62.5 ms. Writing any value to location \$FFFF before overflow occurs clears the COP counter, clears bits 12–4 of the SIM counter, and prevents reset. A CPU interrupt routine can be used to clear the COP.

**NOTE:** The COP should be serviced as soon as possible out of reset and before entering or after exiting stop mode to guarantee the maximum selected amount of time before the first timeout.

A COP reset pulls the RST pin low for 32 CGMXCLK cycles and sets the COP bit in the SIM reset status register (SRSR) (see **10.8.2 SIM Reset Status Register**).

While the microcontroller is in monitor mode, the COP module is disabled if the  $\overline{RST}$  pin or the  $\overline{IRQ}$  pin is held at  $V_{DD} + V_{HI}$  (see 23.5 DC Electrical Characteristics). During a break state,  $V_{DD} + V_{HI}$  on the  $\overline{RST}$  pin disables the COP module.

**NOTE:** Place COP clearing instructions in the main program and not in an interrupt subroutine. Such an interrupt subroutine could keep the COP from generating a reset even while the main program is not working properly.

## 14.4 I/O Signals

The following subsections describe the signals shown in Figure 14-1.

#### 14.4.1 CGMXCLK

CGMXCLK is the crystal oscillator output signal. CGMXCLK frequency is equal to the crystal frequency.

## 14.4.2 STOP Instruction

The STOP instruction clears the SIM counter.

#### 14.4.3 COPCTL Write

Writing any value to the COP control register (COPCTL) (see **14.5 COP Control Register**) clears the COP counter and clears bits 12–4 of the SIM counter. Reading the COP control register returns the reset vector.

#### 14.4.4 Internal Reset Resources

An internal reset clears the SIM counter and the COP counter. (See **10.4.2 Active Resets from Internal Sources**.)

#### 14.4.5 Reset Vector Fetch

A reset vector fetch occurs when the vector address appears on the data bus. A reset vector fetch clears the SIM counter.

#### 14.4.6 COPD (COP Disable)

The COPD bit reflects the state of the COP disable bit (COPD) in the MOR (\$001F). This signal disables COP generated resets when asserted. (See **5.4 Mask Option Register**.)

**Technical Data** 

#### 14.4.7 COPS (COP Short Timeout)

The COPS bit selects the state of the COP short timeout bit (COPS) in the MOR (001F). Timeout periods can be ( $2^{18}-2^4$ ) or ( $2^{13}-2^4$ ) CGMXCLK cycles. (See **5.4 Mask Option Register**.)

## 14.5 COP Control Register

The COP control register is located at address \$FFFF and overlaps the reset vector. Writing any value to \$FFFF clears the COP counter and starts a new timeout period. Reading location \$FFFF returns the low byte of the reset vector.

Address: \$FFFF



Figure 14-2. COP Control Register (COPCTL)

### 14.6 Interrupts

The COP does not generate CPU interrupt requests.

### 14.7 Monitor Mode

The COP is disabled in monitor mode when  $V_{DD} + V_{HI}$  (see 23.5 DC Electrical Characteristics) is present on the IRQ pin or on the RST pin.

## 14.8 Low-Power Modes

The following subsections describe the low-power modes.

#### 14.8.1 Wait Mode

The COP continues to operate during wait mode. To prevent a COP reset during wait mode, periodically clear the COP counter in a CPU interrupt routine.

**NOTE:** If the COP is enabled in wait mode, it must be periodically refreshed.

#### 14.8.2 Stop Mode

Stop mode turns off the CGMXCLK input to the COP and clears the SIM counter. Service the COP immediately before entering or after exiting stop mode to ensure a full COP timeout period after entering or exiting stop mode.

The STOP bit in the MOR register (\$001F) (see **5.4 Mask Option Register**) enables the STOP instruction. To prevent inadvertently turning off the COP with a STOP instruction, disable the STOP instruction by programming the STOP bit to logic 0.

## 14.9 COP Module During Break Interrupts

The COP is disabled during a break interrupt when  $V_{DD} + V_{HI}$  (see 23.5 DC Electrical Characteristics) is present on the RST pin.

# Section 15. External Interrupt (IRQ)

## **15.1 Contents**

| 15.2 | Introduction                       |
|------|------------------------------------|
| 15.3 | Features                           |
| 15.4 | Functional Description             |
| 15.5 | IRQ Pin                            |
| 15.6 | IRQ Module During Break Interrupts |
| 15.7 | IRQ Status and Control Register    |

# **15.2 Introduction**

This section describes the non-maskable external interrupt (IRQ) input.

## **15.3 Features**

Features include:

- Dedicated external interrupt pin (IRQ)
- Hysteresis buffer
- Programmable edge-only or edge and level interrupt sensitivity
- Automatic interrupt acknowledge

## **15.4 Functional Description**

A logic 0 applied to the external interrupt pin can latch a CPU interrupt request. **Figure 15-1** shows the structure of the IRQ module.

Interrupt signals on the  $\overline{IRQ}$  pin are latched into the IRQ latch. An interrupt latch remains set until one of these actions occurs:

- Vector fetch A vector fetch automatically generates an interrupt acknowledge signal that clears the latch that caused the vector fetch.
- Software clear Software can clear an interrupt latch by writing to the appropriate acknowledge bit in the interrupt status and control register (ISCR). Writing a logic 1 to the ACK bit clears the IRQ latch.
- Reset A reset automatically clears both interrupt latches.

The external interrupt pin is falling-edge triggered and is softwareconfigurable to be both falling-edge and low-level triggered. The MODE bit in the ISCR controls the triggering sensitivity of the IRQ pin.



Figure 15-1. IRQ Block Diagram

Technical Data
When an interrupt pin is edge-triggered only, the interrupt latch remains set until a vector fetch, software clear, or reset occurs.

When an interrupt pin is both falling-edge and low-level-triggered, the interrupt latch remains set until both of these occur:

- Vector fetch or software clear
- Return of the interrupt pin to logic 1

The vector fetch or software clear may occur before or after the interrupt pin returns to logic 1. As long as the pin is low, the interrupt request remains pending. A reset will clear the latch and the MODE control bit, thereby clearing the interrupt even if the pin stays low.

When set, the IMASK bit in the ISCR masks all external interrupt requests. A latched interrupt request is not presented to the interrupt priority logic unless the corresponding IMASK bit is clear.

**NOTE:** The interrupt mask (I) in the condition code register (CCR) masks all interrupt requests, including external interrupt requests. (See Figure 15-2.)

## 15.5 IRQ Pin

A logic 0 on the  $\overline{IRQ}$  pin can latch an interrupt request into the IRQ latch. A vector fetch, software clear, or reset clears the IRQ latch.

If the MODE bit is set, the  $\overline{IRQ}$  pin is both falling-edge sensitive and low-level sensitive. With MODE set, both of these actions must occur to clear the IRQ latch:

Vector fetch or software clear — A vector fetch generates an interrupt acknowledge signal to clear the latch. Software may generate the interrupt acknowledge signal by writing a logic 1 to the ACK bit in the interrupt status and control register (ISCR). The ACK bit is useful in applications that poll the IRQ pin and require software to clear the IRQ latch. Writing to the ACK bit can also prevent spurious interrupts due to noise. Setting ACK does not affect subsequent transitions on the IRQ pin. A falling edge on IRQ that occurs after writing to the ACK bit latches another interrupt



Figure 15-2. IRQ Interrupt Flowchart

request. If the IRQ mask bit, IMASK, is clear, the CPU loads the program counter with the vector address at locations \$FFFA and \$FFFB.

 Return of the IRQ pin to logic 1 — As long as the IRQ pin is at logic 0, the IRQ latch remains set.

The vector fetch or software clear and the return of the  $\overline{IRQ}$  pin to logic 1 can occur in any order. The interrupt request remains pending as long as the  $\overline{IRQ}$  pin is at logic 0. A reset will clear the latch and the MODE control bit, thereby clearing the interrupt even if the pin stays low.

If the MODE bit is clear, the  $\overline{IRQ}$  pin is falling-edge sensitive only. With MODE clear, a vector fetch or software clear immediately clears the IRQ latch.

The IRQF bit in the ISCR register can be used to check for pending interrupts. The IRQF bit is not affected by the IMASK bit, which makes it useful in applications where polling is preferred.

Use the branch if interrupt pin is high (BIH) or branch if interrupt pin is low (BIL) instruction to read the logic level on the  $\overline{IRQ}$  pin.

**NOTE:** When using the level-sensitive interrupt trigger, avoid false interrupts by masking interrupt requests in the interrupt routine.

## 15.6 IRQ Module During Break Interrupts

The system integration module (SIM) controls whether the IRQ interrupt latch can be cleared during the break state. The BCFE bit in the SIM break flag control register (SBFCR) enables software to clear the latches during the break state. (See **10.8.3 SIM Break Flag Control Register**.)

To allow software to clear the IRQ latch during a break interrupt, write a logic 1 to the BCFE bit. If a latch is cleared during the break state, it remains cleared when the MCU exits the break state.

To protect the latch during the break state, write a logic 0 to the BCFE bit. With BCFE at logic 0 (its default state), writing to the ACK bit in the IRQ status and control register during the break state has no effect on the IRQ latch.

## 15.7 IRQ Status and Control Register

The IRQ status and control register (ISCR) controls and monitors operation of the IRQ module. The ISCR has these functions:

- Shows the state of the IRQ interrupt flag
- Clears the IRQ interrupt latch
- Masks IRQ interrupt request
- Controls triggering sensitivity of the IRQ interrupt pin

Address: \$001A

|        | Bit 7 | 6         | 5 | 4 | 3    | 2   | 1     | Bit 0 |
|--------|-------|-----------|---|---|------|-----|-------|-------|
| Read:  | 0     | 0         | 0 | 0 | IRQF | 0   | IMASK | MODE  |
| Write: | R     | R         | R | R | R    | ACK | IWASK | WODE  |
| Reset: | 0     | 0         | 0 | 0 | 0    | 0   | 0     | 0     |
|        | R     | = Reserve | d |   |      |     |       |       |



## $IRQF - \overline{IRQ} Flag$

This read-only status bit is high when the IRQ interrupt is pending.

- $1 = \overline{IRQ}$  interrupt pending
- $0 = \overline{IRQ}$  interrupt not pending

ACK — IRQ Interrupt Request Acknowledge Bit

Writing a logic 1 to this write-only bit clears the IRQ latch. ACK always reads as logic 0. Reset clears ACK.

IMASK — IRQ Interrupt Mask Bit

Writing a logic 1 to this read/write bit disables IRQ interrupt requests. Reset clears IMASK.

- $1 = \overline{IRQ}$  interrupt requests disabled
- $0 = \overline{IRQ}$  interrupt requests enabled

MODE — IRQ Edge/Level Select Bit

This read/write bit controls the triggering sensitivity of the IRQ pin. Reset clears MODE.

 $1 = \overline{IRQ}$  interrupt requests on falling edges and low levels

 $0 = \overline{IRQ}$  interrupt requests on falling edges only

# Section 16. Input/Output (I/O) Ports

## 16.1 Contents

## 16.2 Introduction

Forty bidirectional input/output (I/O) pins form six parallel ports. All I/O pins are programmable as inputs or outputs.

**NOTE:** Connect any unused I/O pins to an appropriate logic level, either  $V_{DD}$  or  $V_{SS}$ . Although the I/O ports do not require termination for proper operation, termination reduces excess current consumption and the possibility of electrostatic damage.

| Addr.  | Register Name                 |                 | Bit 7               | 6         | 5       | 4          | 3          | 2     | 1     | Bit 0 |
|--------|-------------------------------|-----------------|---------------------|-----------|---------|------------|------------|-------|-------|-------|
| \$0000 | Dort A Data Dogistor          | Read:<br>Vrite: | PTA7                | PTA6      | PTA5    | PTA4       | PTA3       | PTA2  | PTA1  | PTA0  |
|        | Re                            | eset:           |                     |           |         | Unaffected | l by reset |       |       |       |
| \$0001 | Dort P. Data Dogistor         | Read:<br>Vrite: | PTB7                | PTB6      | PTB5    | PTB4       | PTB3       | PTB2  | PTB1  | PTB0  |
|        | Re                            | eset:           | Unaffected by reset |           |         |            |            |       |       |       |
|        |                               | ead:            | 0                   | 0         | 0       | PTC4       | PTC3       | PTC2  | PTC1  | PTC0  |
| \$0002 | Port C Data Register<br>(PTC) | Vrite:          | R                   | R         | R       | FTC4       | 1105       | FTC2  | FICI  |       |
|        | Re                            | eset:           | Unaffected by reset |           |         |            |            |       |       |       |
|        |                               | ead:            | 0                   | 0         | PTD5    | PTD4       | PTD3       | PTD2  | PTD1  | PTD0  |
| \$0003 | Port D Data Register<br>(PTD) | Vrite:          | R                   | R         | 1105    | 1104       | 1105       | TTDZ  |       |       |
|        | Re                            | eset:           | Unaffected by reset |           |         |            |            |       |       |       |
| \$0004 | Data Direction Degister A     | Read:<br>Vrite: | DDRA7               | DDRA6     | DDRA5   | DDRA4      | DDRA3      | DDRA2 | DDRA1 | DDRA0 |
|        | · · · · ·                     | eset:           | 0                   | 0         | 0       | 0          | 0          | 0     | 0     | 0     |
| \$0005 | Data Direction Pedister B     | Read:<br>Vrite: | DDRB7               | DDRB6     | DDRB5   | DDRB4      | DDRB3      | DDRB2 | DDRB1 | DDRB0 |
|        | Re                            | eset:           | 0                   | 0         | 0       | 0          | 0          | 0     | 0     | 0     |
|        |                               | Γ               | R                   | = Reserve | ed      |            |            |       |       |       |
|        | Figu                          | ure             | 16-1. I/            | O Port    | Registe | er Summ    | nary       |       |       |       |

| Addr.  | Register Name                           |        | Bit 7  | 6     | 5     | 4          | 3          | 2     | 1     | Bit 0 |
|--------|-----------------------------------------|--------|--------|-------|-------|------------|------------|-------|-------|-------|
|        |                                         | Read:  | MCLKEN | 0     | 0     | DDRC4      | DDRC3      | DDRC2 | DDRC1 | DDRC0 |
| \$0006 | Data Direction Register C<br>(DDRC)     |        |        | R     | R     | DDKC4      | DDRC3      | DDRGZ | DDRCI | DDRCU |
|        | · · · ·                                 | Reset: | 0      | 0     | 0     | 0          | 0          | 0     | 0     | 0     |
|        |                                         | Read:  | 0      | 0     | DDRD5 | DDRD4      | DDRD3      | DDR2  | DDRD1 | חחחח  |
| \$0007 | Data Direction Register D<br>(DDRD)     | Write: | R      | R     | סאסס  | UUKU4      |            | DDKZ  |       | DDRD0 |
|        | · · · ·                                 | Reset: | 0      | 0     | 0     | 0          | 0          | 0     | 0     | 0     |
|        |                                         | Read:  | PTE7   | PTE6  | PTE5  | PTE4       | PTE3       | PTE2  | PTE1  | PTE0  |
| \$0008 | Port E Data Register<br>(PTE)           | Write: | PIE/   | FILO  | PIES  | FIL4       | FILJ       | FILZ  | 1161  | FILU  |
|        | · · · ·                                 | Reset: |        |       |       | Unaffected | d by reset |       |       |       |
|        |                                         | Read:  | 0      | 0     | 0     | 0          | PTF3       | ρτερ  | DTΓ1  | ρτεο  |
| \$0009 | Port F Data Register<br>(PTF)           | Write: | R      | R     | R     | R          | PIF3       | PTF2  | PTF1  | PTF0  |
|        | ( , , , , , , , , , , , , , , , , , , , | Reset: |        |       |       | Unaffected | d by reset |       |       |       |
|        |                                         | Read:  | DDRE7  | DDRE6 | DDRE5 | DDRE4      | DDRE3      | DDRE2 | DDRE1 | DDRE0 |
| \$000C | Data Direction Register E<br>(DDRE)     | Write: | DDRE/  | DDREO | DDRED | DDKE4      | DDRE3      | DDREZ | DUKET | DDREU |
|        | · · · ·                                 | Reset: | 0      | 0     | 0     | 0          | 0          | 0     | 0     | 0     |
|        |                                         | Read:  | 0      | 0     | 0     | 0          | רחחח       | סססרי |       |       |
| \$000D | D Data Direction Register F<br>(DDRF)   |        | R      | R     | R     | R          | DDRF3      | DDRF2 | DDRF1 | DDRF0 |
|        | (5511)                                  | Reset: | 0      | 0     | 0     | 0          | 0          | 0     | 0     | 0     |
|        |                                         |        |        |       |       |            |            |       |       |       |

Figure 16-1. I/O Port Register Summary (Continued)

### 16.3 Port A

Port A is an 8-bit, general-purpose, bidirectional I/O port.

#### 16.3.1 Port A Data Register

The port A data register contains a data latch for each of the eight port A pins.



Figure 16-2. Port A Data Register (PTA)

PTA[7:0] — Port A Data Bits

These read/write bits are software programmable. Data direction of each port A pin is under the control of the corresponding bit in data direction register A. Reset has no effect on port A data.

#### 16.3.2 Data Direction Register A

Data direction register A (DDRA) determines whether each port A pin is an input or an output. Writing a logic 1 to a DDRA bit enables the output buffer for the corresponding port A pin; a logic 0 disables the output buffer.



Figure 16-3. Data Direction Register A (DDRA)

**Technical Data** 

DDRA[7:0] — Data Direction Register A Bits

These read/write bits control port A data direction. Reset clears DDRA[7:0], configuring all port A pins as inputs.

- 1 = Corresponding port A pin configured as output
- 0 = Corresponding port A pin configured as input
- **NOTE:** Avoid glitches on port A pins by writing to the port A data register before changing data direction register A bits from 0 to 1.

Figure 16-4 shows the port A I/O logic.



Figure 16-4. Port A I/O Circuit

When bit DDRAx is a logic 1, reading address \$0000 reads the PTAx data latch. When bit DDRAx is a logic 0, reading address \$0000 reads the voltage level on the pin. The data latch can always be written, regardless of the state of its data direction bit. Table 16-1 summarizes the operation of the port A pins.

Table 16-1. Port A Pin Functions

| DDRA<br>Bit | PTA<br>Bit | I/O Pin<br>Mode | Accesses<br>to DDRA | Accesse  | s to PTA                |
|-------------|------------|-----------------|---------------------|----------|-------------------------|
|             | Bit Mode   |                 | Read/Write          | Read     | Write                   |
| 0           | Х          | Input, Hi-Z     | DDRA[7:0]           | Pin      | PTA[7:0] <sup>(1)</sup> |
| 1           | Х          | Output          | DDRA[7:0]           | PTA[7:0] | PTA[7:0]                |

X = don't care

Hi-Z = high impedance

1. Writing affects data register, but does not affect input.

## 16.4 Port B

Port B is an 8-bit special function port that shares all of its pins with the analog-to-digital converter (ADC).

#### 16.4.1 Port B Data Register

The port B data register contains a data latch for each of the eight port B pins.

| Address:                | \$0001 |      |      |           |            |      |      |       |
|-------------------------|--------|------|------|-----------|------------|------|------|-------|
|                         | Bit 7  | 6    | 5    | 4         | 3          | 2    | 1    | Bit 0 |
| Read:<br>Write:         | PTB7   | PTB6 | PTB5 | PTB4      | PTB3       | PTB2 | PTB1 | PTB0  |
| Reset:                  |        |      |      | Unaffecte | d by reset |      |      |       |
| Alternate<br>Functions: | ATD7   | ATD6 | ATD5 | ATD4      | ATD3       | ATD2 | ATD1 | ATD0  |
| -                       | r      |      |      |           | Deviat     |      |      |       |

#### Figure 16-5. Port B Data Register (PTB)

PTB[7:0] — Port B Data Bits

These read/write bits are software programmable. Data direction of each port B pin is under the control of the corresponding bit in data direction register B. Reset has no effect on port B data.

#### ATD[7:0] — ADC Channels

PTB7/ATD7–PTB0/ATD0 are eight of the 12 analog-to-digital converter channels. The ADC channel select bits, CH[4:0], determine whether the PTB7/ATD7–PTB0/ATD0 pins are ADC channels or general-purpose I/O pins. If an ADC channel is selected and a read of this corresponding bit in the port B data register occurs, the data will be 0 if the data direction for this bit is programmed as an input. Otherwise, the data will reflect the value in the data latch. (See **Section 19. Analog-to-Digital Converter (ADC)**.) Data direction register B (DDRB) does not affect the data direction of port B pins that are being used by the ADC. However, the DDRB bits always determine whether reading port B returns to the states of the latches or logic 0.

#### 16.4.2 Data Direction Register B

Data direction register B determines whether each port B pin is an input or an output. Writing a logic 1 to a DDRB bit enables the output buffer for the corresponding port B pin; a logic 0 disables the output buffer.

| Address:        | \$0005 |       |       |       |       |       |       |       |
|-----------------|--------|-------|-------|-------|-------|-------|-------|-------|
|                 | Bit 7  | 6     | 5     | 4     | 3     | 2     | 1     | Bit 0 |
| Read:<br>Write: | DDRB7  | DDRB6 | DDRB5 | DDRB4 | DDRB3 | DDRB2 | DDRB1 | DDRB0 |
| Reset:          | 0      | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

Figure 16-6. Data Direction Register B (DDRB)

DDRB[7:0] — Data Direction Register B Bits

These read/write bits control port B data direction. Reset clears DDRB[7:0], configuring all port B pins as inputs.

1 = Corresponding port B pin configured as output

- 0 = Corresponding port B pin configured as input
- **NOTE:** Avoid glitches on port B pins by writing to the port B data register before changing data direction register B bits from 0 to 1.

Figure 16-7 shows the port B I/O logic.



Figure 16-7. Port B I/O Circuit

When bit DDRBx is a logic 1, reading address \$0001 reads the PTBx data latch. When bit DDRBx is a logic 0, reading address \$0001 reads the voltage level on the pin, or logic 0 if that particular bit is in use by the ADC. The data latch can always be written, regardless of the state of its data direction bit. Table 16-2 summarizes the operation of the port B pins.

| DDRB<br>Bit | PTB<br>Bit | Bit in Use<br>by ADC | I/O Pin<br>Mode | Accesses<br>to DDRB | Accesses to PTB |                         |  |
|-------------|------------|----------------------|-----------------|---------------------|-----------------|-------------------------|--|
| Bit         |            | by ADC               | Wode            | Read/Write          | Read            | Write                   |  |
| 0           | Х          | No                   | Input, Hi-Z     | DDRB[7:0]           | Pin             | PTB[7:0] <sup>(1)</sup> |  |
| 1           | Х          | No                   | Output          | DDRB[7:0]           | PTB[7:0]        | PTB[7:0]                |  |
| 0           | Х          | Yes                  | Input, Hi-Z     | DDRB[7:0]           | 0               | PTB[7:0] <sup>(1)</sup> |  |
| 1           | Х          | Yes                  | Input, Hi-Z     | DDRB[7:0]           | PTB[7:0]        | PTB[7:0]                |  |

 Table 16-2. Port B Pin Functions

X = don't care

Hi-Z = high impedance

1. Writing affects data register, but does not affect input.

## 16.5 Port C

Port C is a 5-bit, general-purpose, bidirectional I/O port that shares one of its pins with the bus clock (MCLK).

#### 16.5.1 Port C Data Register

The port C data register contains a data latch for each of the five port C pins.



Figure 16-8. Port C Data Register (PTC)

PTC[4:0] — Port C Data Bits

These read/write bits are software-programmable. Data direction of each port C pin is under the control of the corresponding bit in data direction register C. Reset has no effect on port C data.

MCLK — T12 System Bus Clock Bit

The bus clock (MCLK) is driven out of PTC2 when enabled by the MCLKEN bit in PTCDDR7.

#### 16.5.2 Data Direction Register C

Data direction register C determines whether each port C pin is an input or an output. Writing a logic 1 to a DDRC bit enables the output buffer for the corresponding port C pin; a logic 0 disables the output buffer.





MCLKEN — MCLK Enable Bit

This read/write bit enables MCLK to be an output signal on PTC2. If MCLK is enabled, PTC2 is under the control of MCLKEN. Reset clears this bit.

1 = MCLK output enabled

0 = MCLK output disabled

DDRC[4:0] — Data Direction Register C Bits

These read/write bits control port C data direction. Reset clears DDRC[7:0], configuring all port C pins as inputs.

1 = Corresponding port C pin configured as output

0 = Corresponding port C pin configured as input

**NOTE:** Avoid glitches on port C pins by writing to the port C data register before changing data direction register C bits from 0 to 1.

Figure 16-10 shows the port C I/O logic.



Figure 16-10. Port C I/O Circuit

When bit DDRCx is a logic 1, reading address \$0002 reads the PTCx data latch. When bit DDRCx is a logic 0, reading address \$0002 reads the voltage level on the pin. The data latch can always be written, regardless of the state of its data direction bit. Table 16-3 summarizes the operation of the port C pins.

| Table 16-3. Port C Pin Function | าร |
|---------------------------------|----|
|---------------------------------|----|

| DDRC<br>Bit | PTC<br>Bit | I/O Pin<br>Mode | Accesses<br>to DDRC | -          | cesses<br>PTC               |  |
|-------------|------------|-----------------|---------------------|------------|-----------------------------|--|
| Dit         | DIL        | WOUE            | Read/Write          | Read       | Write                       |  |
| [7] = 0     | PTC2       | Input, Hi-Z     | DDRC[7]             | 0          | PTC2                        |  |
| [7] = 1     | PTC2       | Output, MCLK    | DDRC[7]             | Data Latch | —                           |  |
| 0           | Х          | Input, Hi-Z     | DDRC[4:0]           | Pin        | PTC[4:3,1:0] <sup>(1)</sup> |  |
| 1           | Х          | Output          | DDRC[4:0]           | PTC[4:0]   | TC[4:0] PTC[4:3,1:0]        |  |

X = don't care

Hi-Z = high impedance

1. Writing affects data register, but does not affect input.

## 16.6 Port D

Port D is a 6-bit, special function I/O port that shares some of its pins with the analog-to-digital converter (ADC).

#### 16.6.1 Port D Data Register

The port D data register contains a data latch for the seven port D pins.



Figure 16-11. Port D Data Register (PTD)

PTD[5:0] - Port D Data Bits

PTD[5:0] are read/write, software programmable bits. Data direction of PTD[5:0] pins are under the control of the corresponding bit in data direction register D.

#### ATD[11:8] — ADC Channel Status Bits

PTD3/ATD11–PTD0/ATD8 are four of the 12 analog-to-digital converter channels. The ADC channel select bits, CH[4:0], determine whether the PTD3/ATD11–PTD0/ATD8 pins are ADC channels or general-purpose I/O pins. If an ADC channel is selected and a read of this corresponding bit in the port B data register occurs, the data will be 0 if the data direction for this bit is programmed as an input. Otherwise, the data will reflect the value in the data latch. (See Section 19. Analog-to-Digital Converter (ADC).)

**NOTE:** Data direction register D (DDRD) does not affect the data direction of port D pins that are being used by the ADC. However, the DDRD bits

**Technical Data** 

always determine whether reading port D returns the states of the latches or logic 0.

**NOTE:** Do not use ADC channel ATD14 when using the FLT pin as the clock input for the TIM.

#### 16.6.2 Data Direction Register D

Data direction register D determines whether each port D pin is an input or an output. Writing a logic 1 to a DDRD bit enables the output buffer for the corresponding port D pin; a logic 0 disables the output buffer.

Address: \$0007



Figure 16-12. Data Direction Register D (DDRD)

DDRD[5:0] — Data Direction Register D Bits

These read/write bits control port D data direction. Reset clears DDRD[5:0], configuring all port D pins as inputs.

- 1 = Corresponding port D pin configured as output
- 0 = Corresponding port D pin configured as input
- **NOTE:** Avoid glitches on port D pins by writing to the port D data register before changing data direction register D bits from 0 to 1.

Figure 16-13 shows the port D I/O logic.



Figure 16-13. Port D I/O Circuit

When bit DDRDx is a logic 1, reading address \$0003 reads the PTDx data latch. When bit DDRDx is a logic 0, reading address \$0003 reads the voltage level on the pin. The data latch can always be written, regardless of the state of its data direction bit. **Table 16-4** summarizes the operation of the port D pins.

| Table 16-4. | Port D Pin | Functions |
|-------------|------------|-----------|
|-------------|------------|-----------|

| DDRD<br>Bit | PTD Bit in Use<br>Bit by ADC |        | I/O Pin<br>Mode | Accesses<br>to DDRD | Accesses<br>to PTD |                         |  |
|-------------|------------------------------|--------|-----------------|---------------------|--------------------|-------------------------|--|
| Dit         | ы                            | by ADC | woue            | Read/Write          | Read               | Write                   |  |
| 0           | Х                            | No     | Input, Hi-Z     | DDRD[5:0]           | Pin                | PTD[5:0] <sup>(1)</sup> |  |
| 1           | Х                            | No     | Output          | DDRD[5:0]           | PTD[5:0]           | PTD[5:0]                |  |
| 0           | Х                            | Yes    | Input, Hi-Z     | DDRD[5:0]           | 0                  | PTD[5:0] <sup>(1)</sup> |  |
| 1           | Х                            | Yes    | Input, Hi-Z     | DDRD[5:0]           | PTD[5:0]           | TD[5:0] PTD[5:0]        |  |

X = don't care

Hi-Z = high impedance

1. Writing affects data register, but does not affect input.

198

## 16.7 Port E

Port E is an 8-bit special function port that shares two of its pins with the timer interface module (TIM), two of its pins with the serial communications interface module (SCI), and four of its pins with the serial peripheral interface module (SPI).

#### 16.7.1 Port E Data Register

The port E data register contains a data latch for each of the eight port E pins.

| Address:               | \$0008 |      |      |           |            |       |      |       |
|------------------------|--------|------|------|-----------|------------|-------|------|-------|
|                        | Bit 7  | 6    | 5    | 4         | 3          | 2     | 1    | Bit 0 |
| Read:<br>Write:        | PTE7   | PTE6 | PTE5 | PTE4      | PTE3       | PTE2  | PTE1 | PTE0  |
| Reset:                 |        |      |      | Unaffecte | d by reset |       |      |       |
| Alternate<br>Function: | SPSCK  | MOSI | MISO | SS        | TACH1      | TACH0 | RxD  | TxD   |

Figure 16-14. Port E Data Register (PTE)

PTE[7:0] — Port E Data Bits

PTE[7:0] are read/write, software programmable bits. Data direction of each port E pin is under the control of the corresponding bit in data direction register E.

SPSCK — SPI Serial Clock Bit

The PTE7/SPSCK pin is the serial clock input of an SPI slave module and serial clock output of an SPI master module. When the SPE bit is clear, the PTE7/SPSCK pin is available for general-purpose I/O.

MOSI — Master Out/Slave In Bit

The PTE6/MOSI pin is the master out/slave in terminal of the SPI module. When the SPE bit is clear, the PTE6/MOSI pin is available for general-purpose I/O. (See **18.14.1 SPI Control Register**.)

#### MISO — Master In/Slave Out Bit

The PTE5/MISO pin is the master in/slave out terminal of the SPI module. When the SPI enable bit, SPE, is clear, the SPI module is disabled, and the PTE5/MISO pin is available for general-purpose I/O. (See **18.14.1 SPI Control Register**.)

SS — Slave Select Bit

The PTE4/SS pin is the slave select input of the SPI module. When the SPE bit is clear or when the SPI master bit, SPMSTR, is set and MODFEN bit is low, the PTE4/SS pin is available for general-purpose I/O. (See **18.13.4 SS (Slave Select)**.) When the SPI is enabled as a slave, the DDRE4 bit in data direction register E (DDRE) has no effect on the PTE4/SS pin.

**NOTE:** Data direction register E (DDRE) does not affect the data direction of port E pins that are being used by the SPI module. However, the DDRE bits always determine whether reading port E returns the states of the latches or the states of the pins. (See Table 16-5.)

TACH[1:0] — Timer A Channel I/O Bits

The PTE3/TACH1–PTE2/TACH0 pins are the TIM input capture/output compare pins. The edge/level select bits, ELSxB:ELSxA, determine whether the PTE3/TACH1–PTE2/TACH0 pins are timer A channel I/O pins or general-purpose I/O pins. (See **20.9.4 TIMA Channel Status and Control Registers**.)

**NOTE:** Data direction register E (DDRE) does not affect the data direction of port E pins that are being used by the TIM. However, the DDRE bits always determine whether reading port E returns the states of the latches or the states of the pins. (See Table 16-5.)

RxD — SCI Receive Data Input Bit

The PTE1/RxD pin is the receive data input for the SCI module. When the enable SCI bit, ENSCI, is clear, the SCI module is disabled, and the PTE1/RxD pin is available for general-purpose I/O. (See 17.9.1 SCI Control Register 1.)

TxD — SCI Transmit Data Output

The PTE0/TxD pin is the transmit data output for the SCI module. When the enable SCI bit, ENSCI, is clear, the SCI module is disabled, and the PTE0/TxD pin is available for general-purpose I/O. (See **17.9.1 SCI Control Register 1**.)

**NOTE:** Data direction register E (DDRE) does not affect the data direction of port E pins that are being used by the SCI module. However, the DDRE bits always determine whether reading port E returns the states of the latches or the states of the pins. (See **Table 16-5**.)

#### 16.7.2 Data Direction Register E

Data direction register E determines whether each port E pin is an input or an output. Writing a logic 1 to a DDRE bit enables the output buffer for the corresponding port E pin; a logic 0 disables the output buffer.

Address: \$000C

|        | Bit 7 | 6      | 5      | 4      | 3     | 2     | 1      | Bit 0  |
|--------|-------|--------|--------|--------|-------|-------|--------|--------|
| Read:  | DDRE7 | DDRE6  | DDRE5  | DDRE4  | DDRE3 | DDRE2 | DDRE1  | DDRE0  |
| Write: | DDRL  | DDILLO | DDILLJ | DDICL4 | DDRLJ | DDRLZ | DDILLI | DDICEO |
| Reset: | 0     | 0      | 0      | 0      | 0     | 0     | 0      | 0      |

Figure 16-15. Data Direction Register E (DDRE)

DDRE[7:0] — Data Direction Register E Bits

These read/write bits control port E data direction. Reset clears DDRE[7:0], configuring all port E pins as inputs.

- 1 = Corresponding port E pin configured as output
- 0 = Corresponding port E pin configured as input
- **NOTE:** Avoid glitches on port E pins by writing to the port E data register before changing data direction register E bits from 0 to 1.

Figure 16-16 shows the port E I/O logic.



Figure 16-16. Port E I/O Circuit

When bit DDREx is a logic 1, reading address \$0008 reads the PTEx data latch. When bit DDREx is a logic 0, reading address \$0008 reads the voltage level on the pin. The data latch can always be written, regardless of the state of its data direction bit. **Table 16-5** summarizes the operation of the port E pins.

| Table | 16-5. | Port E | : Pin | Functions |
|-------|-------|--------|-------|-----------|
|-------|-------|--------|-------|-----------|

| DDRE<br>Bit | PTE<br>Bit | I/O Pin<br>Mode | Accesses<br>to DDRE | Accesse  | s to PTE                |  |
|-------------|------------|-----------------|---------------------|----------|-------------------------|--|
| Bit         | Dit        | Wode            | Read/Write          | Read     | Write                   |  |
| 0           | Х          | Input, Hi-Z     | DDRE[7:0]           | Pin      | PTE[7:0] <sup>(1)</sup> |  |
| 1           | Х          | Output          | DDRE[7:0]           | PTE[7:0] | PTE[7:0]                |  |

X = don't care

Hi-Z = high impedance

1. Writing affects data register, but does not affect input.

## 16.8 Port F

Port F is a 4-bit special function port that shares four of its pins with the timer interface module (TIM).

#### 16.8.1 Port F Data Register

The port F data register contains a data latch for each of the four port F pins.



PTF[3:0] — Port F Data Bits

These read/write bits are software programmable. Data direction of each port F pin is under the control of the corresponding bit in data direction register F. Reset has no effect on PTF[3:0].

TACLK — Timer A Clock Input Bit

The PTF3/TACLK pin is the external clock input for TIMA. The prescaler select bits, PS[2:0], select PTF3/TACLK as the TIMA clock input. (See **20.9.1 TIMA Status and Control Register**.) When not selected as the TIMA clock, PTF3/TACLK is available for general-purpose I/O.

TBCLK — Timer B Clock Input Bit

The PTF2/TBCLK pin is the external clock input for TIMB. The prescaler select bits, PS[2:0], select  $\overline{FLT}$  as the TIMB clock input. (See **21.9.1 TIMB Status and Control Register**.) When not selected as the TIMB clock, PTF2/TBCLK is available for general-purpose I/O.

#### TBCH[1:0] — Timer B Channel I/O Bits

The PTF1/TBCH1–PTF0/TBCH0 pins are the TIMB input capture/output compare pins. The edge/level select bits, ELSxB–ELSxA, determine whether the PTF1/TBCH1–PTF0/TBCH0 pins are timer channel I/O pins or general-purpose I/O pins. (See **21.9.1 TIMB Status and Control Register**.)

**NOTE:** Data direction register F (DDRF) does not affect the data direction of port F pins that are being used by the TIM. However, the DDRF bits always determine whether reading port F returns the states of the latches or the states of the pins. (See Table 16-6.)

#### 16.8.2 Data Direction Register F

Data direction register F determines whether each port F pin is an input or an output. Writing a logic 1 to a DDRF bit enables the output buffer for the corresponding port F pin; a logic 0 disables the output buffer.

\$000D Address: Bit 7 5 4 3 2 1 Bit 0 6 Read: 0 0 0 0 DDRF1 DDRF3 DDRF2 DDRF0 Write: R R R R 0 0 0 0 Reset: 0 0 0 0 R = Reserved

Figure 16-18. Data Direction Register F (DDRF)

DDRF[3:0] — Data Direction Register F Bits

These read/write bits control port F data direction. Reset clears DDRF[3:0], configuring all port F pins as inputs.

- 1 = Corresponding port F pin configured as output
- 0 = Corresponding port F pin configured as input
- **NOTE:** Avoid glitches on port F pins by writing to the port F data register before changing data direction register F bits from 0 to 1.

Figure 16-19 shows the port F I/O logic.



Figure 16-19. Port F I/O Circuit

When bit DDRFx is a logic 1, reading address \$0009 reads the PTFx data latch. When bit DDRFx is a logic 0, reading address \$0009 reads the voltage level on the pin. The data latch can always be written, regardless of the state of its data direction bit. **Table 16-6** summarizes the operation of the port F pins.

| Table 16 | -6. Port | F Pin | Functions |
|----------|----------|-------|-----------|
|----------|----------|-------|-----------|

| DDRF<br>Bit | PTF<br>Bit | I/O Pin<br>Mode | Accesses<br>to DDRF | Accesses to PTF |                         |  |
|-------------|------------|-----------------|---------------------|-----------------|-------------------------|--|
|             | Dit        | MODE            | Read/Write          | Read            | Write                   |  |
| 0           | Х          | Input, Hi-Z     | DDRF[3:0]           | Pin             | PTF[3:0] <sup>(1)</sup> |  |
| 1           | Х          | Output          | DDRF[3:0]           | PTF[3:0]        | PTF[3:0]                |  |

X = don't care

Hi-Z = high impedance

1. Writing affects data register, but does not affect input.

**Technical Data** 

# Section 17. Serial Communications Interface (SCI)

## 17.1 Contents

| 17.3       Features       .208         17.4       Functional Description       .209         17.4.1       Data Format       .212         17.4.2       Transmitter       .212         17.4.3       Character Length.       .212         17.4.4       Character Transmission       .212         17.4.5       Break Characters       .214 |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 17.4.1       Data Format       .212         17.4.2       Transmitter       .212         17.4.3       Character Length       .212         17.4.4       Character Transmission       .212                                                                                                                                               |
| 17.4.2Transmitter.21217.4.3Character Length21217.4.4Character Transmission.212                                                                                                                                                                                                                                                        |
| 17.4.3Character Length.21217.4.4Character Transmission212                                                                                                                                                                                                                                                                             |
| 17.4.4 Character Transmission                                                                                                                                                                                                                                                                                                         |
|                                                                                                                                                                                                                                                                                                                                       |
| 17.4.5 Break Characters                                                                                                                                                                                                                                                                                                               |
|                                                                                                                                                                                                                                                                                                                                       |
| 17.4.6 Idle Characters                                                                                                                                                                                                                                                                                                                |
| 17.4.7 Inversion of Transmitted Output                                                                                                                                                                                                                                                                                                |
| 17.4.8 Transmitter Interrupts                                                                                                                                                                                                                                                                                                         |
| 17.4.9 Receiver                                                                                                                                                                                                                                                                                                                       |
| 17.4.10 Character Length                                                                                                                                                                                                                                                                                                              |
| 17.4.11 Character Reception                                                                                                                                                                                                                                                                                                           |
| 17.4.12 Data Sampling                                                                                                                                                                                                                                                                                                                 |
| 17.4.13 Framing Errors                                                                                                                                                                                                                                                                                                                |
| 17.4.14 Receiver Wakeup                                                                                                                                                                                                                                                                                                               |
|                                                                                                                                                                                                                                                                                                                                       |
| 17.5 Receiver Interrupts                                                                                                                                                                                                                                                                                                              |
| 17.5.1 Error Interrupts                                                                                                                                                                                                                                                                                                               |
| 17.6 Low-Power Modes                                                                                                                                                                                                                                                                                                                  |
| 17.6.1 Wait Mode                                                                                                                                                                                                                                                                                                                      |
| 17.6.2 Stop Mode                                                                                                                                                                                                                                                                                                                      |
|                                                                                                                                                                                                                                                                                                                                       |
| 17.7 SCI During Break Module Interrupts                                                                                                                                                                                                                                                                                               |
| 17.8 I/O Signals                                                                                                                                                                                                                                                                                                                      |
| 17.8.1 PTE0/TxD (Transmit Data)                                                                                                                                                                                                                                                                                                       |
| 17.8.2 PTE1/RxD (Receive Data)                                                                                                                                                                                                                                                                                                        |

| 17.9   | I/O Registers              |
|--------|----------------------------|
| 17.9.1 | SCI Control Register 1     |
| 17.9.2 | SCI Control Register 2     |
| 17.9.3 | 3 SCI Control Register 323 |
| 17.9.4 | SCI Status Register 1      |
| 17.9.5 | 5 SCI Status Register 2    |
| 17.9.6 | SCI Data Register          |
| 17.9.7 | SCI Baud Rate Register238  |

## 17.2 Introduction

This section describes the serial communications interface module (SCI, version D), which allows high-speed asynchronous communications with peripheral devices and other MCUs.

### 17.3 Features

Features of the SCI module include:

- Full-duplex operation
- Standard mark/space non-return-to-zero (NRZ) format
- 32 programmable baud rates
- Programmable 8-bit or 9-bit character length
- Separately enabled transmitter and receiver
- Separate receiver and transmitter central processor unit (CPU) interrupt requests
- Programmable transmitter output polarity
- Two receiver wakeup methods:
  - Idle line wakeup
  - Address mark wakeup

- Interrupt-driven operation with eight interrupt flags:
  - Transmitter empty
  - Transmission complete
  - Receiver full
  - Idle receiver input
  - Receiver overrun
  - Noise error
  - Framing error
  - Parity error
- Receiver framing error detection
- Hardware parity checking
- 1/16 bit-time noise detection

#### **17.4 Functional Description**

**Figure 17-1** shows the structure of the SCI module. The SCI allows full-duplex, asynchronous, NRZ serial communication between the MCU and remote devices, including other MCUs. The transmitter and receiver of the SCI operate independently, although they use the same baud rate generator. During normal operation, the CPU monitors the status of the SCI, writes the data to be transmitted, and processes received data.

Refer to **Figure 17-2** for a summary of the input/output (I/O) registers.

## Serial Communications Interface (SCI)



Figure 17-1. SCI Module Block Diagram

| Addr.  | Register Name                           |                 | Bit 7 | 6          | 5     | 4          | 3          | 2    | 1    | Bit 0 |
|--------|-----------------------------------------|-----------------|-------|------------|-------|------------|------------|------|------|-------|
| \$0013 | SCI Control Register 1<br>(SCC1)        | Read:<br>Write: | LOOPS | ENSCI      | TXINV | М          | WAKE       | ILTY | PEN  | PTY   |
|        |                                         | Reset:          | 0     | 0          | 0     | 0          | 0          | 0    | 0    | 0     |
| \$0014 | SCI Control Register 2<br>(SCC2)        | Read:<br>Write: | SCTIE | TCIE       | SCRIE | ILIE       | TE         | RE   | RWU  | SBK   |
|        | · · ·                                   | Reset:          | 0     | 0          | 0     | 0          | 0          | 0    | 0    | 0     |
|        |                                         | Read:           | R8    | Т8         | R     | R          | ORIE       | NEIE | FEIE | PEIE  |
| \$0015 | SCI Control Register 3<br>(SCC3)        | Write:          | R     |            |       | IX.        |            |      |      |       |
|        | ( , , , , , , , , , , , , , , , , , , , | Reset:          | U     | U          | 0     | 0          | 0          | 0    | 0    | 0     |
|        |                                         | Read:           | SCTE  | тс         | SCRF  | IDLE       | OR         | NF   | FE   | PE    |
| \$0016 | SCI Status Register 1<br>(SCS1)         | Write:          | R     | R          | R     | R          | R          | R    | R    | R     |
|        | ( , , , , , , , , , , , , , , , , , , , | Reset:          | 1     | 1          | 0     | 0          | 0          | 0    | 0    | 0     |
|        |                                         | Read:           | 0     | 0          | 0     | 0          | 0          | 0    | BKF  | RPF   |
| \$0017 | SCI Status Register 2<br>(SCS2)         | Write:          | R     | R          | R     | R          | R          | R    | R    | R     |
|        | ( , , , , , , , , , , , , , , , , , , , | Reset:          | 0     | 0          | 0     | 0          | 0          | 0    | 0    | 0     |
|        |                                         | Read:           | R7    | R6         | R5    | R4         | R3         | R2   | R1   | R0    |
| \$0018 | SCI Data Register<br>(SCDR)             | Write:          | T7    | T6         | T5    | T4         | T3         | T2   | T1   | Т0    |
|        | ( ,                                     | Reset:          |       |            |       | Unaffected | d by reset |      |      |       |
| \$0019 | SCI Baud Rate Register<br>(SCBR)        | Read:<br>Write: | R     | R          | SCP1  | SCP0       | R          | SCR2 | SCR1 | SCR0  |
|        | · · · · · ·                             | Reset:          | 0     | 0          | 0     | 0          | 0          | 0    | 0    | 0     |
|        |                                         |                 | R     | ] = Reserv | red   |            | U = Unaffe | cted |      |       |

Figure 17-2. SCI I/O Register Summary

#### 17.4.1 Data Format

The SCI uses the standard non-return-to-zero (NRZ) mark/space data format illustrated in **Figure 17-3**.



Figure 17-3. SCI Data Formats

#### 17.4.2 Transmitter

Figure 17-4 shows the structure of the SCI transmitter.

#### 17.4.3 Character Length

The transmitter can accommodate either 8-bit or 9-bit data. The state of the M bit in SCI control register 1 (SCC1) determines character length. When transmitting 9-bit data, bit T8 in SCI control register 3 (SCC3) is the ninth bit (bit 8).

#### 17.4.4 Character Transmission

During an SCI transmission, the transmit shift register shifts a character out to the PTE0/TxD pin. The SCI data register (SCDR) is the write-only buffer between the internal data bus and the transmit shift register.

To initiate an SCI transmission:

- Initialize the Tx and Rx rates in the SCI baud register (SCBR) (\$0019). See 17.9.7 SCI Baud Rate Register.
- Enable the SCI by writing a logic 1 to ENSCI in SCI control register 1 (SCC1) (\$0013).



Figure 17-4. SCI Transmitter

- 3. Enable the transmitter by writing a logic 1 to the transmitter enable bit (TE) in SCI control register 2 (SCC2) (\$0014).
- Clear the SCI transmitter empty bit (SCTE) by first reading SCI status register (SCS1) (\$0016) and then writing to the SCDR (\$0018).
- 5. Repeat step 3 for each subsequent transmission.

At the start of a transmission, transmitter control logic automatically loads the transmit shift register with a preamble of 10 or 11 logic 1s. After the preamble shifts out, control logic transfers the SCDR data into the

transmit shift register. A logic 0 start bit automatically goes into the least significant bit (LSB) position of the transmit shift register. A logic 1 stop bit goes into the most significant bit (MSB) position.

The SCI transmitter empty bit, SCTE in the SCI status control register (SCS1), becomes set when the SCDR transfers a byte to the transmit shift register. The SCTE bit indicates that the SCDR can accept new data from the internal data bus. If the SCI transmit interrupt enable bit, SCTI E (SCC2), is also set, the SCTE bit generates a transmitter CPU interrupt request.

When the transmit shift register is not transmitting a character, the PTE0/TxD pin goes to the idle condition, logic 1. If at any time software clears the ENSCI bit in SCI control register 1 (SCC1), the transmitter and receiver relinquish control of the port E pins.

#### 17.4.5 Break Characters

Writing a logic 1 to the send break bit, SBK (SCC2), loads the transmit shift register with a break character. A break character contains all logic 0s and has no start, stop, or parity bit. Break character length depends on the M bit (SCC1). As long as SBK is at logic 1, transmitter logic continuously loads break characters into the transmit shift register. After software clears the SBK bit, the shift register finishes transmitting the last break character and then transmits at least one logic 1. The automatic logic 1 at the end of a break character guarantees the recognition of the start bit of the next character.

The SCI recognizes a break character when a start bit is followed by eight or nine logic 0 data bits and a logic 0 where the stop bit should be. Receiving a break character has the following effects on SCI registers:

- Sets the framing error bit (FE) in SCS1
- Sets the SCI receiver full bit (SCRF) in SCS1
- Clears the SCI data register (SCDR)
- Clears the R8 bit in SCC3
- Sets the break flag bit (BKF) in SCS2
- May set the overrun (OR), noise flag (NF), parity error (PE), or reception-in-progress flag (RPF) bits

#### 17.4.6 Idle Characters

An idle character contains all logic 1s and has no start, stop, or parity bit. Idle character length depends on the M bit (mode character length) in SCC1. The preamble is a synchronizing idle character that begins every transmission.

If the TE bit (transmitter enable) is cleared during a transmission, the PTE0/TxD pin becomes idle after completion of the transmission in progress. Clearing and then setting the TE bit during a transmission queues an idle character to be sent after the character currently being transmitted.

**NOTE:** When queueing an idle character, return the TE bit to logic 1 before the stop bit of the current character shifts out to the PTE0/TxD pin. Setting TE after the stop bit appears on PTE0/TxD causes data previously written to the SCDR to be lost.

A good time to toggle the TE bit is when the SCTE bit becomes set and just before writing the next byte to the SCDR.

#### 17.4.7 Inversion of Transmitted Output

The transmit inversion bit (TXINV) in SCI control register 1 (SCC1) reverses the polarity of transmitted data. All transmitted values, including idle, break, start, and stop bits, are inverted when TXINV is at logic 1. (See **17.9.1 SCI Control Register 1**.)

#### **17.4.8 Transmitter Interrupts**

These conditions can generate CPU interrupt requests from the SCI transmitter:

 SCI transmitter empty (SCTE) — The SCTE bit in SCS1 indicates that the SCDR has transferred a character to the transmit shift register. SCTE can generate a transmitter CPU interrupt request. Setting the SCI transmit interrupt enable bit, SCTIE (SCC2), enables the SCTE bit to generate transmitter CPU interrupt requests.

MC68HC08QA24

 Transmission complete (TC) — The TC bit in SCS1 indicates that the transmit shift register and the SCDR are empty and that no break or idle character has been generated. The transmission complete interrupt enable bit, TCIE (SCC2), enables the TC bit to generate transmitter CPU interrupt requests.

#### 17.4.9 Receiver

Figure 17-5 shows the structure of the SCI receiver.

#### 17.4.10 Character Length

The receiver can accommodate either 8-bit or 9-bit data. The state of the M bit in SCI control register 1 (SCC1) determines character length. When receiving 9-bit data, bit R8 in SCI control register 2 (SCC2) is the ninth bit (bit 8). When receiving 8-bit data, bit R8 is a copy of the eighth bit (bit 7).

#### 17.4.11 Character Reception

During an SCI reception, the receive shift register shifts characters in from the PTE1/RxD pin. The SCI data register (SCDR) is the read-only buffer between the internal data bus and the receive shift register.

After a complete character shifts into the receive shift register, the data portion of the character transfers to the SCDR. The SCI receiver full bit, SCRF, in SCI status register 1 (SCS1) becomes set, indicating that the received byte can be read. If the SCI receive interrupt enable bit, SCRIE (SCC2), is also set, the SCRF bit generates a receiver CPU interrupt request.


Figure 17-5. SCI Receiver Block Diagram

### 17.4.12 Data Sampling

The receiver samples the PTE1/RxD pin at the RT clock rate. The RT clock is an internal signal with a frequency 16 times the baud rate. To adjust for baud rate mismatch, the RT clock is resynchronized at these times (see Figure 17-6):

- After every start bit
- After the receiver detects a data bit change from logic 1 to logic 0 (after the majority of data bit samples at RT8, RT9, and RT10 returns a valid logic 1 and the majority of the next RT8, RT9, and RT10 samples returns a valid logic 0)

To locate the start bit, data recovery logic does an asynchronous search for a logic 0 preceded by three logic 1s. When the falling edge of a possible start bit occurs, the RT clock begins to count to 16.





To verify the start bit and to detect noise, data recovery logic takes samples at RT3, RT5, and RT7. **Table 17-1** summarizes the results of the start bit verification samples.

| RT3, RT5, and RT7<br>Samples | Start Bit<br>Verification | Noise Flag |
|------------------------------|---------------------------|------------|
| 000                          | Yes                       | 0          |
| 001                          | Yes                       | 1          |
| 010                          | Yes                       | 1          |
| 011                          | No                        | 0          |
| 100                          | Yes                       | 1          |
| 101                          | No                        | 0          |
| 110                          | No                        | 0          |
| 111                          | No                        | 0          |

 Table 17-1. Start Bit Verification

If start bit verification is not successful, the RT clock is reset and a new search for a start bit begins.

To determine the value of a data bit and to detect noise, recovery logic takes samples at RT8, RT9, and RT10. **Table 17-2** summarizes the results of the data bit samples.

| RT8, RT9, and RT10<br>Samples | Data Bit<br>Determination | Noise Flag |
|-------------------------------|---------------------------|------------|
| 000                           | 0                         | 0          |
| 001                           | 0                         | 1          |
| 010                           | 0                         | 1          |
| 011                           | 1                         | 1          |
| 100                           | 0                         | 1          |
| 101                           | 1                         | 1          |
| 110                           | 1                         | 1          |
| 111                           | 1                         | 0          |

Table 17-2. Data Bit Recovery

MC68HC08QA24

To verify a stop bit and to detect noise, recovery logic takes samples at RT8, RT9, and RT10. **Table 17-3** summarizes the results of the stop bit samples.

| RT8, RT9, and RT10<br>Samples | Framing<br>Error Flag | Noise Flag |
|-------------------------------|-----------------------|------------|
| 000                           | 1                     | 0          |
| 001                           | 1                     | 1          |
| 010                           | 1                     | 1          |
| 011                           | 0                     | 1          |
| 100                           | 1                     | 1          |
| 101                           | 0                     | 1          |
| 110                           | 0                     | 1          |
| 111                           | 0                     | 0          |

#### 17.4.13 Framing Errors

If the data recovery logic does not detect a logic 1 where the stop bit should be in an incoming character, it sets the framing error bit, FE, in SCS1. The FE flag is set at the same time that the SCRF bit (SCS1) is set. A break character that has no stop bit also sets the FE bit.

#### 17.4.14 Receiver Wakeup

So that the MCU can ignore transmissions intended only for other receivers in multiple-receiver systems, the receiver can be put into a standby state. Setting the receiver wakeup bit, RWU (SCC2), puts the receiver into a standby state during which receiver interrupts are disabled.

MC68HC08QA24

**NOTE:** The RT8, RT9, and RT10 samples do not affect start bit verification. If any or all of the RT8, RT9, and RT10 start bit samples are logic 1s following a successful start bit verification, the noise flag (NF) is set and the receiver assumes that the bit is a start bit.

Depending on the state of the WAKE bit in SCC1, either of two conditions on the PTE1/RxD pin can bring the receiver out of the standby state:

- Address mark An address mark is a logic 1 in the most significant bit position of a received character. When the WAKE bit is set, an address mark wakes the receiver from the standby state by clearing the RWU bit. The address mark also sets the SCI receiver full bit, SCRF. Software can then compare the character containing the address mark to the user-defined address of the receiver. If they are the same, the receiver remains awake and processes the characters that follow. If they are not the same, software can set the RWU bit and put the receiver back into the standby state.
- 2. Idle input line condition When the WAKE bit is clear, an idle character on the PTE1/RxD pin wakes the receiver from the standby state by clearing the RWU bit. The idle character that wakes the receiver does not set the receiver idle bit, IDLE, or the SCI receiver full bit, SCRF. The idle line type bit, ILTY, determines whether the receiver begins counting logic 1s as idle character bits after the start bit or after the stop bit.
- **NOTE:** Clearing the WAKE bit after the PTE1/RxD pin has been idle may cause the receiver to wake up immediately.

# **17.5 Receiver Interrupts**

These sources can generate CPU interrupt requests from the SCI receiver:

 SCI receiver full (SCRF) — The SCRF bit in SCS1 indicates that the receive shift register has transferred a character to the SCDR.
 SCRF can generate a receiver CPU interrupt request. Setting the SCI receive interrupt enable bit, SCRIE (SCC2), enables the SCRF bit to generate receiver CPU interrupts.

Idle input (IDLE) — The IDLE bit in SCS1 indicates that 10 or 11 consecutive logic 1s shifted in from the PTE1/RxD pin. The idle line interrupt enable bit, ILIE (SCC2), enables the IDLE bit to generate CPU interrupt requests.

# 17.5.1 Error Interrupts

These receiver error flags in SCS1 can generate CPU interrupt requests:

- Receiver overrun (OR) The OR bit indicates that the receive shift register shifted in a new character before the previous character was read from the SCDR. The previous character remains in the SCDR, and the new character is lost. The overrun interrupt enable bit, ORIE (SCC3), enables OR to generate SCI error CPU interrupt requests.
- Noise flag (NF) The NF bit is set when the SCI detects noise on incoming data or break characters, including start, data, and stop bits. The noise error interrupt enable bit, NEIE (SCC3), enables NF to generate SCI error CPU interrupt requests.
- Framing error (FE) The FE bit in SCS1 is set when a logic 0 occurs where the receiver expects a stop bit. The framing error interrupt enable bit, FEIE (SCC3), enables FE to generate SCI error CPU interrupt requests.
- Parity error (PE) The PE bit in SCS1 is set when the SCI detects a parity error in incoming data. The parity error interrupt enable bit, PEIE (SCC3), enables PE to generate SCI error CPU interrupt requests.

# **17.6 Low-Power Modes**

The WAIT and STOP instructions put the MCU in low powerconsumption standby modes.

### 17.6.1 Wait Mode

The SCI module remains active after the execution of a WAIT instruction. In wait mode, the SCI module registers are not accessible by the CPU. Any enabled CPU interrupt request from the SCI module can bring the MCU out of wait mode.

If SCI module functions are not required during wait mode, reduce power consumption by disabling the module before executing the WAIT instruction.

#### 17.6.2 Stop Mode

The SCI module is inactive after the execution of a STOP instruction. The STOP instruction does not affect SCI register states. SCI module operation resumes after an external interrupt.

Because the internal clock is inactive during stop mode, entering stop mode during an SCI transmission or reception results in invalid data.

# 17.7 SCI During Break Module Interrupts

The system integration module (SIM) controls whether status bits in other modules can be cleared during interrupts generated by the break module. The BCFE bit in the SIM break flag control register (SBFCR) enables software to clear status bits during the break state.

To allow software to clear status bits during a break interrupt, write a logic 1 to the BCFE bit. If a status bit is cleared during the break state, it remains cleared when the MCU exits the break state.

To protect status bits during the break state, write a logic 0 to the BCFE bit. With BCFE at logic 0 (its default state), software can read and write I/O registers during the break state without affecting status bits. Some status bits have a two-step read/write clearing procedure. If software does the first step on such a bit before the break, the bit cannot change during the break state as long as BCFE is at logic 0. After the break, doing the second step clears the status bit.

# 17.8 I/O Signals

Port E shares two of its pins with the SCI module. The two SCI I/O pins are:

- PTE0/TxD Transmit data
- PTE1/RxD Receive data

# 17.8.1 PTE0/TxD (Transmit Data)

The PTE0/TxD pin is the serial data output from the SCI transmitter. The SCI shares the PTE0/TxD pin with port E. When the SCI is enabled, the PTE0/TxD pin is an output regardless of the state of the DDRE2 bit in data direction register E (DDRE).

#### 17.8.2 PTE1/RxD (Receive Data)

The PTE1/RxD pin is the serial data input to the SCI receiver. The SCI shares the PTE1/RxD pin with port E. When the SCI is enabled, the PTE1/RxD pin is an input regardless of the state of the DDRE1 bit in data direction register E (DDRE).

# 17.9 I/O Registers

These I/O registers control and monitor SCI operation:

- SCI control register 1 (SCC1)
- SCI control register 2 (SCC2)
- SCI control register 3 (SCC3)
- SCI status register 1 (SCS1)
- SCI status register 2 (SCS2)
- SCI data register (SCDR)
- SCI baud rate register (SCBR)

# 17.9.1 SCI Control Register 1

SCI control register 1:

- Enables loop mode operation
- Enables the SCI
- Controls output polarity
- Controls character length
- Controls SCI wakeup method
- Controls idle character detection
- Enables parity function
- Controls parity type

Address: \$0013

|        | Bit 7  | 6     | 5     | 4   | 3    | 2    | 1   | Bit 0 |
|--------|--------|-------|-------|-----|------|------|-----|-------|
| Read:  | LOOPS  | ENSCI | TXINV | М   | WAKE | ILTY | PEN | PTY   |
| Write: | 2001 0 | ENOOI |       | IVI | WARE |      |     |       |
| Reset: | 0      | 0     | 0     | 0   | 0    | 0    | 0   | 0     |

Figure 17-7. SCI Control Register 1 (SCC1)

LOOPS - Loop Mode Select Bit

This read/write bit enables loop mode operation. In loop mode the PTE1/RxD pin is disconnected from the SCI, and the transmitter output goes into the receiver input. Both the transmitter and the receiver must be enabled to use loop mode. Reset clears the LOOPS bit.

1 = Loop mode enabled

0 = Normal operation enabled

ENSCI — Enable SCI Bit

This read/write bit enables the SCI and the SCI baud rate generator. Clearing ENSCI sets the SCTE and TC bits in SCI status register 1 and disables transmitter interrupts. Reset clears the ENSCI bit.

- 1 = SCI enabled
- 0 = SCI disabled

MOTOROLA

TXINV — Transmit Inversion Bit

This read/write bit reverses the polarity of transmitted data. Reset clears the TXINV bit.

- 1 = Transmitter output inverted
- 0 = Transmitter output not inverted
- **NOTE:** Setting the TXINV bit inverts all transmitted values, including idle, break, start, and stop bits.
  - M Mode (Character Length) Bit

This read/write bit determines whether SCI characters are eight or nine bits long. (See **Table 17-4**.) The ninth bit can serve as an extra stop bit, as a receiver wakeup signal, or as a parity bit. Reset clears the M bit.

1 = 9-bit SCI characters

- 0 = 8-bit SCI characters
- WAKE Wakeup Condition Bit

This read/write bit determines which condition wakes up the SCI: a logic 1 (address mark) in the most significant bit position of a received character or an idle condition on the PTE1/RxD pin. Reset clears the WAKE bit.

1 = Address mark wakeup

- 0 = Idle line wakeup
- ILTY Idle Line Type Bit

This read/write bit determines when the SCI starts counting logic 1s as idle character bits. The counting begins either after the start bit or after the stop bit. If the count begins after the start bit, then a string of logic 1s preceding the stop bit can cause false recognition of an idle character. Beginning the count after the stop bit avoids false idle character recognition, but requires properly synchronized transmissions. Reset clears the ILTY bit.

- 1 = Idle character bit count begins after stop bit
- 0 = Idle character bit count begins after start bit

PEN — Parity Enable Bit

This read/write bit enables the SCI parity function. (See **Table 17-4**.) When enabled, the parity function inserts a parity bit in the most significant bit position. (See **Figure 17-3**.) Reset clears the PEN bit.

1 = Parity function enabled

0 = Parity function disabled

# PTY — Parity Bit

This read/write bit determines whether the SCI generates and checks for odd parity or even parity. (See **Table 17-4**.) Reset clears the PTY bit.

- 1 = Odd parity
- 0 = Even parity
- **NOTE:** Changing the PTY bit in the middle of a transmission or reception can generate a parity error.

| 0 | Control Bits |               |              | Character Format |              |                     |  |
|---|--------------|---------------|--------------|------------------|--------------|---------------------|--|
| М | PEN:PTY      | Start<br>Bits | Data<br>Bits | Parity           | Stop<br>Bits | Character<br>Length |  |
| 0 | 0X           | 1             | 8            | None             | 1            | 10 bits             |  |
| 1 | 0X           | 1             | 9            | None             | 1            | 11 bits             |  |
| 0 | 10           | 1             | 7            | Even             | 1            | 10 bits             |  |
| 0 | 11           | 1             | 7            | Odd              | 1            | 10 bits             |  |
| 1 | 10           | 1             | 8            | Even             | 1            | 11 bits             |  |
| 1 | 11           | 1             | 8            | Odd              | 1            | 11 bits             |  |

Table 17-4. Character Format Selection

# 17.9.2 SCI Control Register 2

SCI control register 2:

- Enables the following CPU interrupt requests:
  - Enables the SCTE bit to generate transmitter CPU interrupt requests
  - Enables the TC bit to generate transmitter CPU interrupt requests
  - Enables the SCRF bit to generate receiver CPU interrupt requests
  - Enables the IDLE bit to generate receiver CPU interrupt requests
- Enables the transmitter
- Enables the receiver
- Enables SCI wakeup
- Transmits SCI break characters

Address: \$0014

|        | Bit 7 | 6    | 5     | 4    | 3   | 2  | 1   | Bit 0 |
|--------|-------|------|-------|------|-----|----|-----|-------|
| Read:  | SCTIE | TCIE | SCRIE | ILIE | TE  | RE | RWU | SBK   |
| Write: |       |      |       |      | . – |    |     |       |
| Reset: | 0     | 0    | 0     | 0    | 0   | 0  | 0   | 0     |

#### Figure 17-8. SCI Control Register 2 (SCC2)

SCTIE — SCI Transmit Interrupt Enable Bit

This read/write bit enables the SCTE bit to generate SCI transmitter CPU interrupt requests. Reset clears the SCTIE bit.

- 1 = SCTE enabled to generate CPU interrupt requests
- 0 = SCTE not enabled to generate CPU interrupt requests

TCIE — Transmission Complete Interrupt Enable Bit

This read/write bit enables the TC bit to generate SCI transmitter CPU interrupt requests. Reset clears the TCIE bit.

1 = TC enabled to generate CPU interrupt requests

0 = TC not enabled to generate CPU interrupt requests

### SCRIE — SCI Receive Interrupt Enable Bit

This read/write bit enables the SCRF bit to generate SCI receiver CPU interrupt requests. Reset clears the SCRIE bit.

- 1 = SCRF enabled to generate CPU interrupt requests
- 0 = SCRF not enabled to generate CPU interrupt requests
- ILIE Idle Line Interrupt Enable Bit

This read/write bit enables the IDLE bit to generate SCI receiver CPU interrupt requests. Reset clears the ILIE bit.

- 1 = IDLE enabled to generate CPU interrupt requests
- 0 = IDLE not enabled to generate CPU interrupt requests
- TE Transmitter Enable Bit

Setting this read/write bit begins the transmission by sending a preamble of 10 or 11 logic 1s from the transmit shift register to the PTE0/TxD pin. If software clears the TE bit, the transmitter completes any transmission in progress before the PTE0/TxD returns to the idle condition (logic 1). Clearing and then setting TE during a transmission queues an idle character to be sent after the character currently being transmitted. Reset clears the TE bit.

- 1 = Transmitter enabled
- 0 = Transmitter disabled
- **NOTE:** Writing to the TE bit is not allowed when the enable SCI bit (ENSCI) is clear. ENSCI is in SCI control register 1.
  - RE Receiver Enable Bit

Setting this read/write bit enables the receiver. Clearing the RE bit disables the receiver but does not affect receiver interrupt flag bits. Reset clears the RE bit.

- 1 = Receiver enabled
- 0 = Receiver disabled
- **NOTE:** Writing to the RE bit is not allowed when the enable SCI bit (ENSCI) is clear. ENSCI is in SCI control register 1.

# RWU — Receiver Wakeup Bit

This read/write bit puts the receiver in a standby state during which receiver interrupts are disabled. The WAKE bit in SCC1 determines whether an idle input or an address mark brings the receiver out of the standby state and clears the RWU bit. Reset clears the RWU bit.

- 1 = Standby state
- 0 = Normal operation
- SBK Send Break Bit

Setting and then clearing this read/write bit transmits a break character followed by a logic 1. The logic 1 after the break character guarantees recognition of a valid start bit. If SBK remains set, the transmitter continuously transmits break characters with no logic 1s between them. Reset clears the SBK bit.

- 1 = Transmit break characters
- 0 = No break characters transmitted
- **NOTE:** Do not toggle the SBK bit immediately after setting the SCTE bit because toggling SBK too early causes the SCI to send a break character instead of a preamble.

# 17.9.3 SCI Control Register 3

SCI control register 3:

- Stores the ninth SCI data bit received and the ninth SCI data bit to be transmitted
- Enables these interrupts:
  - Receiver overrun interrupts
  - Noise error interrupts
  - Framing error interrupts
  - Parity error interrupts

#### Address: \$0015





#### R8 — Received Bit 8

When the SCI is receiving 9-bit characters, R8 is the read-only ninth bit (bit 8) of the received character. R8 is received at the same time that the SCDR receives the other eight bits.

When the SCI is receiving 8-bit characters, R8 is a copy of the eighth bit (bit 7). Reset has no effect on the R8 bit.

#### T8 — Transmitted Bit 8

When the SCI is transmitting 9-bit characters, T8 is the read/write ninth bit (bit 8) of the transmitted character. T8 is loaded into the transmit shift register at the same time that the SCDR is loaded into the transmit shift register. Reset has no effect on the T8 bit.

ORIE — Receiver Overrun Interrupt Enable Bit

This read/write bit enables SCI error CPU interrupt requests generated by the receiver overrun bit, OR.

1 = SCI error CPU interrupt requests from OR bit enabled

0 = SCI error CPU interrupt requests from OR bit disabled

NEIE — Receiver Noise Error Interrupt Enable Bit

This read/write bit enables SCI error CPU interrupt requests generated by the noise error bit, NE. Reset clears NEIE.

1 = SCI error CPU interrupt requests from NE bit enabled

0 = SCI error CPU interrupt requests from NE bit disabled

FEIE — Receiver Framing Error Interrupt Enable Bit

This read/write bit enables SCI error CPU interrupt requests generated by the framing error bit, FE. Reset clears FEIE.

- 1 = SCI error CPU interrupt requests from FE bit enabled
- 0 = SCI error CPU interrupt requests from FE bit disabled

PEIE — Receiver Parity Error Interrupt Enable Bit

This read/write bit enables SCI receiver CPU interrupt requests generated by the parity error bit, PE. (See Figure 17-10.) Reset clears PEIE.

- 1 = SCI error CPU interrupt requests from PE bit enabled
- 0 = SCI error CPU interrupt requests from PE bit disabled

### 17.9.4 SCI Status Register 1

SCI status register 1 contains flags to signal the following conditions:

- Transfer of SCDR data to transmit shift register complete
- Transmission complete
- Transfer of receive shift register data to SCDR complete
- Receiver input idle
- Receiver overrun
- Noisy data
- Framing error
- Parity error

#### Address: \$0016

|        | Bit 7 | 6         | 5    | 4    | 3  | 2  | 1  | Bit 0 |
|--------|-------|-----------|------|------|----|----|----|-------|
| Read:  | SCTE  | TC        | SCRF | IDLE | OR | NF | FE | PE    |
| Write: | R     | R         | R    | R    | R  | R  | R  | R     |
| Reset: | 1     | 1         | 0    | 0    | 0  | 0  | 0  | 0     |
|        | R     | = Reserve | d    |      |    |    |    |       |

Figure 17-10. SCI Status Register 1 (SCS1)

SCTE — SCI Transmitter Empty Bit

This clearable, read-only bit is set when the SCDR transfers a character to the transmit shift register. SCTE can generate an SCI transmitter CPU interrupt request. When the SCTIE bit in SCC2 is set, SCTE generates an SCI transmitter CPU interrupt request. In normal operation, clear the SCTE bit by reading SCS1 with SCTE set and then writing to SCDR. Reset sets the SCTE bit.

1 = SCDR data transferred to transmit shift register

0 = SCDR data not transferred to transmit shift register

# **NOTE:** Setting the TE bit for the first time also sets the SCTE bit. Setting the TE and SCTIE bits generates an SCI transmitter CPU request.

MC68HC08QA24

# TC — Transmission Complete Bit

This read-only bit is set when the SCTE bit is set and no data, preamble, or break character is being transmitted. TC generates an SCI transmitter CPU interrupt request if the TCIE bit in SCC2 is also set. TC is cleared automatically when data, preamble, or break character is queued and ready to be sent. There may be up to 1.5 transmitter clocks of latency between queueing data, preamble, and break character and the transmission actually starting. Reset sets the TC bit.

1 = No transmission in progress

0 = Transmission in progress

SCRF — SCI Receiver Full Bit

This clearable, read-only bit is set when the data in the receive shift register transfers to the SCI data register. SCRF can generate an SCI receiver CPU interrupt request. In normal operation, clear the SCRF bit by reading SCS1 with SCRF set and then reading the SCDR. Reset clears SCRF.

1 = Received data available in SCDR

0 = Data not available in SCDR

# IDLE — Receiver Idle Bit

This clearable, read-only bit is set when 10 or 11 consecutive logic 1s appear on the receiver input. IDLE generates an SCI error CPU interrupt request if the ILIE bit in SCC2 is also set and the DMARE bit in SCC3 is clear. Clear the IDLE bit by reading SCS1 with IDLE set and then reading the SCDR. After the receiver is enabled, it must receive a valid character that sets the SCRF bit before an idle condition can set the IDLE bit. Also, after the IDLE bit has been cleared, a valid character must again set the SCRF bit before an idle condition can set the IDLE bit. Reset clears the IDLE bit.

1 = Receiver input idle

0 = Receiver input active (or idle since the IDLE bit was cleared)

# OR — Receiver Overrun Bit

This clearable, read-only bit is set when software fails to read the SCDR before the receive shift register receives the next character. The OR bit generates an SCI error CPU interrupt request if the ORIE bit in SCC3 is also set. The data in the shift register is lost, but the data already in the SCDR is not affected. Clear the OR bit by reading SCS1 with OR set and then reading the SCDR. Reset clears the OR bit.

- 1 = Receive shift register full and SCRF = 1
- 0 = No receiver overrun

Software latency may allow an overrun to occur between reads of SCS1 and SCDR in the flag-clearing sequence. **Figure 17-11** shows the normal flag-clearing sequence and an example of an overrun caused by a delayed flag-clearing sequence. The delayed read of SCDR does not clear the OR bit because OR was not set when SCS1 was read. Byte 2 caused the overrun and is lost. The next flag-clearing sequence reads byte 3 in the SCDR instead of byte 2.

In applications that are subject to software latency or in which it is important to know which byte is lost due to an overrun, the flag-clearing routine can check the OR bit in a second read of SCS1 after reading the data register.

NF — Receiver Noise Flag Bit

This clearable, read-only bit is set when the SCI detects noise on the PTE1/RxD pin. NF generates an NF CPU interrupt request if the NEIE bit in SCC3 is also set. Clear the NF bit by reading SCS1 and then reading the SCDR. Reset clears the NF bit.

- 1 = Noise detected
- 0 = No noise detected
- FE Receiver Framing Error Bit

This clearable, read-only bit is set when a logic 0 is accepted as the stop bit. FE generates an SCI error CPU interrupt request if the FEIE bit in SCC3 also is set. Clear the FE bit by reading SCS1 with FE set and then reading the SCDR. Reset clears the FE bit.

1 = Framing error detected

0 = No framing error detected

MOTOROLA

PE — Receiver Parity Error Bit

This clearable, read-only bit is set when the SCI detects a parity error in incoming data. PE generates a PE CPU interrupt request if the PEIE bit in SCC3 is also set. Clear the PE bit by reading SCS1 with PE set and then reading the SCDR. Reset clears the PE bit.

1 = Parity error detected

0 = No parity error detected



Figure 17-11. Flag Clearing Sequence

# 17.9.5 SCI Status Register 2

SCI status register 2 contains flags to signal two conditions:

- 1. Break character detected
- 2. Incoming data

Address: \$0017

|        | Bit 7 | 6         | 5 | 4 | 3     | 2 | 1   | Bit 0 |
|--------|-------|-----------|---|---|-------|---|-----|-------|
| Read:  | 0     | 0         | 0 | 0 | 0     | 0 | BKF | RPF   |
| Write: | R     | R         | R | R | R     | R | R   | R     |
| Reset: | 0     | 0         | 0 | 0 | 0     | 0 | 0   | 0     |
|        | R     | = Reserve | d |   |       |   |     |       |
|        |       |           |   | • | - • • |   |     |       |

Figure 17-12. SCI Status Register 2 (SCS2)

# BKF — Break Flag Bit

This clearable, read-only bit is set when the SCI detects a break character on the PTE1/RxD pin. In SCS1, the FE and SCRF bits are also set. In 9-bit character transmissions, the R8 bit in SCC3 is cleared. BKF does not generate a CPU interrupt request. Clear BKF by reading SCS2 with BKF set and then reading the SCDR. Once cleared, BKF can become set again only after logic 1s again appear on the PTE1/RxD pin followed by another break character. Reset clears the BKF bit.

1 = Break character detected

0 = No break character detected

RPF — Reception-in-Progress Flag Bit

This read-only bit is set when the receiver detects a logic 0 during the RT1 time period of the start bit search. RPF does not generate an interrupt request. RPF is reset after the receiver detects false start bits, usually from noise or a baud rate mismatch or when the receiver detects an idle character. Polling RPF before disabling the SCI module or entering stop mode can show whether a reception is in progress.

1 = Reception in progress

0 = No reception in progress

#### 17.9.6 SCI Data Register

The SCI data register is the buffer between the internal data bus and the receive and transmit shift registers. Reset has no effect on data in the SCI data register.

| Address:    | \$0018 |    |    |           |            |    |    |       |
|-------------|--------|----|----|-----------|------------|----|----|-------|
|             | Bit 7  | 6  | 5  | 4         | 3          | 2  | 1  | Bit 0 |
| Read:       | R7     | R6 | R5 | R4        | R3         | R2 | R1 | R0    |
| Write:      | T7     | T6 | T5 | T4        | Т3         | T2 | T1 | Т0    |
| -<br>Reset: |        |    |    | Unaffecte | d by reset |    |    |       |

Figure 17-13. SCI Data Register (SCDR)

R7/T7-R0/T0 — Receive/Transmit Data Bits

Reading address \$0018 accesses the read-only received data bits, R7–R0. Writing to address \$0018 writes the data to be transmitted, T7–T0. Reset has no effect on the SCI data register.

#### 17.9.7 SCI Baud Rate Register

The baud rate register selects the baud rate for both the receiver and the transmitter.



Figure 17-14. SCI BAUD Rate Register 1 (SCBR)

# SCP1 and SCP0 — SCI Baud Rate Prescaler Bits

These read/write bits select the baud rate prescaler divisor as shown in **Table 17-5**. Reset clears SCP1 and SCP0.

Table 17-5. SCI Baud Rate Prescaling

| SCP1:SCP0 | Prescaler Divisor (PD) |
|-----------|------------------------|
| 00        | 1                      |
| 01        | 3                      |
| 10        | 4                      |
| 11        | 13                     |

SCR2-SCR0 - SCI Baud Rate Select Bits

These read/write bits select the SCI baud rate divisor as shown in **Table 17-6**. Reset clears SCR2:SCR0.

 Table 17-6. SCI Baud Rate Selection

| SCR2:SCR1:SCR0 | Baud Rate Divisor (BD) |
|----------------|------------------------|
| 000            | 1                      |
| 001            | 2                      |
| 010            | 4                      |
| 011            | 8                      |
| 100            | 16                     |
| 101            | 32                     |
| 110            | 64                     |
| 111            | 128                    |

Use this formula to calculate the SCI baud rate:

Baud rate = 
$$\frac{CGMXCLK}{64 \times PD \times BD}$$

PD = Prescale divisor (see Table 17-5)

BD = Baud rate divisor (see Table 17-6)

Table 17-7 shows the SCI baud rates that can be generated with a4.194-MHz crystal.

| SCP1:SCP0 | Prescaler Divisor<br>(PD) | SCR2:SCR1:SCR0 | Baud Rate Divisor<br>(BD) | Baud Rate<br>(f <sub>XCLK</sub> = 4.194 MHz) |  |  |
|-----------|---------------------------|----------------|---------------------------|----------------------------------------------|--|--|
| 00        | 1                         | 000            | 1                         | 65,531                                       |  |  |
| 00        | 1                         | 001            | 2                         | 32,766                                       |  |  |
| 00        | 1                         | 010            | 4                         | 16,383                                       |  |  |
| 00        | 1                         | 011            | 8                         | 8191                                         |  |  |
| 00        | 1                         | 100            | 16                        | 4095                                         |  |  |
| 00        | 1                         | 101            | 32                        | 2048                                         |  |  |
| 00        | 1                         | 110            | 64                        | 1024                                         |  |  |
| 00        | 1                         | 111            | 128                       | 512                                          |  |  |
| 01        | 3                         | 000            | 1                         | 21,844                                       |  |  |
| 01        | 3                         | 001            | 2                         | 10,922                                       |  |  |
| 01        | 3                         | 010            | 4                         | 5461                                         |  |  |
| 01        | 3                         | 011            | 8                         | 2730                                         |  |  |
| 01        | 3                         | 100            | 16                        | 1365                                         |  |  |
| 01        | 3                         | 101            | 32                        | 683                                          |  |  |
| 01        | 3                         | 110            | 64                        | 341                                          |  |  |
| 01        | 3                         | 111            | 128                       | 171                                          |  |  |
| 10        | 4                         | 000            | 1                         | 16,383                                       |  |  |
| 10        | 4                         | 001            | 2                         | 8191                                         |  |  |
| 10        | 4                         | 010            | 4                         | 4096                                         |  |  |
| 10        | 4                         | 011            | 8                         | 2048                                         |  |  |
| 10        | 4                         | 100            | 16                        | 1024                                         |  |  |
| 10        | 4                         | 101            | 32                        | 512                                          |  |  |
| 10        | 4                         | 110            | 64                        | 256                                          |  |  |
| 10        | 4                         | 111            | 128                       | 128                                          |  |  |
| 11        | 13                        | 000            | 1                         | 5041                                         |  |  |
| 11        | 13                        | 001            | 2                         | 1664                                         |  |  |
| 11        | 13                        | 010            | 4                         | 1260                                         |  |  |
| 11        | 13                        | 011            | 8                         | 630                                          |  |  |
| 11        | 13                        | 100            | 16                        | 315                                          |  |  |
| 11        | 13                        | 101            | 32                        | 158                                          |  |  |
| 11        | 13                        | 110            | 64                        | 78.8                                         |  |  |
| 11        | 13                        | 111            | 128                       | 39.4                                         |  |  |

Table 17-7. SCI Baud Rate Selection Examples

# Section 18. Serial Peripheral Interface (SPI)

# **18.1 Contents**

| 18.2 Introduction                                                                                                                                          |
|------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 18.3 Features                                                                                                                                              |
| 18.4 Pin Name and Register Name Conventions                                                                                                                |
| 18.5       Functional Description       .244         18.5.1       Master Mode       .246         18.5.2       Slave Mode       .247                        |
| 18.6Transmission Formats                                                                                                                                   |
| 18.7       Error Conditions       .252         18.7.1       Overflow Error       .254         18.7.2       Mode Fault Error       .256                     |
| 18.8 Interrupts                                                                                                                                            |
| 18.9 Queuing Transmission Data                                                                                                                             |
| 18.10 Resetting the SPI                                                                                                                                    |
| 18.11 Low-Power Modes       .261         18.11.1 Wait Mode       .261         18.11.2 Stop Mode       .261                                                 |
| 18.12 SPI During Break Interrupts                                                                                                                          |
| 18.13       I/O Signals       .262         18.13.1       MISO (Master In/Slave Out)       .263         18.13.2       MOSI (Master Out/Slave In)       .263 |

MC68HC08QA24

| 18.13.3   | SPSCK (Serial Clock)            | .264 |
|-----------|---------------------------------|------|
| 18.13.4   | SS (Slave Select)               | .264 |
| 18.13.5   | V <sub>SS</sub> (Clock Ground)  | .265 |
| 18.14 I/C | Registers                       | .266 |
| 18.14.1   | SPI Control Register            | .266 |
| 18.14.2   | SPI Status and Control Register | .268 |
| 18.14.3   | SPI Data Register               | .272 |

# **18.2 Introduction**

This section describes the serial peripheral interface (SPI) module, which allows full-duplex, synchronous, serial communications with peripheral devices.

# **18.3 Features**

Features of the SPI module include:

- Full-duplex operation
- Master and slave modes
- Double-buffered operation with separate transmit and receive registers
- Four master mode frequencies (maximum = bus frequency ÷ 2)
- Maximum slave mode frequency = bus frequency
- Serial clock with programmable polarity and phase
- Two separately enabled interrupts with CPU service:
  - SPRF (SPI receiver full)
  - SPTE (SPI transmitter empty)
- Mode fault error flag with CPU interrupt capability
- Overflow error flag with CPU interrupt capability
- Programmable wired-OR mode
- I<sup>2</sup>C (inter-integrated circuit) compatibility

# **18.4 Pin Name and Register Name Conventions**

The generic names of the SPI input/output (I/O) pins are:

- SS (slave select)
- SPSCK (SPI serial clock)
- MOSI (master out/slave in)
- MISO (master in/slave out)

The SPI shares four I/O pins with a parallel I/O port. The full name of an SPI pin reflects the name of the shared port pin. **Table 18-1** shows the full names of the SPI I/O pins. The generic pin names appear in the text that follows.

#### Table 18-1. Pin Name Conventions

| SPI Generic Pin Name: | MISO      | MOSI      | SS      | SPSCK      |  |
|-----------------------|-----------|-----------|---------|------------|--|
| Full SPI pin name:    | PTE5/MISO | PTE6/MOSI | PTE4/SS | PTE7/SPSCK |  |

The generic names of the SPI I/O registers are:

- SPI control register (SPCR)
- SPI status and control register (SPSCR)
- SPI data register (SPDR)

Table 18-2 shows the names and the addresses of the SPI I/O registers.

#### Table 18-2. I/O Register Addresses

| Register Name                   | Address |  |  |
|---------------------------------|---------|--|--|
| SPI control register            | \$0010  |  |  |
| SPI status and control register | \$0011  |  |  |
| SPI data register               | \$0012  |  |  |

# **18.5 Functional Description**

**Figure 18-1** summarizes the SPI I/O registers and **Figure 18-2** shows the structure of the SPI module.

| Addr   | Register Name                              |                 | Bit 7 | 6        | 5      | 4         | 3           | 2      | 1    | Bit 0 |
|--------|--------------------------------------------|-----------------|-------|----------|--------|-----------|-------------|--------|------|-------|
| \$0010 | SPI Control Register<br>(SPCR)             | Read:<br>Write: | SPRIE | R        | SPMSTR | CPOL      | СРНА        | SPWOM  | SPE  | SPTIE |
|        |                                            | Reset:          | 0     | 0        | 1      | 0         | 0           | 0      | 0    | 0     |
| \$0011 | SPI Status and Control Register<br>(SPSCR) | Read:           | SPRF  | ERRIE    | OVRF   | MODF      | SPTE        | MODFEN | SPR1 | SPR0  |
|        |                                            | Write:          | R     |          | R      | R         | R           |        |      |       |
|        |                                            | Reset:          | 0     | 0        | 0      | 0         | 1           | 0      | 0    | 0     |
| \$0012 | SPI Data Register<br>(SPDR)                | Read:           | R7    | R6       | R5     | R4        | R3          | R2     | R1   | R0    |
|        |                                            | Write:          | T7    | T6       | T5     | T4        | T3          | T2     | T1   | T0    |
|        |                                            | Reset:          |       |          |        | Unaffecte | ed by reset |        |      |       |
|        |                                            |                 | R     | = Reserv | ed     |           |             |        |      |       |

Figure 18-1. SPI I/O Register Summary





The SPI module allows full-duplex, synchronous, serial communication between the MCU and peripheral devices, including other MCUs. Software can poll the SPI status flags or SPI operation can be interrupt-driven. All SPI interrupts can be serviced by the CPU.

The operation of the SPI module is described here.

#### 18.5.1 Master Mode

The SPI operates in master mode when the SPI master bit, SPMSTR (SPCR \$0010), is set.

**NOTE:** Configure the SPI modules as master and slave before enabling them. Enable the master SPI before enabling the slave SPI. Disable the slave SPI before disabling the master SPI. (See **18.14.1 SPI Control Register**.)

Only a master SPI module can initiate transmissions. Software begins the transmission from a master SPI module by writing to the SPI data register. If the shift register is empty, the byte immediately transfers to the shift register, setting the SPI transmitter empty bit, SPTE (SPSCR \$0011). The byte begins shifting out on the MOSI pin under the control of the serial clock. (See Figure 18-3.)

The SPR1 and SPR0 bits control the baud rate generator and determine the speed of the shift register. (See **18.14.2 SPI Status and Control Register**.) Through the SPSCK pin, the baud rate generator of the master also controls the shift register of the slave peripheral.



Figure 18-3. Full-Duplex Master-Slave Connections

As the byte shifts out on the MOSI pin of the master, another byte shifts in from the slave on the master's MISO pin. The transmission ends when the receiver full bit, SPRF (SPSCR), becomes set. At the same time that SPRF becomes set, the byte from the slave transfers to the receive data register. In normal operation, SPRF signals the end of a transmission. Software clears SPRF by reading the SPI status and control register and then reading the SPI data register. Writing to the SPI data register clears the SPTIE bit.

#### 18.5.2 Slave Mode

The SPI operates in slave mode when the SPMSTR bit (SPCR \$0010) is clear. In slave mode the SPSCK pin is the input for the serial clock from the master MCU. Before a data transmission occurs, the  $\overline{SS}$  pin of the slave MCU must be at logic 0.  $\overline{SS}$  must remain low until the transmission is complete. (See 18.7.2 Mode Fault Error.)

In a slave SPI module, data enters the shift register under the control of the serial clock from the master SPI module. After a byte enters the shift register of a slave SPI, it is transferred to the receive data register, and the SPRF bit (SPSCR) is set. To prevent an overflow condition, slave software then must read the SPI data register before another byte enters the shift register.

The maximum frequency of the SPSCK for an SPI configured as a slave is the bus clock speed, which is twice as fast as the fastest master SPSCK clock that can be generated. The frequency of the SPSCK for an SPI configured as a slave does not have to correspond to any SPI baud rate. The baud rate only controls the speed of the SPSCK generated by an SPI configured as a master. Therefore, the frequency of the SPSCK for an SPI configured as a slave can be any frequency less than or equal to the bus speed.

When the master SPI starts a transmission, the data in the slave shift register begins shifting out on the MISO pin. The slave can load its shift register with a new byte for the next transmission by writing to its transmit data register. The slave must write to its transmit data register at least one bus cycle before the master starts the next transmission. Otherwise, the byte already in the slave shift register shifts out on the MISO pin.

Data written to the slave shift register during a a transmission remains in a buffer until the end of the transmission.

When the clock phase bit (CPHA) is set, the first edge of SPSCK starts a transmission. When CPHA is clear, the falling edge of  $\overline{SS}$  starts a transmission. (See **18.6 Transmission Formats**.)

If the write to the data register is late, the SPI transmits the data already in the shift register from the previous transmission.

**NOTE:** To prevent SPSCK from appearing as a clock edge, SPSCK must be in the proper idle state before the slave is enabled.

# **18.6 Transmission Formats**

During an SPI transmission, data is simultaneously transmitted (shifted out serially) and received (shifted in serially). A serial clock line synchronizes shifting and sampling on the two serial data lines. A slave select line allows individual selection of a slave SPI device; slave devices that are not selected do not interfere with SPI bus activities. On a master SPI device, the slave select line can be used optionally to indicate a multiple-master bus contention.

# **18.6.1 Clock Phase and Polarity Controls**

Software can select any of four combinations of serial clock (SCK) phase and polarity using two bits in the SPI control register (SPCR). The clock polarity is specified by the CPOL control bit, which selects an active high or low clock and has no significant effect on the transmission format.

The clock phase (CPHA) control bit (SPCR) selects one of two fundamentally different transmission formats. The clock phase and polarity should be identical for the master SPI device and the communicating slave device. In some cases, the phase and polarity are changed between transmissions to allow a master device to communicate with peripheral slaves having different requirements.

**NOTE:** Before writing to the CPOL bit or the CPHA bit (SPCR), disable the SPI by clearing the SPI enable bit (SPE).

#### 18.6.2 Transmission Format When CPHA = 0

**Figure 18-4** shows an SPI transmission in which CPHA (SPCR) is logic 0. The figure should not be used as a replacement for data sheet parametric information.

Two waveforms are shown for SCK: one for CPOL = 0 and another for CPOL = 1. The diagram may be interpreted as a master or slave timing diagram since the serial clock (SCK), master in/slave out (MISO), and master out/slave in (MOSI) pins are directly connected between the master and the slave. The MISO signal is the output from the slave, and the MOSI signal is the output from the master. The  $\overline{SS}$  line is the slave select input to the slave. The slave SPI drives its MISO output only when its slave select input ( $\overline{SS}$ ) is at logic 0, so that only the selected slave drives to the master. The  $\overline{SS}$  pin of the master is not shown but is assumed to be inactive. The  $\overline{SS}$  pin of the master must be high or must be reconfigured as general-purpose I/O not affecting the SPI. (See **18.7.2 Mode Fault Error**.) When CPHA = 0, the first SPSCK edge is the MSB capture strobe. Therefore, the slave must begin driving its data before the first SPSCK edge, and a falling edge on the  $\overline{SS}$  pin is used to start the transmission. The  $\overline{SS}$  pin must be toggled high and then low again between each byte transmitted as shown in Figure 18-4.





MC68HC08QA24



Figure 18-5. CPHA/SS Timing

When CPHA = 0 for a slave, the falling edge of  $\overline{SS}$  indicates the beginning of the transmission. This causes the SPI to leave its idle state and begin driving the MISO pin with the MSB of its data. Once the transmission begins, no new data is allowed into the shift register from the transmit data register. Therefore, the SPI data register of the slave must be loaded with transmit data before the falling edge of  $\overline{SS}$ . Any data written after the falling edge is stored in the transmit data register and transferred to the shift register after the current transmission.

# 18.6.3 Transmission Format When CPHA = 1

**Figure 18-6** shows an SPI transmission in which CPHA (SPCR) is logic 1. The figure should not be used as a replacement for data sheet parametric information. Two waveforms are shown for SCK: one for CPOL = 0 and another for CPOL = 1. The diagram may be interpreted as a master or slave timing diagram since the serial clock (SCK), master in/slave out (MISO), and master out/slave in (MOSI) pins are directly connected between the master and the slave. The MISO signal is the output from the slave, and the MOSI signal is the output from the master. The  $\overline{SS}$  line is the slave select input to the slave. The slave SPI drives its MISO output only when its slave select input ( $\overline{SS}$ ) is at logic 0, so that only the selected slave drives to the master. The  $\overline{SS}$  pin of the master is not shown but is assumed to be inactive. The  $\overline{SS}$  pin of the master must be high or must be reconfigured as general-purpose I/O not affecting the SPI. (See 18.7.2 Mode Fault Error.) When CPHA = 1, the master

**Technical Data** 

MC68HC08QA24



Figure 18-6. Transmission Format (CPHA = 1)

begins driving its MOSI pin on the first SPSCK edge. Therefore, the slave uses the first SPSCK edge as a start transmission signal. The  $\overline{SS}$  pin can remain low between transmissions. This format may be preferable in systems having only one master and only one slave driving the MISO data line.

When CPHA = 1 for a slave, the first edge of the SPSCK indicates the beginning of the transmission. This causes the SPI to leave its idle state and begin driving the MISO pin with the MSB of its data. Once the transmission begins, no new data is allowed into the shift register from the transmit data register. Therefore, the SPI data register of the slave must be loaded with transmit data before the first edge of SPSCK. Any data written after the first edge is stored in the transmit data register and transferred to the shift register after the current transmission.

MC68HC08QA24

# **18.6.4 Transmission Initiation Latency**

When the SPI is configured as a master (SPMSTR = 1), transmissions are started by a software write to the SPDR (\$0012). CPHA has no effect on the delay to the start of the transmission, but it does affect the initial state of the SCK signal. When CPHA = 0, the SCK signal remains inactive for the first half of the first SCK cycle. When CPHA = 1, the first SCK cycle begins with an edge on the SCK line from its inactive to its active level. The SPI clock rate (selected by SPR1-SPR0) affects the delay from the write to SPDR and the start of the SPI transmission. (See Figure 18-7.) The internal SPI clock in the master is a free-running derivative of the internal MCU clock. It is only enabled when both the SPE and SPMSTR bits (SPCR) are set to conserve power. SCK edges occur halfway through the low time of the internal MCU clock. Since the SPI clock is free-running, it is uncertain where the write to the SPDR will occur relative to the slower SCK. This uncertainty causes the variation in the initiation delay shown in Figure 18-7. This delay will be no longer than a single SPI bit time. That is, the maximum delay between the write to SPDR and the start of the SPI transmission is two MCU bus cycles for DIV2, eight MCU bus cycles for DIV8, 32 MCU bus cycles for DIV32, and 128 MCU bus cycles for DIV128.

# **18.7 Error Conditions**

Two flags signal SPI error conditions:

- Overflow (OVRFin SPSCR) Failing to read the SPI data register before the next byte enters the shift register sets the OVRF bit. The new byte does not transfer to the receive data register, and the unread byte still can be read by accessing the SPI data register. OVRF is in the SPI status and control register.
- 2. Mode fault error (MODF in SPSCR) The MODF bit indicates that the voltage on the slave select pin  $(\overline{SS})$  is inconsistent with the mode of the SPI. MODF is in the SPI status and control register.


Figure 18-7. Transmission Start Delay (Master)

#### 18.7.1 Overflow Error

The overflow flag (OVRF in SPSCR) becomes set if the SPI receive data register still has unread data from a previous transmission when the capture strobe of bit 1 of the next transmission occurs. (See Figure 18-4 and Figure 18-6.) If an overflow occurs, the data being received is not transferred to the receive data register so that the unread data can still be read. Therefore, an overflow error always indicates the loss of data.

OVRF generates a receiver/error CPU interrupt request if the error interrupt enable bit (ERRIE in SPSCR) is also set. MODF and OVRF can generate a receiver/error CPU interrupt request. (See **Figure 18-10**.) It is not possible to enable only MODF or OVRF to generate a receiver/error CPU interrupt request. However, leaving MODFEN low prevents MODF from being set.

If an end-of-block transmission interrupt was meant to pull the MCU out of wait, having an overflow condition without overflow interrupts enabled causes the MCU to hang in wait mode. If the OVRF is enabled to generate an interrupt, it can pull the MCU out of wait mode instead.

If the CPU SPRF interrupt is enabled and the OVRF interrupt is not, watch for an overflow condition. **Figure 18-8** shows how it is possible to miss an overflow.



#### Figure 18-8. Missed Read of Overflow Condition

The first part of **Figure 18-8** shows how to read the SPSCR and SPDR to clear the SPRF without problems. However, as illustrated by the second transmission example, the OVRF flag can be set in between the time that SPSCR and SPDR are read.

In this case, an overflow can be easily missed. Since no more SPRF interrupts can be generated until this OVRF is serviced, it will not be obvious that bytes are being lost as more transmissions are completed. To prevent this, either enable the OVRF interrupt or do another read of the SPSCR after the read of the SPDR. This ensures that the OVRF was not set before the SPRF was cleared and that future transmissions will complete with an SPRF interrupt. **Figure 18-9** illustrates this process. Generally, to avoid this second SPSCR read, enable the OVRF to the CPU by setting the ERRIE bit (SPSCR).



Figure 18-9. Clearing SPRF When OVRF Interrupt Is Not Enabled

#### 18.7.2 Mode Fault Error

For the MODF flag (in SPSCR) to be set, the mode fault error enable bit (MODFEN in SPSCR) must be set. Clearing the MODFEN bit does not clear the MODF flag but does prevent MODF from being set again after MODF is cleared.

MODF generates a receiver/error CPU interrupt request if the error interrupt enable bit (ERRIE in SPSCR) is also set. The SPRF, MODF, and OVRF interrupts share the same CPU interrupt vector. MODF and OVRF can generate a receiver/error CPU interrupt request. (See Figure 18-10.) It is not possible to enable only MODF or OVRF to generate a receiver/error CPU interrupt request. However, leaving MODFEN low prevents MODF from being set.

In a master SPI with the mode fault enable bit (MODFEN) set, the mode fault flag (MODF) is set if  $\overline{SS}$  goes to logic 0. A mode fault in a master SPI causes these events to occur:

- If ERRIE = 1, the SPI generates an SPI receiver/error CPU interrupt request.
- The SPE bit is cleared.
- The SPTE bit is set.
- The SPI state counter is cleared.
- The data direction register of the shared I/O port regains control of port drivers.
- **NOTE:** To prevent bus contention with another master SPI after a mode fault error, clear all data direction register (DDR) bits associated with the SPI shared port pins.

Setting the MODF flag (SPSCR) does not clear the SPMSTR bit. Reading SPMSTR when MODF = 1 will indicate a MODE fault error occurred in either master mode or slave mode.

When configured as a slave (SPMSTR = 0), the MODF flag is set if  $\overline{SS}$  goes high during a transmission. When CPHA = 0, a transmission begins when  $\overline{SS}$  goes low and ends once the incoming SPSCK returns to its idle level after the shift of the eighth data bit. When CPHA = 1, the

transmission begins when the SPSCK leaves its idle level and  $\overline{SS}$  is already low. The transmission continues until the SPSCK returns to its IDLE level after the shift of the last data bit. (See **18.6 Transmission Formats**.)

**NOTE:** When CPHA = 0, a MODF occurs if a slave is selected ( $\overline{SS}$  is at logic 0) and later unselected ( $\overline{SS}$  is at logic 1) even if no SPSCK is sent to that slave. This happens because  $\overline{SS}$  at logic 0 indicates the start of the transmission (MISO driven out with the value of MSB) for CPHA = 0. When CPHA = 1, a slave can be selected and then later unselected with no transmission occurring. Therefore, MODF does not occur since a transmission was never begun.

In a slave SPI (MSTR = 0), the MODF bit generates an SPI receiver/error CPU interrupt request if the ERRIE bit is set. The MODF bit does not clear the SPE bit or reset the SPI in any way. Software can abort the SPI transmission by toggling the SPE bit of the slave.

**NOTE:** A logic 1 voltage on the SS pin of a slave SPI puts the MISO pin in a high impedance state. Also, the slave SPI ignores all incoming SPSCK clocks, even if a transmission has begun.

To clear the MODF flag, read the SPSCR and then write to the SPCR register. This entire clearing procedure must occur with no MODF condition existing or else the flag will not be cleared.

## **18.8 Interrupts**

The four SPI status flags shown in **Table 18-3** can be enabled to generate CPU interrupt requests:.

| Flag                     | Request                                                                    |
|--------------------------|----------------------------------------------------------------------------|
| SPTE (transmitter empty) | SPI transmitter CPU interrupt request (SPTIE = 1)                          |
| SPRF (receiver full)     | SPI receiver CPU interrupt request (SPRIE = 1)                             |
| OVRF (overflow)          | SPI receiver/error interrupt request (SPRIE = 1,<br>ERRIE = 1)             |
| MODF (mode fault)        | SPI receiver/error interrupt request (SPRIE = 1,<br>ERRIE = 1, MODFEN = 1) |

#### Table 18-3. SPI Interrupts

The SPI transmitter interrupt enable bit (SPTIE) enables the SPTE flag to generate transmitter CPU interrupt requests.

The SPI receiver interrupt enable bit (SPRIE) enables the SPRF bit to generate receiver CPU interrupt, provided that the SPI is enabled (SPE = 1).

The error interrupt enable bit (ERRIE) enables both the MODF and OVRF flags to generate a receiver/error CPU interrupt request.

The mode fault enable bit (MODFEN) can prevent the MODF flag from being set so that only the OVRF flag is enabled to generate receiver/error CPU interrupt requests.



Figure 18-10. SPI Interrupt Request Generation

Two sources in the SPI status and control register can generate CPU interrupt requests:

- SPI receiver full bit (SPRF) The SPRF bit becomes set every time a byte transfers from the shift register to the receive data register. If the SPI receiver interrupt enable bit, SPRIE, is also set, SPRF can generate an SPI receiver/error CPU interrupt request.
- SPI transmitter empty (SPTE) The SPTE bit becomes set every time a byte transfers from the transmit data register to the shift register. If the SPI transmit interrupt enable bit, SPTIE, is also set, SPTE can generate an SPTE CPU interrupt request.

**Technical Data** 

## **18.9 Queuing Transmission Data**

The double-buffered transmit data register allows a data byte to be queued and transmitted. For an SPI configured as a master, a queued data byte is transmitted immediately after the previous transmission has completed. The SPI transmitter empty flag (SPTE in SPSCR) indicates when the transmit data buffer is ready to accept new data. Write to the SPI data register only when the SPTE bit is high. **Figure 18-11** shows the timing associated with doing back-to-back transmissions with the SPI (SPSCK has CPHA–CPOL = 1-0).



## Figure 18-11. SPRF/SPTE CPU Interrupt Timing

The transmit data buffer allows back-to-back transmissions without the slave precisely timing its writes between transmissions as in a system with a single data buffer. Also, if no new data is written to the data buffer, the last value contained in the shift register is the next data word to be transmitted.

For an idle master or idle slave that has no data loaded into its transmit buffer, the SPTE is set again no more than two bus cycles after the transmit buffer empties into the shift register. This allows the user to queue up a 16-bit value to send. For an already active slave, the load of the shift register cannot occur until the transmission is completed. This implies that a back-to-back write to the transmit data register is not possible. The SPTE indicates when the next write can occur.

## 18.10 Resetting the SPI

Any system reset completely resets the SPI. Partial resets occur whenever the SPI enable bit (SPE) is low. Whenever SPE is low, these occur:

- The SPTE flag is set.
- Any transmission currently in progress is aborted.
- The shift register is cleared.
- The SPI state counter is cleared, making it ready for a new complete transmission.
- All the SPI port logic is defaulted back to being general-purpose I/O.

These additional items are reset only by a system reset:

- All control bits in the SPCR register
- All control bits in the SPSCR register (MODFEN, ERRIE, SPR1, and SPR0)
- The status flags SPRF, OVRF, and MODF

By not resetting the control bits when SPE is low, the user can clear SPE between transmissions without having to reset all control bits when SPE is set back to high for the next transmission.

By not resetting the SPRF, OVRF, and MODF flags, the user can still service these interrupts after the SPI has been disabled. The user can disable the SPI by writing 0 to the SPE bit. The SPI also can be disabled by a mode fault occurring in an SPI that was configured as a master with the MODFEN bit set.

## **18.11 Low-Power Modes**

The WAIT and STOP instructions put the MCU in low powerconsumption standby modes.

#### 18.11.1 Wait Mode

The SPI module remains active after the execution of a WAIT instruction. In wait mode, the SPI module registers are not accessible by the CPU. Any enabled CPU interrupt request from the SPI module can bring the MCU out of wait mode.

If SPI module functions are not required during wait mode, reduce power consumption by disabling the SPI module before executing the WAIT instruction.

To exit wait mode when an overflow condition occurs, enable the OVRF bit to generate CPU interrupt requests by setting the error interrupt enable bit (ERRIE). (See **18.8 Interrupts**.)

#### 18.11.2 Stop Mode

The SPI module is inactive after the execution of a STOP instruction. The STOP instruction does not affect register conditions. SPI operation resumes after the MCU exits stop mode. If stop mode is exited by reset, any transfer in progress is aborted and the SPI is reset.

## 18.12 SPI During Break Interrupts

The system integration module (SIM) controls whether status bits in other modules can be cleared during the break state. The BCFE bit in the SIM break flag control register (SBFCR, \$FE03) enables software to clear status bits during the break state. (See **10.8.3 SIM Break Flag Control Register**.)

To allow software to clear status bits during a break interrupt, write a logic 1 to the BCFE bit. If a status bit is cleared during the break state, it remains cleared when the MCU exits the break state.

To protect status bits during the break state, write a logic 0 to the BCFE bit. With BCFE at logic 0 (its default state), software can read and write I/O registers during the break state without affecting status bits. Some status bits have a 2-step read/write clearing procedure. If software does the first step on such a bit before the break, the bit cannot change during the break state as long as BCFE is at logic 0. After the break, doing the second step clears the status bit.

Since the SPTE bit cannot be cleared during a break with the BCFE bit cleared, a write to the data register in break mode will not initiate a transmission nor will this data be transferred into the shift register. Therefore, a write to the SPDR in break mode with the BCFE bit cleared has no effect.

## 18.13 I/O Signals

The SPI module has five I/O pins and shares four of them with a parallel I/O port:

- MISO Data received
- MOSI Data transmitted
- SPSCK Serial clock
- SS Slave select
- V<sub>SS</sub> Clock ground

#### **Technical Data**

The SPI has limited inter-integrated circuit (I<sup>2</sup>C) capability (requiring software support) as a master in a single-master environment. To communicate with I<sup>2</sup>C peripherals, MOSI becomes an open-drain output when the SPWOM bit in the SPI control register is set. In I<sup>2</sup>C communication, the MOSI and MISO pins are connected to a bidirectional pin from the I<sup>2</sup>C peripheral and through a pullup resistor to V<sub>DD</sub>.

## 18.13.1 MISO (Master In/Slave Out)

MISO is one of the two SPI module pins that transmit serial data. In full duplex operation, the MISO pin of the master SPI module is connected to the MISO pin of the slave SPI module. The master SPI simultaneously receives data on its MISO pin and transmits data from its MOSI pin.

Slave output data on the MISO pin is enabled only when the SPI is configured as a slave. The SPI is configured as a slave when its SPMSTR bit is logic 0 and its  $\overline{SS}$  pin is at logic 0. To support a multiple-slave system, a logic 1 on the  $\overline{SS}$  pin puts the MISO pin in a high-impedance state.

When enabled, the SPI controls data direction of the MISO pin regardless of the state of the data direction register of the shared I/O port.

#### 18.13.2 MOSI (Master Out/Slave In)

MOSI is one of the two SPI module pins that transmit serial data. In full duplex operation, the MOSI pin of the master SPI module is connected to the MOSI pin of the slave SPI module. The master SPI simultaneously transmits data from its MOSI pin and receives data on its MISO pin.

When enabled, the SPI controls data direction of the MOSI pin regardless of the state of the data direction register of the shared I/O port.

## 18.13.3 SPSCK (Serial Clock)

The serial clock synchronizes data transmission between master and slave devices. In a master MCU, the SPSCK pin is the clock output. In a slave MCU, the SPSCK pin is the clock input. In full duplex operation, the master and slave MCUs exchange a byte of data in eight serial clock cycles.

When enabled, the SPI controls data direction of the SPSCK pin regardless of the state of the data direction register of the shared I/O port.

## 18.13.4 SS (Slave Select)

The  $\overline{SS}$  pin has various functions depending on the current state of the SPI. For an SPI configured as a slave, the  $\overline{SS}$  is used to select a slave. For CPHA = 0, the  $\overline{SS}$  is used to define the start of a transmission. (See **18.6 Transmission Formats**.) Since it is used to indicate the start of a transmission, the  $\overline{SS}$  must be toggled high and low between each byte transmitted for the CPHA = 0 format. However, it can remain low throughout the transmission for the CPHA = 1 format. See **Figure 18-12**.



Figure 18-12. CPHA/SS Timing

When an SPI is configured as a slave, the  $\overline{SS}$  pin is always configured as an input. It cannot be used as a general-purpose I/O regardless of the state of the MODFEN control bit. However, the MODFEN bit can still prevent the state of the  $\overline{SS}$  from creating a MODF error. (See 18.14.2 SPI Status and Control Register.)

**NOTE:** A logic 1 voltage on the SS pin of a slave SPI puts the MISO pin in a high-impedance state. The slave SPI ignores all incoming SPSCK clocks, even if a transmission already has begun.

When an SPI is configured as a master, the  $\overline{SS}$  input can be used in conjunction with the MODF flag to prevent multiple masters from driving MOSI and SPSCK. (See **18.7.2 Mode Fault Error**.) For the state of the  $\overline{SS}$  pin to set the MODF flag, the MODFEN bit in the SPSCK register must be set. If the MODFEN bit is low for an SPI master, the  $\overline{SS}$  pin can be used as a general-purpose I/O under the control of the data direction register of the shared I/O port. With MODFEN high, it is an input-only pin to the SPI regardless of the state of the data direction register of the shared I/O port.

The CPU can always read the state of the  $\overline{SS}$  pin by configuring the appropriate pin as an input and reading the data register. (See **Table 18-4**.)

| SPE | SPMSTR | MODFEN | SPI Configuration   | State of SS Logic                         |
|-----|--------|--------|---------------------|-------------------------------------------|
| 0   | х      | х      | Not enabled         | General-purpose I/O;<br>SS ignored by SPI |
| 1   | 0      | Х      | Slave               | Input-only to SPI                         |
| 1   | 1      | 0      | Master without MODF | General-purpose I/O;<br>SS ignored by SPI |
| 1   | 1      | 1      | Master with MODF    | Input-only to SPI                         |

Table 18-4. SPI Configuration

X = don't care

## 18.13.5 V<sub>SS</sub> (Clock Ground)

 $V_{SS}$  is the ground return for the serial clock pin, SPSCK, and the ground for the port output buffers. To reduce the ground return path loop and minimize radio frequency (RF) emissions, connect the ground pin of the slave to the  $V_{SS}$  pin.

## 18.14 I/O Registers

Three registers control and monitor SPI operation:

- SPI control register (SPCR, \$0010)
- SPI status and control register (SPSCR, \$0011)
- SPI data register (SPDR, \$0012)

## 18.14.1 SPI Control Register

The SPI control register:

- Enables SPI module interrupt requests
- Selects CPU interrupt requests
- Configures the SPI module as master or slave
- Selects serial clock polarity and phase
- Configures the SPSCK, MOSI, and MISO pins as open-drain outputs
- Enables the SPI module





SPRIE — SPI Receiver Interrupt Enable Bit

This read/write bit enables CPU interrupt requests generated by the SPRF bit. The SPRF bit is set when a byte transfers from the shift register to the receive data register. Reset clears the SPRIE bit.

1 = SPRF CPU interrupt requests enabled

0 = SPRF CPU interrupt requests disabled

## SPMSTR — SPI Master Bit

This read/write bit selects master mode operation or slave mode operation. Reset sets the SPMSTR bit.

- 1 = Master mode
- 0 = Slave mode

## CPOL — Clock Polarity Bit

This read/write bit determines the logic state of the SPSCK pin between transmissions. (See **Figure 18-4** and **Figure 18-6**.) To transmit data between SPI modules, the SPI modules must have identical CPOL bits. Reset clears the CPOL bit.

## CPHA — Clock Phase Bit

This read/write bit controls the timing relationship between the serial clock and SPI data. (See Figure 18-4 and Figure 18-6.) To transmit data between SPI modules, the SPI modules must have identical CPHA bits. When CPHA = 0, the  $\overline{SS}$  pin of the slave SPI module must be set to logic 1 between bytes. (See Figure 18-12.) Reset sets the CPHA bit.

When CPHA = 0 for a slave, the falling edge of  $\overline{SS}$  indicates the beginning of the transmission. This causes the SPI to leave its idle state and begin driving the MISO pin with the MSB of its data. Once the transmission begins, no new data is allowed into the shift register from the data register. Therefore, the slave data register must be loaded with the desired transmit data before the falling edge of  $\overline{SS}$ . Any data written after the falling edge is stored in the data register and transferred to the shift register at the current transmission.

When CPHA = 1 for a slave, the first edge of the SPSCK indicates the beginning of the transmission. The same applies when  $\overline{SS}$  is high for a slave. The MISO pin is held in a high-impedance state, and the incoming SPSCK is ignored. In certain cases, it may also cause the MODF flag to be set. (See **18.7.2 Mode Fault Error**.) A logic 1 on the  $\overline{SS}$  pin does not in any way affect the state of the SPI state machine.

SPWOM - SPI Wired-OR Mode Bit

This read/write bit disables the pullup devices on pins SPSCK, MOSI, and MISO so that those pins become open-drain outputs.

- 1 = Wired-OR SPSCK, MOSI, and MISO pins
- 0 = Normal push-pull SPSCK, MOSI, and MISO pins

SPE — SPI Enable Bit

This read/write bit enables the SPI module. Clearing SPE causes a partial reset of the SPI. (See **18.10 Resetting the SPI**.) Reset clears the SPE bit.

1 = SPI module enabled

0 = SPI module disabled

SPTIE— SPI Transmit Interrupt Enable Bit

This read/write bit enables CPU interrupt requests generated by the SPTE bit. SPTE is set when a byte transfers from the transmit data register to the shift register. Reset clears the SPTIE bit.

1 = SPTE CPU interrupt requests enabled

0 = SPTE CPU interrupt requests disabled

#### 18.14.2 SPI Status and Control Register

The SPI status and control register contains flags to signal these conditions:

- Receive data register full
- Failure to clear SPRF bit before next byte is received (overflow error)
- Inconsistent logic level on <del>SS</del> pin (mode fault error)
- Transmit data register empty

The SPI status and control register also contains bits that perform these functions:

- Enable error interrupts
- Enable mode fault error detection
- Select master SPI baud rate

Address: \$0011

|        | Bit 7 | 6          | 5    | 4    | 3    | 2      | 1    | Bit 0 |  |  |  |
|--------|-------|------------|------|------|------|--------|------|-------|--|--|--|
| Read:  | SPRF  | ERRIE      | OVRF | MODF | SPTE | MODFEN | SPR1 | SPR0  |  |  |  |
| Write: | R     |            | R    | R    | R    |        | JENT |       |  |  |  |
| Reset: | 0     | 0          | 0    | 0    | 1    | 0      | 0    | 0     |  |  |  |
|        | R     | = Reserved |      |      |      |        |      |       |  |  |  |



## SPRF — SPI Receiver Full Bit

This clearable, read-only flag is set each time a byte transfers from the shift register to the receive data register. SPRF generates a CPU interrupt request if the SPRIE bit in the SPI control register is set also.

During an SPRF CPU interrupt, the CPU clears SPRF by reading the SPI status and control register with SPRF set and then reading the SPI data register. Any read of the SPI data register clears the SPRF bit.

Reset clears the SPRF bit.

1 = Receive data register full

0 = Receive data register not full

ERRIE — Error Interrupt Enable Bit

This bit enables the MODF and OVRF flags to generate CPU interrupt requests. Reset clears the ERRIE bit.

- 1 = MODF and OVRF can generate CPU interrupt requests
- 0 = MODF and OVRF cannot generate CPU interrupt requests

OVRF — Overflow Bit

This clearable, read-only flag is set if software does not read the byte in the receive data register before the next byte enters the shift register. In an overflow condition, the byte already in the receive data register is unaffected, and the byte that shifted in last is lost. Clear the OVRF bit by reading the SPI status and control register with OVRF set and then reading the SPI data register. Reset clears the OVRF flag.

- 1 = Overflow
- 0 = No overflow

MODF — Mode Fault Bit

This clearable, ready-only flag is set in a slave SPI if the  $\overline{SS}$  pin goes high during a transmission. In a master SPI, the MODF flag is set if the  $\overline{SS}$  pin goes low at any time. Clear the MODF bit by reading the SPI status and control register with MODF set and then writing to the SPI status and control register. Reset clears the MODF bit.

 $1 = \overline{SS}$  pin at inappropriate logic level

 $0 = \overline{SS}$  pin at appropriate logic level

SPTE — SPI Transmitter Empty Bit

This clearable, read-only flag is set each time the transmit data register transfers a byte into the shift register. SPTE generates an SPTE CPU interrupt request if the SPTIE bit in the SPI control register is set also.

**NOTE:** Do not write to the SPI data register unless the SPTE bit is high.

For an idle master or idle slave that has no data loaded into its transmit buffer, the SPTE will be set again within two bus cycles since the transmit buffer empties into the shift register. This allows the user to queue up a 16-bit value to send. For an already active slave, the load of the shift register cannot occur until the transmission is completed. This implies that a back-to-back write to the transmit data register is not possible. The SPTE indicates when the next write can occur.

Reset sets the SPTE bit.

1 = Transmit data register empty

0 = Transmit data register not empty

MODFEN — Mode Fault Enable Bit

This read/write bit, when set to 1, allows the MODF flag to be set. If the MODF flag is set, clearing the MODFEN does not clear the MODF flag. If the SPI is enabled as a master and the MODFEN bit is low, then the  $\overline{SS}$  pin is available as a general-purpose I/O.

If the MODFEN bit is set, then this pin is not available as a general-purpose I/O. When the SPI is enabled as a slave, the  $\overline{SS}$  pin is not available as a general-purpose I/O regardless of the value of MODFEN. (See **18.13.4 SS (Slave Select)**.)

If the MODFEN bit is low, the level of the SS pin does not affect the operation of an enabled SPI configured as a master. For an enabled SPI configured as a slave, having MODFEN low only prevents the MODF flag from being set. It does not affect any other part of SPI operation. (See **18.7.2 Mode Fault Error**.)

SPR1 and SPR0 — SPI Baud Rate Select Bits

In master mode, these read/write bits select one of four baud rates as shown in **Table 18-5**. SPR1 and SPR0 have no effect in slave mode. Reset clears SPR1 and SPR0.

| SPR1:SPR0 | Baud Rate Divisor (BD) |
|-----------|------------------------|
| 00        | 2                      |
| 01        | 8                      |
| 10        | 32                     |
| 11        | 128                    |

Table 18-5. SPI Master Baud Rate Selection

Use the following formula to calculate the SPI baud rate:

Baud rate = 
$$\frac{CGMOUT}{2 \times BD}$$

where:

CGMOUT = base clock output of the clock generator module (CGM), see **Section 9. Clock Generator Module (CGM)**.

BD = baud rate divisor

#### 18.14.3 SPI Data Register

The SPI data register is the read/write buffer for the receive data register and the transmit data register. Writing to the SPI data register writes data into the transmit data register. Reading the SPI data register reads data from the receive data register. The transmit data and receive data registers are separate buffers that can contain different values. See Figure 18-2.

| Address: | \$0012 |                           |    |    |    |    |    |       |  |  |  |  |  |  |
|----------|--------|---------------------------|----|----|----|----|----|-------|--|--|--|--|--|--|
|          | Bit 7  | 6                         | 5  | 4  | 3  | 2  | 1  | Bit 0 |  |  |  |  |  |  |
| Read:    | R7     | R6                        | R5 | R4 | R3 | R2 | R1 | R0    |  |  |  |  |  |  |
| Write:   | T7     | T6                        | T5 | T4 | Т3 | T2 | T1 | T0    |  |  |  |  |  |  |
| Reset:   |        | Indeterminate after reset |    |    |    |    |    |       |  |  |  |  |  |  |

Figure 18-15. SPI Data Register (SPDR)

R7-R0/T7-T0 - Receive/Transmit Data Bits

**NOTE:** Do not use read-modify-write instructions on the SPI data register since the buffer read is not the same as the buffer written.

# Section 19. Analog-to-Digital Converter (ADC)

## **19.1 Contents**

| 19.2 Introduction                                                        | 274 |
|--------------------------------------------------------------------------|-----|
| 19.3 Features                                                            | 274 |
| 19.4 Functional Description2                                             | 274 |
| 19.4.1 ADC Port I/O Pins                                                 | 274 |
| 19.4.2 Voltage Conversion                                                | 276 |
| 19.4.3 Conversion Time                                                   | 276 |
| 19.4.4 Continuous Conversion                                             | 276 |
| 19.4.5 Accuracy and Precision2                                           | 277 |
| 19.5 Interrupts                                                          | 277 |
| 19.6 Low-Power Modes                                                     | 277 |
| 19.6.1 Wait Mode                                                         | 277 |
| 19.6.2 Stop Mode                                                         | 277 |
| 19.7 I/O Signals                                                         | 278 |
| 19.7.1 ADC Analog Power Pin (V <sub>DDA</sub> /V <sub>DDAREF</sub> )/ADC |     |
| Voltage Reference Pin (V <sub>REFH</sub> )                               | 278 |
| 19.7.2 ADC Analog Ground Pin (V <sub>SSA</sub> )/ADC                     |     |
| Voltage Reference Low Pin (V <sub>REFL</sub> )                           |     |
| 19.7.3 ADC Voltage In (ADCVIN)                                           | 278 |
| 19.8 I/O Registers                                                       | 279 |
| 19.8.1 ADC Status and Control Register                                   | 279 |
| 19.8.2 ADC Data Register                                                 | 282 |
| 19.8.3 ADC Input Clock Register                                          | 282 |

## **19.2 Introduction**

This section describes the 8-bit analog-to-digital converter (ADC).

## **19.3 Features**

Features of the ADC module include:

- 12 channels (52-PLCC) with multiplexed input
- Linear successive approximation
- 8-bit resolution
- Single or continuous conversion
- Conversion complete flag or conversion complete interrupt
- Selectable ADC clock

## **19.4 Functional Description**

Twelve ADC channels are available for sampling external sources at pins PTD3/ATD11–PTD0/ATD8 and PTB7/ATD7–PTB0/ATD0. An analog multiplexer allows the single ADC converter to select one of the 12 ADC channels as ADC voltage input (ADCVIN). ADCVIN is converted by the successive approximation register-based counters. When the conversion is completed, ADC places the result in the ADC data register and sets a flag or generates an interrupt. (See Figure 19-1.)

#### 19.4.1 ADC Port I/O Pins

PTD3/ATD11–PTD0/ATD8 and PTB7/ATD7–PTB0/ATD0 are general-purpose input/output (I/O) pins that are shared with the ADC channels.

The channel select bits (ADC status control register, \$0038), define which ADC channel/port pin will be used as the input signal. The ADC overrides the port I/O logic by forcing that pin as input to the ADC.

#### **Technical Data**



Figure 19-1. ADC Block Diagram

The remaining ADC channels/port pins are controlled by the port I/O logic and can be used as general-purpose I/O. Writes to the port register or DDR will not have any affect on the port pin that is selected by the ADC. Read of a port pin which is in use by the ADC will return a logic 0 if the corresponding DDR bit is at logic 0. If the DDR bit is at logic 1, the value in the port data latch is read.

## 19.4.2 Voltage Conversion

When the input voltage to the ADC equals  $V_{REFH}$  (see 23.7 ADC Characteristics), the ADC converts the signal to \$FF (full scale). If the input voltage equals  $V_{SSA}/V_{REFL}$ , the ADC converts it to \$00. Input voltages between  $V_{REFH}$  and  $V_{SSA}/V_{REFL}$  are a straight-line linear conversion. All other input voltages will result in \$FF if greater than  $V_{REFH}$  and \$00 if less than  $V_{SSA}/V_{REFL}$ .

**NOTE:** Input voltage should not exceed the analog supply voltages.

## 19.4.3 Conversion Time

Sixteen ADC internal clocks are required to perform one conversion. The ADC starts a conversion on the first rising edge of the ADC internal clock immediately following a write to the ADSCR. If the ADC internal clock is selected to run at 1 MHz, then one conversion will take 16  $\mu$ s to complete. But since the ADC can run almost completely asynchronously to the bus clock, (for example, the ADC is configured to derive its internal clock from CGMXCLK and the bus clock is being derived from the PLL within the CGM [CGMOUT]), this 16  $\mu$ s conversion can take up to 17  $\mu$ s to complete. This worst-case could occur if the write to the ADSCR happened directly after the rising edge of the ADC internal clock. With a 1-MHz ADC internal clock the maximum sample rate is 59 kHz to 62 kHz. Refer to **23.7 ADC Characteristics** 

Conversion Time =  $\frac{16 \text{ to } 17 \text{ ADC clock cycles}}{\text{ADC clock frequency}}$ 

Number of bus cycles = Conversion time x bus frequency

#### **19.4.4 Continuous Conversion**

In the continuous conversion mode, the ADC continuously converts the selected channel filling the ADC data register with new data after each conversion. Data from the previous conversion will be overwritten whether that data has been read or not. Conversions will continue until

**Technical Data** 

the ADCO bit is cleared. The COCO bit (ADC status control register, \$0038) is set after each conversion and can be cleared by writing the ADC status and control register or reading of the ADC data register.

#### **19.4.5 Accuracy and Precision**

The conversion process is monotonic and has no missing codes. See **23.7 ADC Characteristics** for accuracy information.

## **19.5 Interrupts**

When the AIEN bit is set, the ADC module is capable of generating a CPU interrupt after each ADC conversion. A CPU interrupt is generated if the COCO bit is at logic 0. The COCO bit is not used as a conversion complete flag when interrupts are enabled.

## **19.6 Low-Power Modes**

This section describes the low-power modes.

#### 19.6.1 Wait Mode

The ADC continues normal operation during wait mode. Any enabled CPU interrupt request from the ADC can bring the MCU out of wait mode. If the ADC is not required to bring the MCU out of wait mode, power down the ADC by setting the ADCH[4:0] bits in the ADC status and control register to logic 1s before executing the WAIT instruction.

#### 19.6.2 Stop Mode

The ADC module is inactive after the execution of a STOP instruction. Any pending conversion is aborted. ADC conversions resume when the MCU exits stop mode. Allow one conversion cycle to stabilize the analog circuitry before attempting a new ADC conversion after exiting stop mode.

MC68HC08QA24

## 19.7 I/O Signals

The ADC module has 12 channels that are shared with I/O port B and port D. Refer to **23.7 ADC Characteristics** for voltages referenced in the next three subsections.

## 19.7.1 ADC Analog Power Pin (V<sub>DDA</sub>/V<sub>DDAREF</sub>)/ADC Voltage Reference Pin (V<sub>REFH</sub>)

The ADC analog portion uses  $V_{DDA}/V_{DDAREF}$  as its power pin. Connect the  $V_{DDA}/V_{DDAREF}$  pin to the same voltage potential as  $V_{DD}$ . External filtering may be necessary to ensure clean  $V_{DDA}/V_{DDAREF}$  for good results.

 $V_{REFH}$  is the high reference voltage for all analog-to-digital conversions. Connect the  $V_{REFH}$  pin to a voltage potential between 1.5 volts and  $V_{DDAREF}/V_{DDA}$  depending on the desired upper conversion boundary.

**NOTE:** Route  $V_{DDA}/V_{DDAREF}$  carefully for maximum noise immunity and place bypass capacitors as close as possible to the package.

## 19.7.2 ADC Analog Ground Pin (V<sub>SSA</sub>)/ADC Voltage Reference Low Pin (V<sub>REFL</sub>)

The ADC analog portion uses  $V_{SSA}$  as its ground pin. Connect the  $V_{SSA}$  pin to the same voltage potential as  $V_{SS}$ .

 $V_{REFL}$  is the lower reference supply for the ADC. Connect the  $V_{REFL}$  pin to a voltage potential between  $V_{SSA}$  and 0.5 volts depending on the desired lower conversion boundary.

**NOTE:** In a 52-pin package V<sub>SSA</sub> and V<sub>REFL</sub> are bonded together.

## 19.7.3 ADC Voltage In (ADCVIN)

ADCVIN is the input voltage signal from one of the 12 ADC channels to the ADC module.

## 19.8 I/O Registers

These I/O registers control and monitor ADC operation:

- ADC status and control register (ADSCR)
- ADC data register (ADR)
- ADC clock register (ADICLK)

## **19.8.1 ADC Status and Control Register**

These paragraphs describe the function of the ADC status and control register.

Address: \$0038

|        | Bit 7 | 6         | 5          | 4      | 3      | 2     | 1      | Bit 0  |  |  |  |  |  |
|--------|-------|-----------|------------|--------|--------|-------|--------|--------|--|--|--|--|--|
| Read:  | 0000  | AIEN      | ADCO       | ADCH4  | ADCH3  | ADCH2 | ADCH1  | ADCH0  |  |  |  |  |  |
| Write: | R     |           | ADCO       | ADCI14 | ADCI15 | ADCHZ | ADCITI | ADCITO |  |  |  |  |  |
| Reset: | 0     | 0         | 0          | 1      | 1      | 1     | 1      | 1      |  |  |  |  |  |
|        | R     | = Reserve | = Reserved |        |        |       |        |        |  |  |  |  |  |



COCO — Conversions Complete Bit

When the AIEN bit is a logic 0, the COCO is a read-only bit which is set each time a conversion is completed. This bit is cleared whenever the ADC status and control register is written or whenever the ADC data register is read. Reset clears this bit.

1 = Conversion completed (AIEN = 0)

0 =Conversion not completed (AIEN = 0)

or

0 = CPU interrupt enabled (AIEN = 1)

AIEN — ADC Interrupt Enable Bit

When this bit is set, an interrupt is generated at the end of an ADC conversion. The interrupt signal is cleared when the data register is read or the status/control register is written. Reset clears the AIEN bit.

- 1 = ADC interrupt enabled
- 0 = ADC interrupt disabled

MOTOROLA

ADCO — ADC Continuous Conversion Bit

When set, the ADC will convert samples continuously and update the ADR register at the end of each conversion. Only one conversion is allowed when this bit is cleared. Reset clears the ADCO bit.

1 = Continuous ADC conversion

0 = One ADC conversion

ADCH[4:0] — ADC Channel Select Bits

ADCH4, ADCH3, ADCH2, ADCH1, and ADCH0 form a 5-bit field which is used to select one of the ADC channels. The five channel select bits are detailed in **Table 19-1**.

**NOTE:** Care should be taken when using a port pin as both an analog and a digital input simultaneously to prevent switching noise from corrupting the analog signal.

The ADC subsystem is turned off when the channel select bits are all set to 1. This feature allows for reduced power consumption for the MCU when the ADC is not used. Reset sets all of these bits to a logic 1.

**NOTE:** Recovery from the disabled state requires one conversion cycle to stabilize.

| ADCH4 | ADCH3      | ADCH2          | ADCH1       | ADCH0 | Input Select                                        |
|-------|------------|----------------|-------------|-------|-----------------------------------------------------|
| 0     | 0          | 0              | 0           | 0     | PTB0/ATD0                                           |
| 0     | 0          | 0              | 0           | 1     | PTB1/ATD1                                           |
| 0     | 0          | 0              | 1           | 0     | PTB2/ATD2                                           |
| 0     | 0          | 0              | 1           | 1     | PTB3/ATD3                                           |
| 0     | 0          | 1              | 0           | 0     | PTB4/ATD4                                           |
| 0     | 0          | 1              | 0           | 1     | PTB5/ATD5                                           |
| 0     | 0          | 1              | 1           | 0     | PTB6/ATD6                                           |
| 0     | 0          | 1              | 1           | 1     | PTB7/ATD7                                           |
| 0     | 1          | 0              | 0           | 0     | PTD0/ATD8                                           |
| 0     | 1          | 0              | 0           | 1     | PTD1/ATD9                                           |
| 0     | 1          | 0              | 1           | 0     | PTD2/ATD10                                          |
| 0     | 1          | 0              | 1           | 1     | PTD3/ATD11                                          |
|       | Range 0110 | 00 (\$0C) to 1 | 1010 (\$1A) |       | Unused (see Note 1)                                 |
| 1     | 1          | 0              | 1           | 1     | Reserved                                            |
| 1     | 1          | 1              | 0           | 0     | Reserved                                            |
| 1     | 1          | 1              | 0           | 1     | V <sub>REFH</sub><br>(see Note 2)                   |
| 1     | 1          | 1              | 1           | 0     | V <sub>SSA</sub> /V <sub>REFL</sub> (see<br>Note 2) |
| 1     | 1          | 1              | 1           | 1     | ADC power off                                       |

 Table 19-1. Mux Channel Select

Notes:

1. If any unused channels are selected, the resulting ADC conversion will be unknown.

2. The voltage levels supplied from internal reference nodes as specified in the table are used to verify the operation of the ADC converter both in production test and for user applications.

## 19.8.2 ADC Data Register

One 8-bit result register is provided. This register is updated each time an ADC conversion completes.



#### 19.8.3 ADC Input Clock Register

This register selects the clock frequency for the ADC.





#### ADIV2:ADIV0 — ADC Clock Prescaler Bits

ADIV2, ADIV1, and ADIV0 form a 3-bit field which selects the divide ratio used by the ADC to generate the internal ADC clock. **Table 19-2** shows the available clock configurations. The ADC clock should be set to approximately 1 MHz.

| ADIV2 | ADIV1 | ADIV0 | ADC Clock Rate       |
|-------|-------|-------|----------------------|
| 0     | 0     | 0     | ADC input clock / 1  |
| 0     | 0     | 1     | ADC input clock / 2  |
| 0     | 1     | 0     | ADC input clock / 4  |
| 0     | 1     | 1     | ADC input clock / 8  |
| 1     | Х     | Х     | ADC input clock / 16 |

 Table 19-2. ADC Clock Divide Ratio

X = don't care

ADICLK — ADC Input Clock Register Bit

ADICLK selects either bus clock or CGMXCLK as the input clock source to generate the internal ADC clock. Reset selects CGMXCLK as the ADC clock source.

If the external clock (CGMXCLK) is equal to or greater than 1 MHz, CGMXCLK can be used as the clock source for the ADC. If CGMXCLK is less than 1 MHz, use the PLL-generated bus clock as the clock source. As long as the internal ADC clock is at approximately 1 MHz, correct operation can be guaranteed. (See 23.7 ADC Characteristics.)

## 1 = Internal bus clock

0 = External clock (CGMXCLK)

1 MHz =  $\frac{f_{XCLK} \text{ or bus frequency}}{ADIV[2:0]}$ 

**NOTE:** During the conversion process, changing the ADC clock will result in an incorrect conversion.

MC68HC08QA24

**Technical Data** 

# Section 20. Timer Interface A (TIMA)

## 20.1 Contents

| 20.2 In                                                                              | ntroduction                 |
|--------------------------------------------------------------------------------------|-----------------------------|
| 20.3 F                                                                               | eatures                     |
| 20.4.1<br>20.4.2<br>20.4.3<br>20.4.3.1<br>20.4.3.2<br>20.4.4<br>20.4.4.1<br>20.4.4.2 |                             |
| 20.4.4.3<br>20.5 In                                                                  | PWM Initialization          |
| 20.6 Lo<br>20.6.1<br>20.6.2                                                          | ow-Power Modes              |
| 20.7 T                                                                               | IMA During Break Interrupts |
| 20.8 l/<br>20.8.1<br>20.8.2                                                          | O Signals                   |
| 20.9 1/0<br>20.9.1<br>20.9.2<br>20.9.3<br>20.9.4                                     | O Registers                 |
| 20.9.5                                                                               | TIMA Channel Registers      |

MC68HC08QA24

## 20.2 Introduction

This section describes the timer interface module (TIMA). The TIMA is a 2-channel timer that provides a timing reference with input capture, output compare, and pulse width modulation functions. **Figure 20-1** is a block diagram of the TIMA.

## 20.3 Features

Features of the TIMA include:

- Two input capture/output compare channels:
  - Rising-edge, falling-edge, or any-edge input capture trigger
  - Set, clear, or toggle output compare action
- Buffered and unbuffered pulse width modulation (PWM) signal generation
- Programmable TIMA clock input:
  - 7-frequency internal bus clock prescaler selection
  - External TIMA clock input (4-MHz maximum frequency)
- Free-running or modulo up-count operation
- Toggle any channel pin on overflow
- TIMA counter stop and reset bits
- Modular architecture expandable to eight channels



Figure 20-1. TIMA Block Diagram

| Addr.         | Register Name                              |        | Bit 7  | 6         | 5     | 4    | 3  | 2    | 1   | Bit 0 |
|---------------|--------------------------------------------|--------|--------|-----------|-------|------|----|------|-----|-------|
|               |                                            | Read:  | TOF    | TOIE      | TSTOP | 0    | 0  | PS2  | PS1 | PS0   |
| \$0020        | TIMA Status and Control<br>Register (TASC) | Write: | 0      | TOIL      | 13101 | TRST | R  | F JZ |     | F JU  |
|               |                                            | Reset: | 0      | 0         | 1     | 0    | 0  | 0    | 0   | 0     |
|               |                                            | Read:  | Bit 15 | 14        | 13    | 12   | 11 | 10   | 9   | Bit 8 |
| \$0022        | TIMA Counter Register High<br>(TACNTH)     | Write: | R      | R         | R     | R    | R  | R    | R   | R     |
|               |                                            | Reset: | 0      | 0         | 0     | 0    | 0  | 0    | 0   | 0     |
|               |                                            | Read:  | Bit 7  | 6         | 5     | 4    | 3  | 2    | 1   | Bit 0 |
| \$0023 TIMA C | TIMA Counter Register Low<br>(TACNTL)      | Write: | R      | R         | R     | R    | R  | R    | R   | R     |
|               |                                            |        | 0      | 0         | 0     | 0    | 0  | 0    | 0   | 0     |
|               |                                            |        | R      | = Reserve | ed    |      |    |      |     |       |



MC68HC08QA24

## Timer Interface A (TIMA)

| Addr.  | Register Name                                 |                 | Bit 7     | 6                         | 5    | 4           | 3            | 2     | 1    | Bit 0  |  |  |
|--------|-----------------------------------------------|-----------------|-----------|---------------------------|------|-------------|--------------|-------|------|--------|--|--|
| \$0024 | TIMA Modulo Register High<br>(TAMODH)         | Read:<br>Write: | Bit 15    | 14                        | 13   | 12          | 11           | 10    | 9    | Bit 8  |  |  |
|        | (                                             | Reset:          | 1         | 1                         | 1    | 1           | 1            | 1     | 1    | 1      |  |  |
| \$0025 | TIMA Modulo Register Low<br>(TAMODL)          | Read:<br>Write: | Bit 7     | 6                         | 5    | 4           | 3            | 2     | 1    | Bit 0  |  |  |
|        | Reset:                                        | 1               | 1         | 1                         | 1    | 1           | 1            | 1     | 1    |        |  |  |
| \$0026 | TIMA Channel 0 Status<br>and Control Register | Read:<br>Write: | CH0F<br>0 | CHOIE                     | MS0B | MS0A        | ELSOB        | ELS0A | TOV0 | CHOMAX |  |  |
|        | (TASC0)                                       | Reset:          | 0         | 0                         | 0    | 0           | 0            | 0     | 0    | 0      |  |  |
| \$0027 | TIMA Channel 0 Register High<br>(TACH0H)      | Read:<br>Write: | Bit 15    | 14                        | 13   | 12          | 11           | 10    | 9    | Bit 8  |  |  |
|        | (includy                                      |                 |           | Indeterminate after reset |      |             |              |       |      |        |  |  |
| \$0028 | 50028 TIMA Channel 0 Register Low<br>(TACH0L) | Read:<br>Write: | Bit 7     | 6                         | 5    | 4           | 3            | 2     | 1    | Bit 0  |  |  |
|        |                                               | Reset:          |           |                           | I    | ndeterminat | e after rese | t     |      |        |  |  |
|        | TIMA Channel 1 Status                         | Read:           | CH1F      | CH1IE                     | 0    | MS1A        | ELS1B        | ELS1A | TOV1 | CH1MAX |  |  |
| \$0029 | and Control Register                          | Write:          | 0         |                           | R    | MJIA        | ELJID        | ELJIA | 1001 | CHIMAA |  |  |
|        | (TASC1)                                       | Reset:          | 0         | 0                         | 0    | 0           | 0            | 0     | 0    | 0      |  |  |
| \$002A | TIMA Channel 1 Register High<br>(TACH1H)      | Read:<br>Write: | Bit 15    | 14                        | 13   | 12          | 11           | 10    | 9    | Bit 8  |  |  |
|        | (                                             | Reset:          |           |                           | l    | ndeterminat | e after rese | t     |      |        |  |  |
| \$002B | TIMA Channel 1 Register Low<br>(TACH1L)       | Read:<br>Write: | Bit 7     | 6                         | 5    | 4           | 3            | 2     | 1    | Bit 0  |  |  |
|        |                                               | Reset:          |           |                           | I    | ndeterminat | e after rese | t     |      |        |  |  |
|        |                                               |                 | R         | ] = Reserve               | ed   |             |              |       |      |        |  |  |

Figure 20-2. TIMA I/O Register Summary (Continued)
# **20.4 Functional Description**

**Figure 20-1** shows the TIMA structure. The central component of the TIMA is the 16-bit TIMA counter that can operate as a free-running counter or a modulo up-counter. The TIMA counter provides the timing reference for the input capture and output compare functions. The TIMA counter modulo registers, TAMODH–TAMODL, control the modulo value of the TIMA counter. Software can read the TIMA counter value at any time without affecting the counting sequence.

The two TIMA channels are programmable independently as input capture or output compare channels.

#### 20.4.1 TIMA Counter Prescaler

The TIMA clock source can be one of the seven prescaler outputs or the TIMA clock pin, PTF3/TACLK. The prescaler generates seven clock rates from the internal bus clock. The prescaler select bits, PS[2:0], in the TIMA status and control register select the TIMA clock source.

#### 20.4.2 Input Capture

An input capture function has three basic parts:

- Edge select logic
- Input capture latch
- 16-bit counter

Two 8-bit registers, which make up the 16-bit input capture register, are used to latch the value of the free-running counter after the corresponding input capture edge detector senses a defined transition. The polarity of the active edge is programmable. The level transition which triggers the counter transfer is defined by the corresponding input edge bits (ELSxB and ELSxA in TASCO–TASC1 control registers with x referring to the active channel number). When an active edge occurs on the pin of an input capture channel, the TIMA latches the contents of the TIMA counter into the TIMA channel registers, TCHxH–TCHxL. Input captures can generate TIMA CPU interrupt requests. Software can determine that an input capture event has occurred by enabling input capture interrupts or by polling the status flag bit.

The result obtained by an input capture will be one more than the value of the free-running counter on the rising edge of the internal bus clock preceding the external transition. This delay is required for internal synchronization.

The free-running counter contents are transferred to the TIMA channel status and control register (TASCO–TASC1, see **20.9.4 TIMA Channel Status and Control Registers**) on each proper signal transition regardless of whether the TIMA channel flag (CH0F–CH1F in TASCO–TASC1 registers) is set or clear. When the status flag is set, a CPU interrupt is generated if enabled. The value of the count latched or "captured" is the time of the event. Because this value is stored in the input capture register when the actual event occurs, user software can respond to this event at a later time and determine the actual time of the event. However, this must be done prior to another input capture on the same pin; otherwise, the previous time value will be lost.

By recording the times for successive edges on an incoming signal, software can determine the period and/or pulse width of the signal. To measure a period, two successive edges of the same polarity are captured. To measure a pulse width, two alternate polarity edges are captured. Software should track the overflows at the 16-bit module counter to extend its range.

Another use for the input capture function is to establish a time reference. In this case, an input capture function is used in conjunction with an output compare function. For example, to activate an output signal a specified number of clock cycles after detecting an input event (edge), use the input capture function to record the time at which the edge occurred. A number corresponding to the desired delay is added to this captured value and stored to an output compare register (see **20.9.5 TIMA Channel Registers**). Because both input captures and output compares are referenced to the same 16-bit modulo counter, the delay can be controlled to the resolution of the counter independent of software latencies.

Reset does not affect the contents of the input capture register.

#### 20.4.3 Output Compare

With the output compare function, the TIMA can generate a periodic pulse with a programmable polarity, duration, and frequency. When the counter reaches the value in the registers of an output compare channel, the TIMA can set, clear, or toggle the channel pin. Output compares can generate TIMA CPU interrupt requests.

### 20.4.3.1 Unbuffered Output Compare

Any output compare channel can generate unbuffered output compare pulses as described in **20.4.3 Output Compare**. The pulses are unbuffered because changing the output compare value requires writing the new value over the old value currently in the TIMA channel registers.

An unsynchronized write to the TIMA channel registers to change an output compare value could cause incorrect operation for up to two counter overflow periods. For example, writing a new value before the counter reaches the old value but after the counter reaches the new value prevents any compare during that counter overflow period. Also, using a TIMA overflow interrupt routine to write a new, smaller output compare value may cause the compare to be missed. The TIMA may pass the new value before it is written.

Use these methods to synchronize unbuffered changes in the output compare value on channel x:

- When changing to a smaller value, enable channel x output compare interrupts and write the new value in the output compare interrupt routine. The output compare interrupt occurs at the end of the current output compare pulse. The interrupt routine has until the end of the counter overflow period to write the new value.
- When changing to a larger output compare value, enable channel x TIMA overflow interrupts and write the new value in the TIMA overflow interrupt routine. The TIMA overflow interrupt occurs at the end of the current counter overflow period. Writing a larger value in an output compare interrupt routine (at the end of the current pulse) could cause two output compares to occur in the same counter overflow period.

#### 20.4.3.2 Buffered Output Compare

Channels 0 and 1 can be linked to form a buffered output compare channel whose output appears on the PTE3/TACH1 pin. The TIMA channel registers of the linked pair alternately control the output.

Setting the MS0B bit in TIMA channel 0 status and control register (TASC0) links channel 0 and channel 1. The output compare value in the TIMA channel 0 registers initially controls the output on the PTE2/TACH0 pin. Writing to the TIMA channel 1 registers enables the TIMA channel 1 registers to synchronously control the output after the TIMA overflows. At each subsequent overflow, the TIMA channel registers (0 or 1) that control the output are the ones written to last. TSC0 controls and monitors the buffered output compare function, and TIMA channel 1 status and control register (TASC1) is unused. While the MS0B bit is set, the channel 1 pin, PTE3/TACH1, is available as a general-purpose I/O pin.

**NOTE:** In buffered output compare operation, do not write new output compare values to the currently active channel registers. Writing to the active channel registers is the same as generating unbuffered output compares.

#### 20.4.4 Pulse Width Modulation (PWM)

By using the toggle-on-overflow feature with an output compare channel, the TIMA can generate a PWM signal. The value in the TIMA counter modulo registers determines the period of the PWM signal. The channel pin toggles when the counter reaches the value in the TIMA counter modulo registers. The time between overflows is the period of the PWM signal.

As **Figure 20-3** shows, the output compare value in the TIMA channel registers determines the pulse width of the PWM signal. The time between overflow and output compare is the pulse width. Program the TIMA to clear the channel pin on output compare if the state of the PWM pulse is logic 1. Program the TIMA to set the pin if the state of the PWM pulse is logic 0.

MC68HC08QA24



Figure 20-3. PWM Period and Pulse Width

The value in the TIMA counter modulo registers and the selected prescaler output determines the frequency of the PWM output. The frequency of an 8-bit PWM signal is variable in 256 increments. Writing \$00FF (255) to the TIMA counter modulo registers produces a PWM period of 256 times the internal bus clock period if the prescaler select value is \$000 (see **20.9.1 TIMA Status and Control Register**).

The value in the TIMA channel registers determines the pulse width of the PWM output. The pulse width of an 8-bit PWM signal is variable in 256 increments. Writing \$0080 (128) to the TIMA channel registers produces a duty cycle of 128/256 or 50 percent.

#### 20.4.4.1 Unbuffered PWM Signal Generation

Any output compare channel can generate unbuffered PWM pulses as described in **20.4.4 Pulse Width Modulation (PWM)**. The pulses are unbuffered because changing the pulse width requires writing the new pulse width value over the value currently in the TIMA channel registers.

An unsynchronized write to the TIMA channel registers to change a pulse width value could cause incorrect operation for up to two PWM periods. For example, writing a new value before the counter reaches the old value but after the counter reaches the new value prevents any compare during that PWM period. Also, using a TIMA overflow interrupt routine to write a new, smaller pulse width value may cause the compare to be missed. The TIMA may pass the new value before it is written.

# Timer Interface A (TIMA)

Use these methods to synchronize unbuffered changes in the PWM pulse width on channel x:

- When changing to a shorter pulse width, enable channel x output compare interrupts and write the new value in the output compare interrupt routine. The output compare interrupt occurs at the end of the current pulse. The interrupt routine has until the end of the PWM period to write the new value.
- When changing to a longer pulse width, enable channel x TIMA overflow interrupts and write the new value in the TIMA overflow interrupt routine. The TIMA overflow interrupt occurs at the end of the current PWM period. Writing a larger value in an output compare interrupt routine (at the end of the current pulse) could cause two output compares to occur in the same PWM period.
- **NOTE:** In PWM signal generation, do not program the PWM channel to toggle on output compare. Toggling on output compare prevents reliable 0 percent duty cycle generation and removes the ability of the channel to self-correct in the event of software error or noise. Toggling on output compare also can cause incorrect PWM signal generation when changing the PWM pulse width to a new, much larger value.

#### 20.4.4.2 Buffered PWM Signal Generation

Channels 0 and 1 can be linked to form a buffered PWM channel whose output appears on the PTE2/TACH0 pin. The TIMA channel registers of the linked pair alternately control the pulse width of the output.

Setting the MS0B bit in TIMA channel 0 status and control register (TASC0) links channel 0 and channel 1. The TIMA channel 0 registers initially control the pulse width on the PTE2/TACH0 pin. Writing to the TIMA channel 1 registers enables the TIMA channel 1 registers to synchronously control the pulse width at the beginning of the next PWM period. At each subsequent overflow, the TIMA channel registers (0 or 1) that control the pulse width are the ones written to last. TSC0 controls and monitors the buffered PWM function, and TIMA channel 1 status and control register (TASC1) is unused. While the MS0B bit is set, the channel 1 pin, PTE3/TACH1, is available as a general-purpose I/O pin.

**Technical Data** 

MC68HC08QA24

**NOTE:** In buffered PWM signal generation, do not write new pulse width values to the currently active channel registers. Writing to the active channel registers is the same as generating unbuffered PWM signals.

#### 20.4.4.3 PWM Initialization

To ensure correct operation when generating unbuffered or buffered PWM signals, use this initialization procedure:

- 1. In the TIMA status and control register (TASC):
  - a. Stop the TIMA counter by setting the TIMA stop bit, TSTOP.
  - b. Reset the TIMA counter by setting the TIMA reset bit, TRST.
- 2. In the TIMA counter modulo registers (TAMODH–TAMODL), write the value for the required PWM period.
- 3. In the TIMA channel x registers (TACHxH–TACHxL), write the value for the required pulse width.
- 4. In TIMA channel x status and control register (TASCx):
  - a. Write 0:1 (for unbuffered output compare or PWM signals) or 1:0 (for buffered output compare or PWM signals) to the mode select bits, MSxB–MSxA. (See Table 20-2.)
  - b. Write 1 to the toggle-on-overflow bit, TOVx.
  - c. Write 1:0 (to clear output on compare) or 1:1 (to set output on compare) to the edge/level select bits, ELSxB–ELSxA. The output action on compare must force the output to the complement of the pulse width level. (See Table 20-2.)
- **NOTE:** In PWM signal generation, do not program the PWM channel to toggle on output compare. Toggling on output compare prevents reliable 0 percent duty cycle generation and removes the ability of the channel to self-correct in the event of software error or noise. Toggling on output compare can also cause incorrect PWM signal generation when changing the PWM pulse width to a new, much larger value.
  - 5. In the TIMA status control register (TASC), clear the TIMA stop bit, TSTOP.

MOTOROLA

Setting MS0B links channels 0 and 1 and configures them for buffered PWM operation. The TIMA channel 0 registers (TACH0H–TACH0L) initially control the buffered PWM output. TIMA channel 0 status control register 0 (TASC0) controls and monitors the PWM signal from the linked channels. MS0B takes priority over MS0A.

Clearing the toggle-on-overflow bit, TOVx, inhibits output toggles on TIMA overflows. Subsequent output compares try to force the output to a state it is already in and have no effect. The result is a 0 percent duty cycle output.

Setting the channel x maximum duty cycle bit (CHxMAX) and clearing the TOVx bit generates a 100 percent duty cycle output. (See **20.9.4 TIMA Channel Status and Control Registers**.)

# 20.5 Interrupts

These TIMA sources can generate interrupt requests:

- TIMA overflow flag (TOF) The TOF bit is set when the TIMA counter value rolls over to \$0000 after matching the value in the TIMA counter modulo registers. The TIMA overflow interrupt enable bit, TOIE, enables TIMA overflow CPU interrupt requests. TOF and TOIE are in the TIMA status and control register.
- TIMA channel flags (CH1F–CH0F) The CHxF bit is set when an input capture or output compare occurs on channel x. Channel x TIMA CPU interrupt requests are controlled by the channel x interrupt enable bit, CHxIE.

# 20.6 Low-Power Modes

The WAIT and STOP instructions put the MCU in low powerconsumption standby modes.

#### 20.6.1 Wait Mode

The TIMA remains active after the execution of a WAIT instruction. In wait mode, the TIMA registers are not accessible by the CPU. Any enabled CPU interrupt request from the TIMA can bring the MCU out of wait mode.

If TIMA functions are not required during wait mode, reduce power consumption by stopping the TIMA before executing the WAIT instruction.

#### 20.6.2 Stop Mode

The TIMA is inactive after the execution of a STOP instruction. The STOP instruction does not affect register conditions or the state of the TIMA counter. TIMA operation resumes when the MCU exits stop mode.

### **20.7 TIMA During Break Interrupts**

A break interrupt stops the TIMA counter.

The system integration module (SIM) controls whether status bits in other modules can be cleared during the break state. The BCFE bit in the SIM break flag control register (SBFCR) enables software to clear status bits during the break state. (See **10.8.3 SIM Break Flag Control Register**.)

To allow software to clear status bits during a break interrupt, write a logic 1 to the BCFE bit. If a status bit is cleared during the break state, it remains cleared when the MCU exits the break state.

MC68HC08QA24

To protect status bits during the break state, write a logic 0 to the BCFE bit. With BCFE at logic 0 (its default state), software can read and write I/O registers during the break state without affecting status bits. Some status bits have a 2-step read/write clearing procedure. If software does the first step on such a bit before the break, the bit cannot change during the break state as long as BCFE is at logic 0. After the break, doing the second step clears the status bit.

# 20.8 I/O Signals

Port F shares one of its pins with the TIMA. Port E shares two of its pins with the TIMA. PTF3/TACLK is an external clock input to the TIMA prescaler. The two TIMA channel I/O pins are PTE2/TACH0 and PTE3/TACH1.

### 20.8.1 TIMA Clock Pin (PTF3/TACLK)

PTF3/TACLK is an external clock input that can be the clock source for the TIMA counter instead of the prescaled internal bus clock. Select the PTF3/TACLK input by writing logic 1s to the three prescaler select bits, PS[2:0]. (See **20.9.1 TIMA Status and Control Register**.) The minimum TCLK pulse width, TCLK<sub>LMIN</sub> or TCLK<sub>HMIN</sub>, is:

$$\frac{1}{\text{bus frequency}} + t_{SU}$$

See 23.8 5.0 Vdc  $\pm$  10% Serial Peripheral Interface (SPI) Timing number 6.

The maximum TCLK frequency is the least: 4 MHz or bus frequency ÷ 2.

PTF3/TACLK is available as a general-purpose I/O pin or ADC channel when not used as the TIMA clock input. When the PTF3/TACLK pin is the TIMA clock input, it is an input regardless of the state of the DDRF3 bit in data direction register F.

## 20.8.2 TIMA Channel I/O Pins (PTE3/TACH1–PTE2/TACH0)

Each channel I/O pin is programmable independently as an input capture pin or an output compare pin. PTE2/TACH0 can be configured as a buffered output compare or a buffered PWM pin.

## 20.9 I/O Registers

These I/O registers control and monitor TIMA operation:

- TIMA status and control register (TASC)
- TIMA control registers (TACNTH–TACNTL)
- TIMA counter modulo registers (TAMODH–TAMODL)
- TIMA channel status and control registers (TASC0 and TASC1)
- TIMA channel registers (TACH0H–TACH0L and TACH1H–TACH1L)

#### 20.9.1 TIMA Status and Control Register

The TIMA status and control register:

- Enables TIMA overflow interrupts
- Flags TIMA overflows
- Stops the TIMA counter
- Resets the TIMA counter
- Prescales the TIMA counter clock

# **Timer Interface A (TIMA)**

Address: \$0020

|        | Bit 7 | 6           | 5     | 4    | 3 | 2   | 1   | Bit 0 |
|--------|-------|-------------|-------|------|---|-----|-----|-------|
| Read:  | TOF   | TOIE        | TSTOP | 0    | 0 | PS2 | PS1 | PS0   |
| Write: | 0     |             |       | TRST | R |     | FJI |       |
| Reset: | 0     | 0           | 1     | 0    | 0 | 0   | 0   | 0     |
|        | R     | ] = Reserve | d     |      |   |     |     |       |



### TOF — TIMA Overflow Flag Bit

This read/write flag is set when the TIMA counter resets to \$0000 after reaching the modulo value programmed in the TIMA counter modulo registers. Clear TOF by reading the TIMA status and control register when TOF is set and then writing a logic 0 to TOF. If another TIMA overflow occurs before the clearing sequence is complete, then writing logic 0 to TOF has no effect. Therefore, a TOF interrupt request cannot be lost due to inadvertent clearing of TOF. Reset clears the TOF bit. Writing a logic 1 to TOF has no effect.

1 = TIMA counter has reached modulo value.

0 = TIMA counter has not reached modulo value.

### TOIE — TIMA Overflow Interrupt Enable Bit

This read/write bit enables TIMA overflow interrupts when the TOF bit becomes set. Reset clears the TOIE bit.

1 = TIMA overflow interrupts enabled

0 = TIMA overflow interrupts disabled

### TSTOP — TIMA Stop Bit

This read/write bit stops the TIMA counter. Counting resumes when TSTOP is cleared. Reset sets the TSTOP bit, stopping the TIMA counter until software clears the TSTOP bit.

1 = TIMA counter stopped

- 0 = TIMA counter active
- **NOTE:** Do not set the TSTOP bit before entering wait mode if the TIMA is required to exit wait mode.

TRST — TIMA Reset Bit

Setting this write-only bit resets the TIMA counter and the TIMA prescaler. Setting TRST has no effect on any other registers. Counting resumes from \$0000. TRST is cleared automatically after the TIMA counter is reset and always reads as logic 0. Reset clears the TRST bit.

- 1 = Prescaler and TIMA counter cleared
- 0 = No effect
- **NOTE:** Setting the TSTOP and TRST bits simultaneously stops the TIMA counter at a value of \$0000.

PS[2:0] — Prescaler Select Bits

These read/write bits select either the PTD4 pin or one of the seven prescaler outputs as the input to the TIMA counter as **Table 20-1** shows. Reset clears the PS[2:0] bits.

| PS[2:0] | TIMA Clock Source       |
|---------|-------------------------|
| 000     | Internal bus clock ÷1   |
| 001     | Internal bus clock ÷ 2  |
| 010     | Internal bus clock ÷ 4  |
| 011     | Internal bus clock ÷ 8  |
| 100     | Internal bus clock ÷ 16 |
| 101     | Internal bus clock ÷ 32 |
| 110     | Internal bus clock ÷ 64 |
| 111     | PTF3/TACLK              |

 Table 20-1. Prescaler Selection

#### 20.9.2 TIMA Counter Registers

The two read-only TIMA counter registers contain the high and low bytes of the value in the TIMA counter. Reading the high byte (TACNTH) latches the contents of the low byte (TACNTL) into a buffer. Subsequent reads of TACNTH do not affect the latched TACNTL value until TACNTL is read. Reset clears the TIMA counter registers. Setting the TIMA reset bit (TRST) also clears the TIMA counter registers.

**NOTE:** If TACNTH is read during a break interrupt, be sure to unlatch TACNTL by reading TACNTL before exiting the break interrupt. Otherwise, TACNTL retains the value latched during the break.

|        | Bit 7      | 6           | 5        | 4      | 3  | 2  | 1 | Bit 0 |
|--------|------------|-------------|----------|--------|----|----|---|-------|
| Read:  | Bit 15     | 14          | 13       | 12     | 11 | 10 | 9 | Bit 8 |
| Write: | R          | R           | R        | R      | R  | R  | R | R     |
| Reset: | 0          | 0           | 0        | 0      | 0  | 0  | 0 | 0     |
|        |            |             |          |        |    |    |   |       |
| Regist | er Name ar | nd Address: | TACNTL - | \$0023 |    |    |   |       |

Register Name and Address: TACNTH — \$0022

| Regis  |       | ia / iau 055. | IN CONTLE | φ0020 |   |   |   |       |
|--------|-------|---------------|-----------|-------|---|---|---|-------|
|        | Bit 7 | 6             | 5         | 4     | 3 | 2 | 1 | Bit 0 |
| Read:  | Bit 7 | 6             | 5         | 4     | 3 | 2 | 1 | Bit 0 |
| Write: | R     | R             | R         | R     | R | R | R | R     |
| Reset: | 0     | 0             | 0         | 0     | 0 | 0 | 0 | 0     |
|        | R     | = Reserve     | d         |       |   |   |   |       |

Figure 20-5. TIMA Counter Registers (TACNTH and TACNTL)

### 20.9.3 TIMA Counter Modulo Registers

The read/write TIMA modulo registers contain the modulo value for the TIMA counter. When the TIMA counter reaches the modulo value, the overflow flag (TOF) becomes set, and the TIMA counter resumes counting from \$0000 at the next clock. Writing to the high byte (TMODH) inhibits the TOF bit and overflow interrupts until the low byte (TMODL) is written. Reset sets the TIMA counter modulo registers.

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

Register Name and Address: TAMODH — \$0024

#### Register Name and Address: TAMODL - \$0025

|        | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
|--------|-------|---|---|---|---|---|---|-------|
| Read:  | Bit 7 | 6 | 5 | Л | 3 | 2 | 1 | Bit 0 |
| Write: | DIC   | 0 | 5 | Ŧ | 5 | 2 | I | Dit U |
| Reset: | 1     | 1 | 1 | 1 | 1 | 1 | 1 | 1     |

Figure 20-6. TIMA Counter Modulo Registers (TMODH and TMODL)

**NOTE:** Reset the TIMA counter before writing to the TIMA counter modulo registers.

MC68HC08QA24

303

### 20.9.4 TIMA Channel Status and Control Registers

Each of the TIMA channel status and control registers:

- Flags input captures and output compares
- Enables input capture and output compare interrupts
- Selects input capture, output compare, or PWM operation
- Selects high, low, or toggling output on output compare
- Selects rising edge, falling edge, or any edge as the active input capture trigger
- Selects output toggling on TIMA overflow
- Selects 100 percent PWM duty cycle
- Selects buffered or unbuffered output compare/PWM operation

|        | Bit 7 | 6     | 5      | 4    | 3     | 2     | 1    | Bit 0   |
|--------|-------|-------|--------|------|-------|-------|------|---------|
| Read:  | CH0F  | CHOIE | MS0B   | MS0A | ELS0B | ELS0A | TOV0 | CHOMAX  |
| Write: | 0     | CHUL  | INISOD | MOUA | LLJUD | LLJUA | 1000 | CHOWIAX |
| Reset: | 0     | 0     | 0      | 0    | 0     | 0     | 0    | 0       |

Register Name and Address: TASC0 — \$0026

Register Name and Address: TASC1 — \$0029

|        | Bit 7 | 6         | 5            | 4     | 3     | 2     | 1    | Bit 0  |
|--------|-------|-----------|--------------|-------|-------|-------|------|--------|
| Read:  | CH1F  |           | CH1IE 0<br>R | MS1A  | ELS1B | ELS1A | TOV1 | CH1MAX |
| Write: | 0     | CITIL     |              | WISTA |       |       | IOVI |        |
| Reset: | 0     | 0         | 0            | 0     | 0     | 0     | 0    | 0      |
|        | R     | = Reserve | d            |       |       |       |      |        |

Figure 20-7. TIMA Channel Status and Control Registers (TASC0–TASC1)

### CHxF — Channel x Flag Bit

When channel x is an input capture channel, this read/write bit is set when an active edge occurs on the channel x pin. When channel x is an output compare channel, CHxF is set when the value in the TIMA counter registers matches the value in the TIMA channel x registers.

When CHxIE = 0, clear CHxF by reading TIMA channel x status and control register with CHxF set, and then writing a logic 0 to CHxF. If another interrupt request occurs before the clearing sequence is complete, then writing logic 0 to CHxF has no effect. Therefore, an interrupt request cannot be lost due to inadvertent clearing of CHxF.

Reset clears the CHxF bit. Writing a logic 1 to CHxF has no effect.

- 1 = Input capture or output compare on channel x
- 0 = No input capture or output compare on channel x
- CHxIE Channel x Interrupt Enable Bit

This read/write bit enables TIMA CPU interrupts on channel x.

Reset clears the CHxIE bit.

- 1 = Channel x CPU interrupt requests enabled
- 0 = Channel x CPU interrupt requests disabled

MSxB — Mode Select Bit B

This read/write bit selects buffered output compare/PWM operation. MSxB exists only in the TIMA channel 0.

Setting MS0B disables the channel 1 status and control register and reverts TCH1 to general-purpose I/O.

Reset clears the MSxB bit.

- 1 = Buffered output compare/PWM operation enabled
- 0 = Buffered output compare/PWM operation disabled
- MSxA Mode Select Bit A

When ELSxB:A  $\neq$  00, this read/write bit selects either input capture operation or unbuffered output compare/PWM operation. (See **Table 20-2**.)

1 = Unbuffered output compare/PWM operation

0 = Input capture operation

When ELSxB:A = 00, this read/write bit selects the initial output level of the TCHx pin. (See **Table 20-2**.). Reset clears the MSxA bit.

- 1 = Initial output level low
- 0 = Initial output level high
- **NOTE:** Before changing a channel function by writing to the MSxB or MSxA bit, set the TSTOP and TRST bits in the TIMA status and control register (TASC).

ELSxB and ELSxA — Edge/Level Select Bits

When channel x is an input capture channel, these read/write bits control the active edge-sensing logic on channel x.

When channel x is an output compare channel, ELSxB and ELSxA control the channel x output behavior when an output compare occurs.

When ELSxB and ELSxA are both clear, channel x is not connected to port E, and pin PTEx/TCHx is available as a general-purpose I/O pin. **Table 20-2** shows how ELSxB and ELSxA work. Reset clears the ELSxB and ELSxA bits.

| MSxB:MSxA | ELSxB:ELSxA | Mode               | Configuration                                        |  |  |  |
|-----------|-------------|--------------------|------------------------------------------------------|--|--|--|
| X0        | 00          | Output preset      | Pin under port control; initial<br>output level high |  |  |  |
| X1        | 00          | Output preset      | Pin under port control; initial<br>output level low  |  |  |  |
| 00        | 01          |                    | Capture on rising edge only                          |  |  |  |
| 00        | 10          | Input capture      | Capture on falling edge only                         |  |  |  |
| 00        | 11          |                    | Capture on rising or falling edge                    |  |  |  |
| 01        | 01          | Output             | Toggle output on compare                             |  |  |  |
| 01        | 10          | compare            | Clear output on compare                              |  |  |  |
| 01        | 11          | or PWM             | Set output on compare                                |  |  |  |
| 1X        | 01          | Buffered           | Toggle output on compare                             |  |  |  |
| 1X        | 10          | output<br>compare  | Clear output on compare                              |  |  |  |
| 1X        | 11          | or buffered<br>PWM | Set output on compare                                |  |  |  |

Table 20-2. Mode, Edge, and Level Selection

- **NOTE:** Before enabling a TIMA channel register for input capture operation, make sure that the PTEx/TACHx pin is stable for at least two bus clocks.
  - TOVx Toggle-On-Overflow Bit

When channel x is an output compare channel, this read/write bit controls the behavior of the channel x output when the TIMA counter overflows. When channel x is an input capture channel, TOVx has no effect. Reset clears the TOVx bit.

1 = Channel x pin toggles on TIMA counter overflow.

0 = Channel x pin does not toggle on TIMA counter overflow.

**NOTE:** When TOVx is set, a TIMA counter overflow takes precedence over a channel x output compare if both occur at the same time.

CHxMAX — Channel x Maximum Duty Cycle Bit

When the TOVx bit is at logic 0, setting the CHxMAX bit forces the duty cycle of buffered and unbuffered PWM signals to 100 percent. As **Figure 20-8** shows, the CHxMAX bit takes effect in the cycle after it is set or cleared. The output stays at the 100 percent duty cycle level until the cycle after CHxMAX is cleared.



Figure 20-8. CHxMAX Latency

#### 20.9.5 TIMA Channel Registers

These read/write registers contain the captured TIMA counter value of the input capture function or the output compare value of the output compare function. The state of the TIMA channel registers after reset is unknown.

In input capture mode (MSxB-MSxA = 0:0), reading the high byte of the TIMA channel x registers (TACHxH) inhibits input captures until the low byte (TACHxL) is read.

In output compare mode (MSxB–MSxA  $\neq$  0:0), writing to the high byte of the TIMA channel x registers (TACHxH) inhibits output compares until the low byte (TACHxL) is written.

| 5      | D# 7       | ,           | г.       | 4           | n             | 2       | 1     | D# 0  |
|--------|------------|-------------|----------|-------------|---------------|---------|-------|-------|
| I      | Bit 7      | 6           | 5        | 4           | 3             | 2       | 1     | Bit 0 |
| Read:  | Bit 15     | Bit 14      | Bit 13   | Bit 12      | Bit 11        | Bit 10  | Bit 9 | Bit 8 |
| Write: |            |             |          |             |               |         |       |       |
| Reset: |            |             |          | Indetermina | te after rese | t       |       |       |
|        |            |             |          |             |               |         |       |       |
| Regist | er Name ar | nd Address: | TACHOL — | \$0028      |               |         |       |       |
|        | Bit 7      | 6           | 5        | 4           | 3             | 2       | 1     | Bit 0 |
| Read:  |            |             |          |             |               |         |       | D'I A |
| Write: | Bit 7      | Bit 6       | Bit 5    | Bit 4       | Bit 3         | Bit 2   | Bit 1 | Bit 0 |
| Reset: |            | •           |          | Indetermina | te after rese | t       |       |       |
|        |            |             |          |             |               |         |       |       |
| Regist | er Name ar | nd Address: | TACH1H – | - \$002A    |               |         |       |       |
|        | Bit 7      | 6           | 5        | 4           | 3             | 2       | 1     | Bit 0 |
| Read:  |            | Diala       | D'I 10   | D'I 10      | D'I 11        | D'I 10  |       | D'I 0 |
| Write: | Bit 15     | Bit 14      | Bit 13   | Bit 12      | Bit 11        | Bit 10  | Bit 9 | Bit 8 |
| Reset: |            |             |          | Indetermina | te after rese | t       |       |       |
|        |            | Figure      | 20-9. TI | MA Cha      | nnel Re       | gisters |       |       |
|        |            | -           |          |             | CH1H/L)       | -       |       |       |
|        |            |             |          |             |               |         |       |       |

Register Name and Address: TACH0H - \$0027

Technical Data

MC68HC08QA24

Register Name and Address: TACH1L — \$002B

|                 | Bit 7 | 6     | 5     | 4     | 3     | 2     | 1     | Bit 0 |
|-----------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Read:<br>Write: | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| - ·             |       |       |       |       |       |       |       |       |

Reset:

Indeterminate after reset

Figure 20-9. TIMA Channel Registers (TACH0H/L–TACH1H/L) (Continued)

MC68HC08QA24

# Section 21. Timer Interface B (TIMB)

# 21.1 Contents

| 21.2 Introduction                                       |
|---------------------------------------------------------|
| 21.3 Features                                           |
| 21.4 Functional Description                             |
| 21.4.1 TIMB Counter Prescaler                           |
| 21.4.2 Input Capture                                    |
| 21.4.3 Output Compare                                   |
| 21.4.3.1 Unbuffered Output Compare                      |
| 21.4.3.2 Buffered Output Compare                        |
| 21.4.4 Pulse Width Modulation (PWM)                     |
| 21.4.4.1 Unbuffered PWM Signal Generation               |
| 21.4.4.2 Buffered PWM Signal Generation                 |
| 21.4.4.3 PWM Initialization                             |
| 21.5 Interrupts                                         |
| 21.6 Low-Power Modes                                    |
| 21.6.1 Wait Mode                                        |
| 21.6.2 Stop Mode                                        |
| 21.7 TIMB During Break Interrupts                       |
| 21.8 I/O Signals                                        |
| 21.8.1 TIMB Clock Pin (PTF2/TBCLK)                      |
|                                                         |
| 21.8.2 TIMB Channel I/O Pins (PTF1/TBCH1–PTF0/TBCH0)324 |
| 21.9 I/O Registers                                      |
| 21.9.1 TIMB Status and Control Register                 |
| 21.9.2 TIMB Counter Registers                           |
| 21.9.3 TIMB Counter Modulo Registers                    |
| 21.9.4 TIMB Channel Status and Control Registers        |
| 21.9.5 TIMB Channel Registers                           |
|                                                         |

MC68HC08QA24

# 21.2 Introduction

This section describes the timer interface module (TIMB). The TIMB is a 2-channel timer that provides a timing reference with input capture, output compare, and pulse width modulation functions. Figure 21-1 is a block diagram of the TIMB.

# 21.3 Features

Features of the TIMB include:

- Two input capture/output compare channels:
  - Rising-edge, falling-edge, or any-edge input capture trigger
  - Set, clear, or toggle output compare action
- Buffered and unbuffered pulse width modulation (PWM) signal generation
- Programmable TIMB clock input:
  - 7-frequency internal bus clock prescaler selection
  - External TIMB clock input (4-MHz maximum frequency)
- Free-running or modulo up-count operation
- Toggle any channel pin on overflow
- TIMB counter stop and reset bits
- Modular architecture expandable to eight channels



Figure 21-1. TIMB Block Diagram

| Addr.  | Register Name                              |        | Bit 7  | 6         | 5     | 4    | 3  | 2   | 1   | Bit 0 |
|--------|--------------------------------------------|--------|--------|-----------|-------|------|----|-----|-----|-------|
| \$002C | TIMB Status and Control<br>Register (TBSC) | Read:  | TOF    | TOIE      | TSTOP | 0    | 0  | PS2 | PS1 | PS0   |
|        |                                            | Write: | 0      |           |       | TRST | R  |     |     |       |
|        |                                            | Reset: | 0      | 0         | 1     | 0    | 0  | 0   | 0   | 0     |
| \$002E | TIMB Counter Register High<br>(TBCNTH)     | Read:  | Bit 15 | 14        | 13    | 12   | 11 | 10  | 9   | Bit 8 |
|        |                                            | Write: | R      | R         | R     | R    | R  | R   | R   | R     |
|        |                                            | Reset: | 0      | 0         | 0     | 0    | 0  | 0   | 0   | 0     |
| \$002F | TIMB Counter Register Low<br>(TBCNTL)      | Read:  | Bit 7  | 6         | 5     | 4    | 3  | 2   | 1   | Bit 0 |
|        |                                            | Write: | R      | R         | R     | R    | R  | R   | R   | R     |
|        | · · · ·                                    | Reset: | 0      | 0         | 0     | 0    | 0  | 0   | 0   | 0     |
|        |                                            |        | R      | = Reserve | ed    |      |    |     |     |       |

## Figure 21-2. TIMB I/O Register Summary

MC68HC08QA24

# Timer Interface B (TIMB)

| Addr.  | Register Name                                         |                 | Bit 7                     | 6         | 5    | 4           | 3            | 2     | 1    | Bit 0  |
|--------|-------------------------------------------------------|-----------------|---------------------------|-----------|------|-------------|--------------|-------|------|--------|
| \$0030 | TIMB Modulo Register High<br>(TBMODH)                 | Read:<br>Write: | Bit 15                    | 14        | 13   | 12          | 11           | 10    | 9    | Bit 8  |
|        |                                                       | Reset:          | 1                         | 1         | 1    | 1           | 1            | 1     | 1    | 1      |
| \$0031 | TIMB Modulo Register Low<br>(TBMODL)                  | Read:<br>Write: | Bit 7                     | 6         | 5    | 4           | 3            | 2     | 1    | Bit 0  |
|        |                                                       | Reset:          | 1                         | 1         | 1    | 1           | 1            | 1     | 1    | 1      |
| \$0032 | TIMB Channel 0 Status and<br>Control Register (TBSC0) | Read:<br>Write: | CH0F<br>0                 | CHOIE     | MS0B | MS0A        | ELS0B        | ELS0A | TOV0 | CHOMAX |
|        |                                                       | Reset:          | 0                         | 0         | 0    | 0           | 0            | 0     | 0    | 0      |
| \$0033 | TIMB Channel 0 Register High<br>(TBCH0H)              | Read:<br>Write: | Bit 15                    | 14        | 13   | 12          | 11           | 10    | 9    | Bit 8  |
|        |                                                       | Reset:          | Indeterminate after reset |           |      |             |              |       |      |        |
| \$0034 | TIMB Channel 0 Register Low<br>(TBCH0L)               | Read:<br>Write: | Bit 7                     | 6         | 5    | 4           | 3            | 2     | 1    | Bit 0  |
|        |                                                       | Reset:          | Indeterminate after reset |           |      |             |              |       |      |        |
| \$0035 | TIMB Channel 1 Status and<br>Control Register (TBSC1) | Read:           | CH1F                      | - CH1IE   | 0    | MS1A        | ELS1B        | ELS1A | TOV1 | CH1MAX |
|        |                                                       | Write:          | 0                         |           | R    |             |              |       |      |        |
|        |                                                       | Reset:          | 0                         | 0         | 0    | 0           | 0            | 0     | 0    | 0      |
| \$0036 | TIMB Channel 1 Register High<br>(TBCH1H)              | Read:<br>Write: | Bit 15                    | 14        | 13   | 12          | 11           | 10    | 9    | Bit 8  |
|        |                                                       | Reset:          | Indeterminate after reset |           |      |             |              |       |      |        |
| \$0037 | TIMB Channel 1 Register Low<br>(TBCH1L)               | Read:<br>Write: | Bit 7                     | 6         | 5    | 4           | 3            | 2     | 1    | Bit 0  |
|        |                                                       | Reset:          |                           |           | I    | ndeterminat | e after rese | t     |      |        |
|        |                                                       |                 | R                         | = Reserve | ed   |             |              |       |      |        |

Figure 21-2. TIMB I/O Register Summary (Continued)

**Technical Data** 

314

# **21.4 Functional Description**

**Figure 21-1** shows the TIMB structure. The central component of the TIMB is the 16-bit TIMB counter that can operate as a free-running counter or a modulo up-counter. The TIMB counter provides the timing reference for the input capture and output compare functions. The TIMB counter modulo registers, TBMODH–TBMODL, control the modulo value of the TIMB counter. Software can read the TIMB counter value at any time without affecting the counting sequence.

The two TIMB channels are programmable independently as input capture or output compare channels.

#### 21.4.1 TIMB Counter Prescaler

The TIMB clock source can be one of the seven prescaler outputs or the TIMB clock pin, PTF2/TBCLK. The prescaler generates seven clock rates from the internal bus clock. The prescaler select bits, PS[2:0], in the TIMB status and control register select the TIMB clock source.

#### 21.4.2 Input Capture

An input capture function has three basic parts:

- Edge select logic
- Input capture latch
- 16-bit counter

Two 8-bit registers, which make up the 16-bit input capture register, are used to latch the value of the free-running counter after the corresponding input capture edge detector senses a defined transition. The polarity of the active edge is programmable. The level transition which triggers the counter transfer is defined by the corresponding input edge bits (ELSxB and ELSxA in TBSC0 through TBSC1 control registers with x referring to the active channel number). When an active edge occurs on the pin of an input capture channel, the TIMB latches the contents of the TIMB counter into the TIMB channel registers, TCHxH–TCHxL. Input captures can generate TIMB CPU interrupt requests. Software can determine that an input capture event has occurred by enabling input capture interrupts or by polling the status flag bit.

MC68HC08QA24

The result obtained by an input capture will be one more than the value of the free-running counter on the rising edge of the internal bus clock preceding the external transition. This delay is required for internal synchronization.

The free-running counter contents are transferred to the TIMB channel status and control register (TBSC0–TBSC1, see **21.9.4 TIMB Channel Status and Control Registers**) on each proper signal transition regardless of whether the TIMB channel flag (CH0F–CH1F in TBSC0–TBSC1 registers) is set or clear. When the status flag is set, a CPU interrupt is generated if enabled. The value of the count latched or "captured" is the time of the event. Because this value is stored in the input capture register when the actual event occurs, user software can respond to this event at a later time and determine the actual time of the event. However, this must be done prior to another input capture on the same pin; otherwise, the previous time value will be lost.

By recording the times for successive edges on an incoming signal, software can determine the period and/or pulse width of the signal. To measure a period, two successive edges of the same polarity are captured. To measure a pulse width, two alternate polarity edges are captured. Software should track the overflows at the 16-bit module counter to extend its range.

Another use for the input capture function is to establish a time reference. In this case, an input capture function is used in conjunction with an output compare function. For example, to activate an output signal a specified number of clock cycles after detecting an input event (edge), use the input capture function to record the time at which the edge occurred. A number corresponding to the desired delay is added to this captured value and stored to an output compare register (see **21.9.5 TIMB Channel Registers**). Because both input captures and output compares are referenced to the same 16-bit modulo counter, the delay can be controlled to the resolution of the counter independent of software latencies.

Reset does not affect the contents of the input capture register.

### 21.4.3 Output Compare

With the output compare function, the TIMB can generate a periodic pulse with a programmable polarity, duration, and frequency. When the counter reaches the value in the registers of an output compare channel, the TIMB can set, clear, or toggle the channel pin. Output compares can generate TIMB CPU interrupt requests.

#### 21.4.3.1 Unbuffered Output Compare

Any output compare channel can generate unbuffered output compare pulses as described in **21.4.3 Output Compare**. The pulses are unbuffered because changing the output compare value requires writing the new value over the old value currently in the TIMB channel registers.

An unsynchronized write to the TIMB channel registers to change an output compare value could cause incorrect operation for up to two counter overflow periods. For example, writing a new value before the counter reaches the old value but after the counter reaches the new value prevents any compare during that counter overflow period. Also, using a TIMB overflow interrupt routine to write a new, smaller output compare value may cause the compare to be missed. The TIMB may pass the new value before it is written.

Use these methods to synchronize unbuffered changes in the output compare value on channel x:

- When changing to a smaller value, enable channel x output compare interrupts and write the new value in the output compare interrupt routine. The output compare interrupt occurs at the end of the current output compare pulse. The interrupt routine has until the end of the counter overflow period to write the new value.
- When changing to a larger output compare value, enable channel x TIMB overflow interrupts and write the new value in the TIMB overflow interrupt routine. The TIMB overflow interrupt occurs at the end of the current counter overflow period. Writing a larger value in an output compare interrupt routine (at the end of the current pulse) could cause two output compares to occur in the same counter overflow period.

#### 21.4.3.2 Buffered Output Compare

Channels 0 and 1 can be linked to form a buffered output compare channel whose output appears on the PTF0/TBCH0 pin. The TIMB channel registers of the linked pair alternately control the output.

Setting the MS0B bit in TIMB channel 0 status and control register (TBSC0) links channel 0 and channel 1. The output compare value in the TIMB channel 0 registers initially controls the output on the PTF0/TBCH0 pin. Writing to the TIMB channel 1 registers enables the TIMB channel 1 registers to synchronously control the output after the TIMB overflows. At each subsequent overflow, the TIMB channel registers (0 or 1) that control the output are the ones written to last. TSC0 controls and monitors the buffered output compare function, and TIMB channel 1 status and control register (TBSC1) is unused. While the MS0B bit is set, the channel 1 pin, PTF1/TBCH1, is available as a general-purpose I/O pin.

**NOTE:** In buffered output compare operation, do not write new output compare values to the currently active channel registers. Writing to the active channel registers is the same as generating unbuffered output compares.

#### 21.4.4 Pulse Width Modulation (PWM)

By using the toggle-on-overflow feature with an output compare channel, the TIMB can generate a PWM signal. The value in the TIMB counter modulo registers determines the period of the PWM signal. The channel pin toggles when the counter reaches the value in the TIMB counter modulo registers. The time between overflows is the period of the PWM signal.

As **Figure 21-3** shows, the output compare value in the TIMB channel registers determines the pulse width of the PWM signal. The time between overflow and output compare is the pulse width. Program the TIMB to clear the channel pin on output compare if the state of the PWM pulse is logic 1. Program the TIMB to set the pin if the state of the PWM pulse is logic 0.



Figure 21-3. PWM Period and Pulse Width

The value in the TIMB counter modulo registers and the selected prescaler output determines the frequency of the PWM output. The frequency of an 8-bit PWM signal is variable in 256 increments. Writing \$00FF (255) to the TIMB counter modulo registers produces a PWM period of 256 times the internal bus clock period if the prescaler select value is \$000 (see **21.9.1 TIMB Status and Control Register**).

The value in the TIMB channel registers determines the pulse width of the PWM output. The pulse width of an 8-bit PWM signal is variable in 256 increments. Writing \$0080 (128) to the TIMB channel registers produces a duty cycle of 128/256 or 50 percent.

#### 21.4.4.1 Unbuffered PWM Signal Generation

Any output compare channel can generate unbuffered PWM pulses as described in **21.4.4 Pulse Width Modulation (PWM)**. The pulses are unbuffered because changing the pulse width requires writing the new pulse width value over the value currently in the TIMB channel registers.

An unsynchronized write to the TIMB channel registers to change a pulse width value could cause incorrect operation for up to two PWM periods. For example, writing a new value before the counter reaches the old value but after the counter reaches the new value prevents any compare during that PWM period. Also, using a TIMB overflow interrupt routine to write a new, smaller pulse width value may cause the compare to be missed. The TIMB may pass the new value before it is written.

# Timer Interface B (TIMB)

Use the following methods to synchronize unbuffered changes in the PWM pulse width on channel x:

- When changing to a shorter pulse width, enable channel x output compare interrupts and write the new value in the output compare interrupt routine. The output compare interrupt occurs at the end of the current pulse. The interrupt routine has until the end of the PWM period to write the new value.
- When changing to a longer pulse width, enable channel x TIMB overflow interrupts and write the new value in the TIMB overflow interrupt routine. The TIMB overflow interrupt occurs at the end of the current PWM period. Writing a larger value in an output compare interrupt routine (at the end of the current pulse) could cause two output compares to occur in the same PWM period.
- **NOTE:** In PWM signal generation, do not program the PWM channel to toggle on output compare. Toggling on output compare prevents reliable 0 percent duty cycle generation and removes the ability of the channel to self-correct in the event of software error or noise. Toggling on output compare also can cause incorrect PWM signal generation when changing the PWM pulse width to a new, much larger value.

#### 21.4.4.2 Buffered PWM Signal Generation

Channels 0 and 1 can be linked to form a buffered PWM channel whose output appears on the PTF0/TBCH0 pin. The TIMB channel registers of the linked pair alternately control the pulse width of the output.

Setting the MS0B bit in TIMB channel 0 status and control register (TBSC0) links channel 0 and channel 1. The TIMB channel 0 registers initially control the pulse width on the PTF0/TBCH0 pin. Writing to the TIMB channel 1 registers enables the TIMB channel 1 registers to synchronously control the pulse width at the beginning of the next PWM period. At each subsequent overflow, the TIMB channel registers (0 or 1) that control the pulse width are the ones written to last. TSC0 controls and monitors the buffered PWM function, and TIMB channel 1 status and control register (TBSC1) is unused. While the MS0B bit is set, the channel 1 pin, PTF1/TBCH1, is available as a general-purpose I/O pin.

**Technical Data** 

MC68HC08QA24

**NOTE:** In buffered PWM signal generation, do not write new pulse width values to the currently active channel registers. Writing to the active channel registers is the same as generating unbuffered PWM signals.

#### 21.4.4.3 PWM Initialization

To ensure correct operation when generating unbuffered or buffered PWM signals, use this initialization procedure:

- 1. In the TIMB status and control register (TBSC):
  - a. Stop the TIMB counter by setting the TIMB stop bit, TSTOP.
  - b. Reset the TIMB counter by setting the TIMB reset bit, TRST.
- 2. In the TIMB counter modulo registers (TBMODH–TBMODL), write the value for the required PWM period.
- 3. In the TIMB channel x registers (TBCHxH–TBCHxL), write the value for the required pulse width.
- 4. In TIMB channel x status and control register (TBSCx):
  - a. Write 0:1 (for unbuffered output compare or PWM signals) or 1:0 (for buffered output compare or PWM signals) to the mode select bits, MSxB–MSxA. (See Table 21-2.)
  - b. Write 1 to the toggle-on-overflow bit, TOVx.
  - c. Write 1:0 (to clear output on compare) or 1:1 (to set output on compare) to the edge/level select bits, ELSxB–ELSxA. The output action on compare must force the output to the complement of the pulse width level. (See Table 21-2.)
- **NOTE:** In PWM signal generation, do not program the PWM channel to toggle on output compare. Toggling on output compare prevents reliable 0 percent duty cycle generation and removes the ability of the channel to self-correct in the event of software error or noise. Toggling on output compare can also cause incorrect PWM signal generation when changing the PWM pulse width to a new, much larger value.
  - 5. In the TIMB status control register (TBSC), clear the TIMB stop bit, TSTOP.

Setting MS0B links channels 0 and 1 and configures them for buffered PWM operation. The TIMB channel 0 registers (TBCH0H–TBCH0L) initially control the buffered PWM output. TIMB status control register 0 (TBSCR0) controls and monitors the PWM signal from the linked channels. MS0B takes priority over MS0A.

Clearing the toggle-on-overflow bit, TOVx, inhibits output toggles on TIMB overflows. Subsequent output compares try to force the output to a state it is already in and have no effect. The result is a 0 percent duty cycle output.

Setting the channel x maximum duty cycle bit (CHxMAX) and clearing the TOVx bit generates a 100 percent duty cycle output. (See **21.9.4 TIMB Channel Status and Control Registers**.)

# 21.5 Interrupts

These TIMB sources can generate interrupt requests:

- TIMB overflow flag (TOF) The TOF bit is set when the TIMB counter value rolls over to \$0000 after matching the value in the TIMB counter modulo registers. The TIMB overflow interrupt enable bit, TOIE, enables TIMB overflow CPU interrupt requests. TOF and TOIE are in the TIMB status and control register.
- TIMB channel flags (CH1F–CH0F) The CHxF bit is set when an input capture or output compare occurs on channel x. Channel x TIMB CPU interrupt requests are controlled by the channel x interrupt enable bit, CHxIE.

# 21.6 Low-Power Modes

The WAIT and STOP instructions put the MCU in low powerconsumption standby modes.

#### 21.6.1 Wait Mode

The TIMB remains active after the execution of a WAIT instruction. In wait mode, the TIMB registers are not accessible by the CPU. Any enabled CPU interrupt request from the TIMB can bring the MCU out of wait mode.

If TIMB functions are not required during wait mode, reduce power consumption by stopping the TIMB before executing the WAIT instruction.

#### 21.6.2 Stop Mode

The TIMB is inactive after the execution of a STOP instruction. The STOP instruction does not affect register conditions or the state of the TIMB counter. TIMB operation resumes when the MCU exits stop mode.

## 21.7 TIMB During Break Interrupts

A break interrupt stops the TIMB counter.

The system integration module (SIM) controls whether status bits in other modules can be cleared during the break state. The BCFE bit in the SIM break flag control register (SBFCR) enables software to clear status bits during the break state. (See **10.8.3 SIM Break Flag Control Register**.)

To allow software to clear status bits during a break interrupt, write a logic 1 to the BCFE bit. If a status bit is cleared during the break state, it remains cleared when the MCU exits the break state.

To protect status bits during the break state, write a logic 0 to the BCFE bit. With BCFE at logic 0 (its default state), software can read and write I/O registers during the break state without affecting status bits. Some status bits have a 2-step read/write clearing procedure. If software does the first step on such a bit before the break, the bit cannot change during the break state as long as BCFE is at logic 0. After the break, doing the second step clears the status bit.

# 21.8 I/O Signals

Port F shares three of its pins with the TIMB. PTF2/TBCLK is an external clock input to the TIMB prescaler. The two TIMB channel I/O pins are PTF0/TBCH0 and PTF1/TBCH1.

### 21.8.1 TIMB Clock Pin (PTF2/TBCLK)

PTF2/TBCLK is an external clock input that can be the clock source for the TIMB counter instead of the prescaled internal bus clock. Select the PTF2/TBCLK input by writing logic 1s to the three prescaler select bits, PS[2:0]. (See **21.9.1 TIMB Status and Control Register**.) The minimum TCLK pulse width, TCLK<sub>LMIN</sub> or TCLK<sub>HMIN</sub>, is:

 $\frac{1}{\text{bus frequency}} + t_{SU}$ 

See 23.8 5.0 Vdc  $\pm$  10% Serial Peripheral Interface (SPI) Timing number 6.

The maximum TCLK frequency is the least: 4 MHz or bus frequency ÷ 2.

PTF2/TBCLK is available as a general-purpose I/O pin or ADC channel when not used as the TIMB clock input. When the PTF2/TBCLK pin is the TIMB clock input, it is an input regardless of the state of the DDRF2 bit in data direction register F.

### 21.8.2 TIMB Channel I/O Pins (PTF1/TBCH1-PTF0/TBCH0)

Each channel I/O pin is programmable independently as an input capture pin or an output compare pin. PTF0/TBCH0 can be configured as a buffered output compare or a buffered PWM pin.
# 21.9 I/O Registers

These I/O registers control and monitor TIMB operation:

- TIMB status and control register (TBSC)
- TIMB control registers (TBCNTH–TBCNTL)
- TIMB counter modulo registers (TBMODH–TBMODL)
- TIMB channel status and control registers (TBSC0 and TBSC1)
- TIMB channel registers (TBCH0H–TBCH0L and TBCH1H–TBCH1L)

## 21.9.1 TIMB Status and Control Register

The TIMB status and control register:

- Enables TIMB overflow interrupts
- Flags TIMB overflows
- Stops the TIMB counter
- Resets the TIMB counter
- Prescales the TIMB counter clock

## Timer Interface B (TIMB)

Address: \$002C

|        | Bit 7 | 6         | 5     | 4    | 3 | 2    | 1   | Bit 0 |
|--------|-------|-----------|-------|------|---|------|-----|-------|
| Read:  | TOF   | TOIE      | TSTOP | 0    | 0 | PS2  | PS1 | PS0   |
| Write: | 0     | TUIL      |       | TRST | R | 1.52 | FJI | 130   |
| Reset: | 0     | 0         | 1     | 0    | 0 | 0    | 0   | 0     |
|        | R     | = Reserve | d     |      |   |      |     |       |



## TOF — TIMB Overflow Flag Bit

This read/write flag is set when the TIMB counter resets to \$0000 after reaching the modulo value programmed in the TIMB counter modulo registers. Clear TOF by reading the TIMB status and control register when TOF is set and then writing a logic 0 to TOF. If another TIMB overflow occurs before the clearing sequence is complete, then writing logic 0 to TOF has no effect. Therefore, a TOF interrupt request cannot be lost due to inadvertent clearing of TOF. Reset clears the TOF bit. Writing a logic 1 to TOF has no effect.

- 1 = TIMB counter has reached modulo value
- 0 = TIMB counter has not reached modulo value
- TOIE TIMB Overflow Interrupt Enable Bit

This read/write bit enables TIMB overflow interrupts when the TOF bit becomes set. Reset clears the TOIE bit.

1 = TIMB overflow interrupts enabled

0 = TIMB overflow interrupts disabled

TSTOP — TIMB Stop Bit

This read/write bit stops the TIMB counter. Counting resumes when TSTOP is cleared. Reset sets the TSTOP bit, stopping the TIMB counter until software clears the TSTOP bit.

- 1 = TIMB counter stopped
- 0 = TIMB counter active
- **NOTE:** Do not set the TSTOP bit before entering wait mode if the TIMB is required to exit wait mode.

TRST — TIMB Reset Bit

Setting this write-only bit resets the TIMB counter and the TIMB prescaler. Setting TRST has no effect on any other registers. Counting resumes from \$0000. TRST is cleared automatically after the TIMB counter is reset and always reads as logic 0. Reset clears the TRST bit.

- 1 = Prescaler and TIMB counter cleared
- 0 = No effect
- **NOTE:** Setting the TSTOP and TRST bits simultaneously stops the TIMB counter at a value of \$0000.

PS[2:0] — Prescaler Select Bits

These read/write bits select either the PTD4 pin or one of the seven prescaler outputs as the input to the TIMB counter as **Table 21-1** shows. Reset clears the PS[2:0] bits.

| PS[2:0] | TIMB Clock Source       |
|---------|-------------------------|
| 000     | Internal bus clock ÷1   |
| 001     | Internal bus clock ÷ 2  |
| 010     | Internal bus clock ÷ 4  |
| 011     | Internal bus clock ÷ 8  |
| 100     | Internal bus clock ÷ 16 |
| 101     | Internal bus clock ÷ 32 |
| 110     | Internal bus clock ÷ 64 |
| 111     | PTF2/TBCLK              |

Table 21-1. Prescaler Selection

#### 21.9.2 TIMB Counter Registers

The two read-only TIMB counter registers contain the high and low bytes of the value in the TIMB counter. Reading the high byte (TBCNTH) latches the contents of the low byte (TBCNTL) into a buffer. Subsequent reads of TBCNTH do not affect the latched TBCNTL value until TBCNTL is read. Reset clears the TIMB counter registers. Setting the TIMB reset bit (TRST) also clears the TIMB counter registers.

**NOTE:** If TBCNTH is read during a break interrupt, be sure to unlatch TBCNTL by reading TBCNTL before exiting the break interrupt. Otherwise, TBCNTL retains the value latched during the break.

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

Register Name and Address: TBCNTH -- \$002E

Register Name and Address: TBCNTL - \$002F

|       | 6         | 5                                            | 4                                                                 | 3                                                                                      | 2                                                                                                           | 1                                                                                                                                | Bit 0                                                                                                                                                 |
|-------|-----------|----------------------------------------------|-------------------------------------------------------------------|----------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------|
| Bit 7 | 6         | 5                                            | 4                                                                 | 3                                                                                      | 2                                                                                                           | 1                                                                                                                                | Bit 0                                                                                                                                                 |
| R     | R         | R                                            | R                                                                 | R                                                                                      | R                                                                                                           | R                                                                                                                                | R                                                                                                                                                     |
| 0     | 0         | 0                                            | 0                                                                 | 0                                                                                      | 0                                                                                                           | 0                                                                                                                                | 0                                                                                                                                                     |
| R     | = Reserve | d                                            |                                                                   |                                                                                        |                                                                                                             |                                                                                                                                  |                                                                                                                                                       |
|       | R<br>0    | Bit 7      6        R      R        0      0 | Bit 7      6      5        R      R      R        0      0      0 | Bit 7      6      5      4        R      R      R      R        0      0      0      0 | Bit 7      6      5      4      3        R      R      R      R      R        0      0      0      0      0 | Bit 7      6      5      4      3      2        R      R      R      R      R      R        0      0      0      0      0      0 | Bit 7      6      5      4      3      2      1        R      R      R      R      R      R      R        0      0      0      0      0      0      0 |

Figure 21-5. TIMB Counter Registers (TBCNTH and TBCNTL)

#### 21.9.3 TIMB Counter Modulo Registers

The read/write TIMB modulo registers contain the modulo value for the TIMB counter. When the TIMB counter reaches the modulo value, the overflow flag (TOF) becomes set, and the TIMB counter resumes counting from \$0000 at the next clock. Writing to the high byte (TBMODH) inhibits the TOF bit and overflow interrupts until the low byte (TBMODL) is written. Reset sets the TIMB counter modulo registers.

Register Name and Address: TBMODH — \$0030

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

Register Name and Address: TBMODL - \$0031

|        | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
|--------|-------|---|---|---|---|---|---|-------|
| Read:  | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| Write: | DIC   | 0 | 5 | 7 | 5 | 2 | I | Dit U |
| Reset: | 1     | 1 | 1 | 1 | 1 | 1 | 1 | 1     |

Figure 21-6. TIMB Counter Modulo Registers (TBMODH and TBMODL)

**NOTE:** Reset the TIMB counter before writing to the TIMB counter modulo registers.

#### 21.9.4 TIMB Channel Status and Control Registers

Each of the TIMB channel status and control registers:

- Flags input captures and output compares
- Enables input capture and output compare interrupts
- Selects input capture, output compare, or PWM operation
- Selects high, low, or toggling output on output compare
- Selects rising edge, falling edge, or any edge as the active input capture trigger
- Selects output toggling on TIMB overflow
- Selects 100 percent PWM duty cycle
- Selects buffered or unbuffered output compare/PWM operation

|        | Bit 7 | 6     | 5    | 4    | 3     | 2     | 1     | Bit 0  |         |
|--------|-------|-------|------|------|-------|-------|-------|--------|---------|
| Read:  | CH0F  | CHOIE | MS0B | MS0A | ELS0B | ELS0A | TOV0  | CHOMAX |         |
| Write: | 0     | CHUIE |      | MOD  | MOUA  | LLJUD | LLJUA | 1000   | CHOWIAX |
| Reset: | 0     | 0     | 0    | 0    | 0     | 0     | 0     | 0      |         |

Register Name and Address: TBSC0 — \$0032

Register Name and Address: TBSC1 — \$0035

|        | Bit 7 | 6         | 5 | 4    | 3     | 2     | 1    | Bit 0  |
|--------|-------|-----------|---|------|-------|-------|------|--------|
| Read:  | CH1F  | CH1IE -   | 0 | MS1A | ELS1B | ELS1A | TOV1 | CH1MAX |
| Write: | 0     | CITIL     | R |      |       |       |      |        |
| Reset: | 0     | 0         | 0 | 0    | 0     | 0     | 0    | 0      |
|        | R     | = Reserve | d |      |       |       |      |        |

Figure 21-7. TIMB Channel Status and Control Registers (TBSC0–TBSC1)

## CHxF — Channel x Flag Bit

When channel x is an input capture channel, this read/write bit is set when an active edge occurs on the channel x pin. When channel x is an output compare channel, CHxF is set when the value in the TIMB counter registers matches the value in the TIMB channel x registers.

When CHxIE = 0, clear CHxF by reading TIMB channel x status and control register with CHxF set, and then writing a logic 0 to CHxF. If another interrupt request occurs before the clearing sequence is complete, then writing logic 0 to CHxF has no effect. Therefore, an interrupt request cannot be lost due to inadvertent clearing of CHxF.

Reset clears the CHxF bit. Writing a logic 1 to CHxF has no effect.

- 1 = Input capture or output compare on channel x
- 0 = No input capture or output compare on channel x
- CHxIE Channel x Interrupt Enable Bit

This read/write bit enables TIMB CPU interrupts on channel x.

Reset clears the CHxIE bit.

- 1 = Channel x CPU interrupt requests enabled
- 0 = Channel x CPU interrupt requests disabled

MSxB — Mode Select Bit B

This read/write bit selects buffered output compare/PWM operation. MSxB exists only in the TIMB channel 0.

Setting MS0B disables the channel 1 status and control register and reverts TCH1 to general-purpose I/O.

Reset clears the MSxB bit.

- 1 = Buffered output compare/PWM operation enabled
- 0 = Buffered output compare/PWM operation disabled
- MSxA Mode Select Bit A

When ELSxB:A  $\neq$  00, this read/write bit selects either input capture operation or unbuffered output compare/PWM operation. (See **Table 21-2**.)

1 = Unbuffered output compare/PWM operation

0 = Input capture operation

When ELSxB:A = 00, this read/write bit selects the initial output level of the TCHx pin. (See Table 21-2.). Reset clears the MSxA bit.

- 1 = Initial output level low
- 0 = Initial output level high
- **NOTE:** Before changing a channel function by writing to the MSxB or MSxA bit, set the TSTOP and TRST bits in the TIMB status and control register (TBSC).

#### ELSxB and ELSxA — Edge/Level Select Bits

When channel x is an input capture channel, these read/write bits control the active edge-sensing logic on channel x.

When channel x is an output compare channel, ELSxB and ELSxA control the channel x output behavior when an output compare occurs.

When ELSxB and ELSxA are both clear, channel x is not connected to port F, and pin PTFx/TCHx is available as a general-purpose I/O pin. Table 21-2 shows how ELSxB and ELSxA work. Reset clears the ELSxB and ELSxA bits.

| MSxB:MSxA | ELSxB:ELSxA | Mode              | Configuration                                     |
|-----------|-------------|-------------------|---------------------------------------------------|
| X0        | 00          | Output            | Pin under port control; initial output level high |
| X1        | 00          | preset            | Pin under port control; initial output level low  |
| 00        | 01          |                   | Capture on rising edge only                       |
| 00        | 10          | Input<br>capture  | Capture on falling edge only                      |
| 00        | 11          |                   | Capture on rising or falling edge                 |
| 01        | 01          | Output            | Toggle output on compare                          |
| 01        | 10          | compare           | Clear output on compare                           |
| 01        | 11          | or PWM            | Set output on compare                             |
| 1X        | 01          | Buffered          | Toggle output on compare                          |
| 1X        | 10          | output<br>compare | Clear output on compare                           |
| 1X        | 11          | orbuffered<br>PWM | Set output on compare                             |

Table 21-2. Mode, Edge, and Level Selection

- **NOTE:** Before enabling a TIMB channel register for input capture operation, make sure that the PTFx/TBCHx pin is stable for at least two bus clocks.
  - TOVx Toggle-On-Overflow Bit

When channel x is an output compare channel, this read/write bit controls the behavior of the channel x output when the TIMB counter overflows. When channel x is an input capture channel, TOVx has no effect. Reset clears the TOVx bit.

1 = Channel x pin toggles on TIMB counter overflow.

0 = Channel x pin does not toggle on TIMB counter overflow.

**NOTE:** When TOVx is set, a TIMB counter overflow takes precedence over a channel x output compare if both occur at the same time.

CHxMAX — Channel x Maximum Duty Cycle Bit

When the TOVx bit is at logic 0, setting the CHxMAX bit forces the duty cycle of buffered and unbuffered PWM signals to 100 percent. As **Figure 21-8** shows, the CHxMAX bit takes effect in the cycle after it is set or cleared. The output stays at the 100 percent duty cycle level until the cycle after CHxMAX is cleared.



Figure 21-8. CHxMAX Latency

#### 21.9.5 TIMB Channel Registers

These read/write registers contain the captured TIMB counter value of the input capture function or the output compare value of the output compare function. The state of the TIMB channel registers after reset is unknown.

In input capture mode (MSxB-MSxA = 0:0), reading the high byte of the TIMB channel x registers (TBCHxH) inhibits input captures until the low byte (TBCHxL) is read.

In output compare mode (MSxB–MSxA  $\neq$  0:0), writing to the high byte of the TIMB channel x registers (TBCHxH) inhibits output compares until the low byte (TBCHxL) is written.

| 5                  | Bit 7               | 6                | 5             | 4             | 3                  | 2      | 1     | Bit 0 |
|--------------------|---------------------|------------------|---------------|---------------|--------------------|--------|-------|-------|
| Read:<br>Write:    | Bit 15              | Bit 14           | Bit 13        | Bit 12        | Bit 11             | Bit 10 | Bit 9 | Bit 8 |
| Reset:             |                     |                  |               | Indeterminat  | te after rese      | t      |       |       |
| Regist             |                     | nd Address:      |               | - \$0034      |                    |        |       |       |
|                    | Bit 7               | 6                | 5             | 4             | 3                  | 2      | 1     | Bit 0 |
| Read:<br>Write:    | Bit 7               | Bit 6            | Bit 5         | Bit 4         | Bit 3              | Bit 2  | Bit 1 | Bit 0 |
| Reset:             |                     |                  |               | Indeterminat  | te after rese      | t      |       |       |
| Regist             | er Name ar<br>Bit 7 | nd Address:<br>6 | TBCH1H –<br>5 | - \$0036<br>4 | 3                  | 2      | 1     | Bit 0 |
| Read:              | Bit 15              | Bit 14           | Bit 13        | Bit 12        | Bit 11             | Bit 10 | Bit 9 | Bit 8 |
| Write:  <br>Reset: |                     |                  |               |               | te after rese      |        |       |       |
|                    |                     | -                |               |               | nnel Re<br>CH1H/L) | -      |       |       |

Register Name and Address: TBCH0H - \$0033

Register Name and Address: TBCH1L — \$0037

|                 | Bit 7 | 6     | 5     | 4     | 3     | 2     | 1     | Bit 0 |
|-----------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Read:<br>Write: | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
| - ·             |       |       |       |       |       |       |       |       |

Reset:

Indeterminate after reset

Figure 21-9. TIMB Channel Registers (TBCH0H/L–TBCH1H/L) (Continued)

**Technical Data** 

# Section 22. CAN Controller

# 22.1 Contents

| 22.2 Introduction                                                                                    |
|------------------------------------------------------------------------------------------------------|
| 22.3 Features                                                                                        |
| 22.4 External Pins                                                                                   |
| 22.5Message Storage.34122.5.1Background.34122.5.2Receive Structures.34222.5.3Transmit Structures.344 |
| 22.6 Identifier Acceptance Filter                                                                    |
| 22.7Interrupts34922.7.1Interrupt Acknowledge35022.7.2Interrupt Vectors.350                           |
| 22.8 Protocol Violation Protection                                                                   |
| 22.9Low-Power Modes                                                                                  |
| 22.10 Timer Link                                                                                     |
| 22.11 Clock System                                                                                   |
| 22.12 Memory Map                                                                                     |
| 22.13 Programmer's Model of Message Storage                                                          |

| 22.13.4   | Data Segment Registers                            |
|-----------|---------------------------------------------------|
| 22.13.5   | Transmit Buffer Priority Registers                |
| 22.14 Pro | ogrammer's Model of Control Registers             |
| 22.14.1   | MSCAN08 Module Control Register                   |
| 22.14.2   | MSCAN08 Module Control Register                   |
| 22.14.3   | MSCAN08 Bus Timing Register 0                     |
| 22.14.4   | MSCAN08 Bus Timing Register 1                     |
| 22.14.5   | MSCAN08 Receiver Flag Register                    |
| 22.14.6   | MSCAN08 Receiver Interrupt Enable Register        |
| 22.14.7   | MSCAN08 Transmitter Flag Register                 |
| 22.14.8   | MSCAN08 Transmitter Control Register              |
| 22.14.9   | MSCAN08 Identifier Acceptance Control Register376 |
| 22.14.10  | MSCAN08 Receive Error Counter Register            |
| 22.14.11  | MSCAN08 Transmit Error Counter Register           |
| 22.14.12  | MSCAN08 Identifier Acceptance Registers           |
| 22.14.13  | MSCAN08 Identifier Mask Registers                 |

## 22.2 Introduction

The MSCAN08 is the specific implementation of the Motorola scalable controller area network (MSCAN) concept targeted for the Motorola M68HC08 Family.

The module is a communication controller implementing the CAN 2.0 A/B protocol as defined in the BOSCH specification dated September 1991.

The CAN protocol was primarily, but not exclusively, designed to be used as a vehicle serial data bus, meeting the specific requirements of this field:

- Real-time processing
- Reliable operation in the electromagnetic interference (EMI)
  environment of a vehicle
- Cost-effectiveness and required bandwidth

MSCAN08 utilizes an advanced buffer arrangement, resulting in a predictable real-time behavior and simplifies the application software.

## 22.3 Features

Basic features of the MSCAN08 are:

- Modular architecture
- Implementation of the CAN protocol version 2.0A/B:
  - Standard and extended data frames
  - 0-8 bytes data length
  - Programmable bit rate up to 1 Mbps, depending on the actual bit timing and the clock jitter of the phase-lock loop (PLL)
- Support for remote frames
- Double-buffered receive storage scheme
- Triple-buffered transmit storage scheme with internal prioritization using a "local priority" concept
- Flexible maskable identifier filter supports alternatively one full size extended identifier filter or two 16-bit filters or four 8-bit filters
- Programmable wakeup functionality with integrated low-pass filter
- Programmable loop-back mode supports self-test operation
- Separate signalling and interrupt capabilities for all CAN receiver and transmitter error states (warning, error passive, bus off)
- Programmable MSCAN08 clock source either central processor unit (CPU) bus clock or crystal oscillator output
- Programmable link to on-chip timer interface module (TIM) for time-stamping and network synchronization
- Low-power sleep mode

# 22.4 External Pins

The MSCAN08 uses two external pins, one input (CANRx) and one output (CANTx). The CANTx output pin represents the logic level on the CAN: 0 is for a dominant state, and 1 is for a recessive state.

A typical CAN system with MSCAN08 is shown in Figure 22-1.



Figure 22-1. CAN System

Each CAN station is connected physically to the CAN bus lines through a transceiver chip. The transceiver is capable of driving the large current needed for the CAN and has current protection against defected CAN or defected stations.

## 22.5 Message Storage

MSCAN08 facilitates a sophisticated message storage system which addresses the requirements of a broad range of network applications.

#### 22.5.1 Background

Modern application layer software is built under two fundamental assumptions:

- Any CAN node is able to send out a stream of scheduled messages without releasing the bus between two messages. Such nodes will arbitrate for the bus right after sending the previous message and will only release the bus in case of lost arbitration.
- 2. The internal message queue within any CAN node is organized such that the highest priority message will be sent out first if more than one message is ready to be sent.

The above behavior cannot be achieved with a single transmit buffer. That buffer must be reloaded right after the previous message has been sent. This loading process lasts a definite amount of time and has to be completed within the inter-frame sequence (IFS) to be able to send an uninterrupted stream of messages. Even if this is feasible for limited CAN bus speeds, it requires that the CPU reacts with short latencies to the transmit interrupt.

A double buffer scheme would de-couple the re-loading of the transmit buffers from the actual message being sent and as such reduces the reactiveness requirements on the CPU. Problems may arise if the sending of a message would be finished just while the CPU re-loads the second buffer. In that case, no buffer would then be ready for transmission and the bus would be released.

Under all circumstances, at least three transmit buffers are required to meet the first of the above requirements. The MSCAN08 has three transmit buffers.

The second requirement calls for some sort of internal prioritization which the MSCAN08 implements with the "local priority" concept described in **22.5.2 Receive Structures**.

#### 22.5.2 Receive Structures

The received messages are stored in a 2-stage input first in first out (FIFO). The two message buffers are mapped using a ping pong arrangement into a single memory area (see Figure 22-2). While the background receive buffer (RxBG) is exclusively associated to the MSCAN08, the foreground receive buffer (RxFG) is addressable by the CPU08. This scheme simplifies the handler software, because only one address area is applicable for the receive process.

Each buffer has 13 bytes to store the CAN control bits, the identifier (standard or extended), and the data content (for details, see See 22.13 Programmer's Model of Message Storage.).

The receiver full flag (RXF) in the MSCAN08 receiver flag register (CRFLG) (see **22.14.5 MSCAN08 Receiver Flag Register**) signals the status of the foreground receive buffer. When the buffer contains a correctly received message with matching identifier, this flag is set.

After the MSCAN08 successfully receives a message into the background buffer, it copies the content of RxBG into RxFG<sup>(1)</sup>, sets the RXF flag, and emits a receive interrupt to the CPU<sup>(2)</sup>. A new message, which may follow immediately after the IFS field of the CAN frame, will be received into RxBG.

The user's receive handler has to read the received message from RxFG and to reset the RXF flag to acknowledge the interrupt and to release the foreground buffer.

<sup>1.</sup> Only if the RXF flag is not set

<sup>2.</sup> The receive interrupt will occur only if not masked. A polling scheme can be applied on RXF also.





An overrun condition occurs when both the foreground and the background receive message buffers that are filled with correctly received messages and another message is being received from the bus. The latter message will be discarded and an error interrupt with overrun indication will occur if enabled. The over-writing of the background buffer is independent of the identifier filter function. In the overrun situation, the MSCAN08 will stay synchronized to the CAN bus. While it is able to transmit messages, all incoming messages will be discarded.

**NOTE:** MSCAN08 will receive its own messages into the background receive buffer RxBG but will not overwrite RxFG and will NOT emit a receive interrupt. It also will not acknowledge (ACK) its own messages on the CAN bus. The only exception to this rule is in loop-back mode when MSCAN08 will treat its own messages exactly like all other incoming messages.

#### 22.5.3 Transmit Structures

The MSCAN08 has a triple transmit buffer scheme to allow multiple messages to be set up in advance and to achieve an optimized real-time performance. The three buffers are arranged as shown in **Figure 22-2**.

All three buffers have a 13-byte data structure similar to the outline of the receive buffers (see **22.13 Programmer's Model of Message Storage**). An additional transmit buffer priority register (TBPR) contains an 8-bit "local priority" field (PRIO) (see **22.13.5 Transmit Buffer Priority Registers**).

To transmit a message, the CPU08 has to identify an available transmit buffer which is indicated by a set transmit buffer empty (TXE) flag in the MSCAN08 transmitter flag register (CTFLG) (see 22.14.7 MSCAN08 Transmitter Flag Register).

The CPU08 then stores the identifier, the control bits and the data content into one of the transmit buffers. Finally, the buffer has to be flagged ready for transmission by clearing the TXE flag.

The MSCAN08 then will schedule the message for transmission and will signal the successful transmission of the buffer by setting the TXE flag. A transmit interrupt will be emitted<sup>(1)</sup> when TXE is set and can be used to drive the application software to re-load the buffer.

In case more than one buffer is scheduled for transmission when the CAN bus becomes available for arbitration, the MSCAN08 uses the local priority setting of the three buffers for priorisation. For this purpose, every transmit buffer has an 8-bit local priority field (PRIO). The application software sets this field when the message is set up. The local priority reflects the priority of this particular message relative to the set of messages being emitted from this node. The lowest binary value of the PRIO field is defined as the highest priority.

The internal scheduling process takes place whenever the MSCAN08 arbitrates for the bus. This is also the case after the occurrence of a transmission error.

When a high priority message is scheduled by the application software, it may become necessary to abort a lower priority message being set up in one of the three transmit buffers. Because messages that are already under transmission cannot be aborted, the user has to request the abort by setting the corresponding abort request flag (ABTRQ) in the transmission control register (CTCR). The MSCAN08 will then grant the request, if possible, by setting the corresponding abort request acknowledge (ABTAK) and the TXE flag to release the buffer and by emitting a transmit interrupt. The transmit interrupt handler software can tell from the setting of the ABTAK flag whether the message was actually aborted (ABTAK = 1) or sent (ABTAK = 0).

<sup>1.</sup> The transmit interrupt will occur only if not masked. A polling scheme can be applied on TXE also.

## 22.6 Identifier Acceptance Filter

A flexible, programmable generic identifier acceptance filter has been introduced to reduce the CPU interrupt loading. The filter is programmable to operate in three different modes:

- Single identifier acceptance filter to be applied to the full 29 bits of the identifier and to these bits of the CAN frame: RTR, IDE, and SRR. This mode implements a single filter for a full length CAN 2.0B compliant extended identifier.
- Double identifier acceptance filter to be applied to:
  - The 11 bits of the identifier and the RTR bit of CAN 2.0A messages or
  - The 14 most significant bits of the identifier of CAN 2.0B messages
- Quadruple identifier acceptance filter to be applied to the first eight bits of the identifier. This mode implements four independent filters for the first eight bits of a CAN 2.0A compliant standard identifier.

The identifier acceptance registers (CIAR) define the acceptable pattern of the standard or extended identifier (ID10–ID0 or ID28–ID0). Any of these bits can be marked don't care in the identifier mask register (CIMR).



Figure 22-3. Single 32-Bit Maskable Identifier Acceptance Filter

346

The background buffer, RxBG, will be copied into the foreground buffer, RxFG, and the RxF flag will be set only in case of an accepted identifier (an identifier acceptance filter hit). A hit also will cause a receiver interrupt if enabled.



Figure 22-4. Dual 16-Bit Maskable Acceptance Filters

A filter hit is indicated to the application software by a set RXF (receiver buffer full flag, see 22.14.5 MSCAN08 Receiver Flag Register) and two bits in the identifier acceptance control register (see 22.14.9 MSCAN08 Identifier Acceptance Control Register). These identifier hit flags (IDHIT1–IDHIT0) clearly identify the filter section that caused the acceptance. They simplify the application software's task to identify the cause of the receiver interrupt. When more than one hit occurs (two or more filters match), the lower hit has priority.

# **CAN Controller**

| ID28      | IDR0      | ID21    | ID20      | IDR1 | ID15 | ID14 | IDR2 | ID7 | ID6 | IDR3 | RTR |
|-----------|-----------|---------|-----------|------|------|------|------|-----|-----|------|-----|
| ID10      | IDR0      | ID3     | ID2       | IDR1 | IDE  |      |      |     |     |      |     |
|           |           |         |           |      |      |      |      |     |     |      |     |
| AC7       | CIDMR0    | AC0     |           |      |      |      |      |     |     |      |     |
|           |           |         |           |      |      |      |      |     |     |      |     |
| AC7       | CIDAR0    | AC0     |           |      |      |      |      |     |     |      |     |
|           |           |         |           | _    |      |      |      |     |     |      |     |
|           | ID ACCEPT | ED (FIL | TER 0 HIT | r)   |      |      |      |     |     |      |     |
|           |           |         |           |      |      |      |      |     |     |      |     |
| AC7       | CIDMR1    | AC0     |           |      |      |      |      |     |     |      |     |
|           |           |         |           |      |      |      |      |     |     |      |     |
| AC7       | CIDAR1    | AC0     |           |      |      |      |      |     |     |      |     |
|           |           |         |           |      |      |      |      |     |     |      |     |
|           | ID ACCEPT | ED (FIL | TER 1 HIT | Г)   | )    |      |      |     |     |      |     |
|           |           |         |           |      |      |      |      |     |     |      |     |
| AC7       | CIDMR2    | AC0     |           |      |      |      |      |     |     |      |     |
|           | _         |         | 1         |      |      |      |      |     |     |      |     |
| AC7       | CIDAR2    | AC0     |           |      |      |      |      |     |     |      |     |
| _         |           |         |           |      |      |      |      |     |     |      |     |
| $\square$ | ID ACCEPT | ED (FIL | TER 2 HI1 | Γ)   | )    |      |      |     |     |      |     |
|           |           |         |           |      |      |      |      |     |     |      |     |
| AC7       | CIDMR3    | AC0     |           |      |      |      |      |     |     |      |     |
|           | -         |         |           |      |      |      |      |     |     |      |     |
| AC7       | CIDAR3    | AC0     |           |      |      |      |      |     |     |      |     |
|           | $\sim$    |         |           |      | `    |      |      |     |     |      |     |
|           | ID ACCEPT | ed (fil | TER 3 HIT | Г)   | )    |      |      |     |     |      |     |



## 22.7 Interrupts

The MSCAN08 supports four interrupt vectors mapped onto eleven different interrupt sources, any of which can be individually masked for details see 22.14.5 MSCAN08 Receiver Flag Register to 22.14.8 MSCAN08 Transmitter Control Register.

- Transmit interrupt At least one of the three transmit buffers is empty (not scheduled) and can be loaded to schedule a message for transmission. The TXE flags of the empty message buffers are set.
- Receive interrupt A message has been received successfully and loaded into the foreground receive buffer. This interrupt will be emitted immediately after receiving the EOF symbol. The RXF flag is set.
- Wakeup interrupt An activity on the CAN bus occurred during MSCAN08 internal sleep mode.
- Error interrupt An overrun, error, or warning condition occurred. The receiver flag register (CRFLG) will indicate one of the following conditions:
  - Overrun An overrun condition as described in 22.5.2
    Receive Structures has occurred.
  - Receiver warning The receive error counter has reached the CPU Warning limit of 96.
  - Transmitter warning The transmit error counter has reached the CPU Warning limit of 96.
  - Receiver error passive The receive error counter has exceeded the error passive limit of 127 and MSCAN08 has gone to error passive state.
  - Transmitter error passive The transmit error counter has exceeded the error passive limit of 127 and MSCAN08 has gone to error passive state.
  - Bus off The transmit error counter has exceeded 255 and MSCAN08 has gone to bus off state.

#### 22.7.1 Interrupt Acknowledge

Interrupts are directly associated with one or more status flags in either the MSCAN08 receiver flag register (CRFLG) or the MSCAN08 transmitter control register (CTCR). Interrupts are pending as long as one of the corresponding flags is set. The flags in the above registers must be reset within the interrupt handler in order to handshake the interrupt. The flags are reset through writing a 1 to the corresponding bit position. A flag cannot be cleared if the respective condition still prevails.

**NOTE:** Bit manipulation instructions (BSET) shall not be used to clear interrupt flags. The OR instruction is the appropriate way to clear selected flags.

#### 22.7.2 Interrupt Vectors

The MSCAN08 supports four interrupt vectors as shown in **Table 22-1**. The vector addresses are dependent on the chip integration and to be defined. The relative interrupt priority is also integration dependent and to be defined.

| Function   | Source | Local<br>Mask | Global<br>Mask |  |
|------------|--------|---------------|----------------|--|
| Wakeup     | WUPIF  | WUPIE         |                |  |
|            | RWRNIF | RWRNIE        |                |  |
|            | TWRNIF | TWRNIE        |                |  |
| Error      | RERRIF | RERRIE        |                |  |
| interrupts | TERRIF | TERRIE        |                |  |
|            | BOFFIF | BOFFIE        | l bit          |  |
|            | OVRIF  | OVRIE         |                |  |
| Receive    | RXF    | RXFIE         | -              |  |
|            | TXE0   | TXEIE0        |                |  |
| Transmit   | TXE1   | TXEIE1        | -              |  |
|            | TXE2   | TXEIE2        |                |  |

Table 22-1. MSCAN08 Interrupt Vector Addresses

**CAN Controller** 

# 22.8 Protocol Violation Protection

The MSCAN08 will protect the user from accidentally violating the CAN protocol through programming errors. The protection logic implements these features:

- The receive and transmit error counters cannot be written or otherwise manipulated.
- All registers which control the configuration of the MSCAN08 can not be modified while the MSCAN08 is on-line. The SFTRES bit in the MSCAN08 module control register (see 22.14.1 MSCAN08 Module Control Register) serves as a lock to protect these registers:
  - MSCAN08 module control register 1 (CMCR1)
  - MSCAN08 bus timing register 0 and 1 (CBTR0 and CBTR1)
  - MSCAN08 identifier acceptance control register (CIDAC)
  - MSCAN08 identifier acceptance registers (CIDAR0–CIDAR3)
  - MSCAN08 identifier mask registers (CIDMR0–CIDMR3)
- The CANTx pin is forced to recessive if the CPU goes into stop mode.

## 22.9 Low-Power Modes

The WAIT and STOP instructions put the MCU in low powerconsumption stand-by mode.

#### 22.9.1 MSCAN08 Internal Sleep Mode

The CPU can request the MSCAN08 to enter the low-power mode by asserting the SLPRQ bit in the module configuration register (see Figure 22-6). This causes the MSCAN08 module internal clock to stop unless the module is active (such as receiving a message). The SLPAK bit indicates whether the MSCAN08 successfully went into sleep mode. The application software should use this flag as a handshake indication for the request to go into sleep mode. If not set after the request, the MSCAN08 is active and has not yet entered sleep mode. No wakeup interrupt will occur in that case.



Figure 22-6. Sleep Request/Acknowledge Cycle

When in sleep mode, the MSCAN08 stops its own clocks, leaving the MCU in normal run mode.

The MSCAN08 will leave sleep mode (wakeup) when bus activity occurs or when the MCU clears the SLPRQ bit.

The CANTx pin will stay in a recessive state while the MSCAN08 is in internal sleep mode.

**NOTE:** The MCU cannot clear the SLPRQ bit before the MSCAN08 is in sleep mode (SLPAK = 1).

## 22.9.2 CPU Wait Mode

The MSCAN08 module remains active during CPU wait mode. The MSCAN08 will stay synchronized to the CAN bus and will generate enabled transmit, receive, and error interrupts to the CPU. Any such interrupt will bring the MCU out of wait mode.

**Technical Data** 

#### 22.9.3 CPU Stop Mode

A CPU STOP instruction will stop the crystal oscillator, thus shutting down all system clocks. The user is responsible for ensuring that the MSCAN08 is not active when the CPU goes into stop mode. To protect the CAN bus system from fatal consequences of violations to this rule, the MSCAN08 will drive the CANTx pin into a recessive state.

The recommended procedure is to bring the MSCAN08 into sleep mode before the CPU STOP instruction is executed.

#### 22.9.4 Programmable Wakeup Function

The MSCAN08 can be programmed to apply a low-pass filter function to the CANRx input line while in internal sleep mode (see information on control bit WUPM in **22.14.1 MSCAN08 Module Control Register**). This feature can be used to protect the MSCAN08 from wakeup due to short glitches on the CAN bus lines. Such glitches can result from electromagnetic inference within noisy environments.

## 22.10 Timer Link

The MSCAN08 will generate a timer signal whenever a valid frame has been received. Because the CAN specification defines a frame to be valid if no errors occurred before the EOF field has been transmitted successfully, the timer signal will be generated right after the EOF. A pulse of one bit time is generated. As the MSCAN08 receiver engine also receives the frames being sent by itself, a timer signal also will be generated after a successful transmission.

The previously described timer signal can be routed into the on-chip timer interface module (TIM). Under the control of the timer link enable (TLNKEN) bit in the CMCR0 will this signal be connected to the timer n channel m input.

**NOTE:** The timer channel being used for the timer link is integration dependent.

After timer n has been programmed to capture rising edge events, it can be used to generate 16-bit time stamps which can be stored under software control with the received message.

# 22.11 Clock System

**Figure 22-7** shows the structure of the MSCAN08 clock generation circuitry and its interaction with the clock generation module (CGM). With this flexible clocking scheme the MSCAN08 is able to handle CAN bus rates ranging from 10 kbps up to 1 Mbps.



Figure 22-7. Clocking Scheme

The clock source flag (CLKSRC) in the MSCAN08 module control register (CMCR1) (see **22.14.1 MSCAN08 Module Control Register**) defines whether the MSCAN08 is connected to the output of the crystal oscillator or to the PLL output.

The MSCAN08 clock is used to generate the atomic unit of time handled by the MSCAN08: the time quantum. A bit time is subdivided into three segments defined here. For further explanation of the underlying concepts, refer to ISO/DIS 11519-1, Section 10.3.

- SYNC\_SEG This segment has a fixed length of one time quantum. Signal edges are expected to happen within this section.
- Time segment 1 This segment includes the PROP\_SEG and the PHASE\_SEG1 of the CAN standard. It can be programmed by setting the parameter TSEG1 to consist of 4 to 16 time quanta.
- Time segment 2 This segment represents PHASE\_SEG2 of the CAN standard. It can be programmed by setting the TSEG2 parameter to be 2 to 8 time quanta long.

The synchronization jump width (SJW) can be programmed in a range of 1 to 4 time quanta by setting the SJW parameter.

These parameters can be set by programming the bus timing registers, CBTR0–CBTR1, see **22.14.3 MSCAN08 Bus Timing Register 0** and **22.14.4 MSCAN08 Bus Timing Register 1**).

The user is responsible for making sure that the bit time settings comply with the CAN standard. **Table 22-2** gives an overview on the CAN conforming segment settings and the related parameter values.

## 22.12 Memory Map

The MSCAN08 occupies 128 bytes in the CPU08 memory space. The absolute mapping is implementation dependent with the base address being a multiple of 128. The background receive buffer can be read in test mode only.

**NOTE:** Due to design requirements, the absolute addresses and bit locations may change with later revisions of this specification.

MC68HC08QA24



Figure 22-8. Segments within the Bit Time

| Time<br>Segment 1 | TSEG1 | Time<br>Segment 2 | TSEG2 | Synchron.<br>Jump Width | SJW |
|-------------------|-------|-------------------|-------|-------------------------|-----|
| 5 10              | 49    | 2                 | 1     | 12                      | 01  |
| 4 11              | 310   | 3                 | 2     | 13                      | 02  |
| 5 12              | 411   | 4                 | 3     | 14                      | 03  |
| 6 13              | 5 12  | 5                 | 4     | 14                      | 03  |
| 7 14              | 6 13  | 6                 | 5     | 14                      | 03  |
| 8 15              | 714   | 7                 | 6     | 14                      | 03  |
| 9 16              | 8 15  | 8                 | 7     | 14                      | 03  |

Table 22-2. CAN Standard Compliant Bit Time Segment Settings

# 22.13 Programmer's Model of Message Storage

This section details the organization of the receive and transmit message buffers and the associated control registers. For reasons of programmer interface simplification, the receive and transmit message buffers have the same outline. Each message buffer allocates 16 bytes in the memory map containing a 13-byte data structure. An additional transmit buffer priority register (TBPR) is defined for the transmit buffers.

| Addr. | Register Name                                    |
|-------|--------------------------------------------------|
| xxx0  | IDENTIFIER REGISTER 0                            |
| xxx1  | IDENTIFIER REGISTER 1                            |
| xxx2  | IDENTIFIER REGISTER 2                            |
| xxx3  | IDENTIFIER REGISTER 3                            |
| xxx4  | DATA SEGMENT REGISTER 0                          |
| xxx5  | DATA SEGMENT REGISTER 1                          |
| xxx6  | DATA SEGMENT REGISTER 2                          |
| xxx7  | DATA SEGMENT REGISTER 3                          |
| xxx8  | DATA SEGMENT REGISTER 4                          |
| xxx9  | DATA SEGMENT REGISTER 5                          |
| xxxA  | DATA SEGMENT REGISTER 6                          |
| xxxB  | DATA SEGMENT REGISTER 7                          |
| xxxC  | DATA LENGTH REGISTER                             |
| xxxD  | TRANSMIT BUFFER PRIORITY REGISTER <sup>(1)</sup> |
| xxxE  | UNUSED                                           |
| xxxF  | UNUSED                                           |

1. Not applicable for receive buffers

## Figure 22-9. Message Buffer Organization

#### 22.13.1 Message Buffer Outline

**Figure 22-10** shows the common 13-byte data structure of receive and transmit buffers for extended identifiers. The mapping of standard identifiers into the IDR registers is shown in **Figure 22-1**. All bits of the 13-byte data structure are undefined out of reset.

| Addr.  | Register Name |                 | Bit 7 | 6         | 5       | 4      | 3      | 2    | 1    | Bit 0 |
|--------|---------------|-----------------|-------|-----------|---------|--------|--------|------|------|-------|
| \$xxx0 | IDR0          | Read:<br>Write: | ID28  | ID27      | ID26    | ID25   | ID24   | ID23 | ID22 | ID21  |
| \$xxx1 | IDR1          | Read:<br>Write: | ID20  | ID19      | ID16    | SRR(1) | IDE(1) | ID17 | ID16 | ID15  |
| \$xxx2 | IDR2          | Read:<br>Write: | ID14  | ID13      | ID12    | ID11   | ID10   | ID9  | ID8  | ID7   |
| \$xxx3 | IDR3          | Read:<br>Write: | ID6   | ID5       | ID4     | ID3    | ID2    | ID1  | ID0  | RTR   |
| \$xxx4 | DSR0          | Read:<br>Write: | DB7   | DB6       | DB5     | DB4    | DB3    | DB2  | DB1  | DB0   |
| \$xxx5 | DSR1          | Read:<br>Write: | DB7   | DB6       | DB5     | DB4    | DB3    | DB2  | DB1  | DB0   |
| \$xxx6 | DSR2          | Read:<br>Write: | DB7   | DB6       | DB5     | DB4    | DB3    | DB2  | DB1  | DB0   |
| \$xxx7 | DSR3          | Read:<br>Write: | DB7   | DB6       | DB5     | DB4    | DB3    | DB2  | DB1  | DB0   |
| \$xxx8 | DSR4          | Read:<br>Write: | DB7   | DB6       | DB5     | DB4    | DB3    | DB2  | DB1  | DB0   |
|        |               |                 |       | = Unimple | emented |        |        |      |      |       |

## Figure 22-10. Receive/Transmit Message Buffer Extended Identifier Registers

| Addr.           | Register Name  | Bit 7 | 6   | 5   | 4   | 3    | 2    | 1    | Bit 0 |
|-----------------|----------------|-------|-----|-----|-----|------|------|------|-------|
| \$xxx9          | DSR5<br>Write: | DB7   | DB6 | DB5 | DB4 | DB3  | DB2  | DB1  | DB0   |
| \$xxxA          | DSR6<br>Write: | DB7   | DB6 | DB5 | DB4 | DB3  | DB2  | DB1  | DB0   |
| \$xxxB          | DSR7<br>Write: | DB7   | DB6 | DB5 | DB4 | DB3  | DB2  | DB1  | DB0   |
| \$xxxC          | DLR<br>Write:  |       |     |     |     | DLC3 | DLC2 | DLC1 | DLC0  |
| = Unimplemented |                |       |     |     |     |      |      |      |       |

Figure 22-10. Receive/Transmit Message Buffer Extended Identifier Registers (Continued)



Figure 22-11. Standard Identifier Mapping

#### 22.13.2 Identifier Registers

The identifiers consist of either 11 bits (ID10–ID0) for the standard or 29 bits (ID28–ID0) for the extended format. ID10/28 is the most significant bit and is transmitted first on the bus during the arbitration procedure. The highest priority of an identifier is defined as the smallest binary number.

#### SRR — Substitute Remote Request Bit

This fixed recessive bit is used only in extended format. It must be set to 1 by the user for transmission buffers and will be stored as received on the CAN bus for receive buffers.

#### IDE — ID Extended Flag

This flag indicates whether the extended or standard identifier format is applied in this buffer. In case of a receive buffer, the flag is set as being received and indicates to the CPU how to process the buffer identifier registers. In case of a transmit buffer, the flag indicates to the MSCAN08 what type of identifier to send.

- 1 = Extended format, 29 bits
- 0 = Standard format, 11 bits

## RTR — Remote Transmission Request Flag

This flag reflects the status of the remote transmission request bit in the CAN frame. In case of a receive buffer, it indicates the status of the received frame and allows the transmission of an answering frame in software to be supported. In case of a transmit buffer, this flag defines the setting of the RTR bit to be sent.

- 1 = Remote frame
- 0 = Data frame
#### 22.13.3 Data Length Register

The data length register (DLR) keeps the data length field of the CAN frame.

#### DLC3–DLC0 — Data Length Code Bits

The data length code contains the number of bytes (data byte count) of the respective message. At transmission of a remote frame, the data length code is transmitted as programmed while the number of transmitted bytes is always 0. The data byte count ranges from 0 to 8 for a data frame. Table 22-3 shows the effect of setting the DLC bits.

|      | Data Length Code |      |      |                    |  |  |  |  |  |  |  |
|------|------------------|------|------|--------------------|--|--|--|--|--|--|--|
| DLC3 | DLC2             | DLC1 | DLC0 | Data Byte<br>Count |  |  |  |  |  |  |  |
| 0    | 0                | 0    | 0    | 0                  |  |  |  |  |  |  |  |
| 0    | 0                | 0    | 1    | 1                  |  |  |  |  |  |  |  |
| 0    | 0                | 1    | 0    | 2                  |  |  |  |  |  |  |  |
| 0    | 0                | 1    | 1    | 3                  |  |  |  |  |  |  |  |
| 0    | 1                | 0    | 0    | 4                  |  |  |  |  |  |  |  |
| 0    | 1                | 0    | 1    | 5                  |  |  |  |  |  |  |  |
| 0    | 1                | 1    | 0    | 6                  |  |  |  |  |  |  |  |
| 0    | 1                | 1    | 1    | 7                  |  |  |  |  |  |  |  |
| 1    | 0                | 0    | 0    | 8                  |  |  |  |  |  |  |  |

#### 22.13.4 Data Segment Registers

The eight data segment registers (DSRn) contain the data to be transmitted or received. The number of bytes to be transmitted or being received is determined by the data length code in the corresponding DLR.

#### 22.13.5 Transmit Buffer Priority Registers

| Address:        | \$xxxD |       |       |       |       |       |       |       |  |
|-----------------|--------|-------|-------|-------|-------|-------|-------|-------|--|
|                 | Bit 7  | 6     | 5     | 4     | 3     | 2     | 1     | Bit 0 |  |
| Read:<br>Write: | PRIO7  | PRIO6 | PRIO5 | PRIO4 | PRIO3 | PRIO2 | PRIO1 | PRIO0 |  |
| Reset:          | 0      | 0     | 0     | 0     | 0     | 0     | 0     | 0     |  |

Figure 22-12. Transmit Buffer Priority Register (TBPR)

#### PRIO7–PRIO0 — Local Priority Bits

This field defines the local priority of the associated message buffer. The local priority is used for the internal priorisation process of the MSCAN08 and is defined to be highest for the smallest binary number. The MSCAN08 implements the following internal priorisation mechanism:

- All transmission buffers with a cleared TXE flag participate in the prioritization right before the SOF is sent.
- The transmission buffer with the lowest local priority field wins the prioritization.
- In case more than one buffer has the same lowest priority, the message buffer with the lower index number wins.
- **NOTE:** To ensure data integrity, no registers of the transmit buffers shall be written while the associated TXE flag is cleared.

To ensure data integrity, no registers of the receive buffer shall be read while the RXF flag is cleared.

## 22.14 Programmer's Model of Control Registers

The programmer's model has been laid out for maximum simplicity and efficiency. **Figure 22-13** gives an overview on the control register block of the MSCAN08.

| Addr.  | Register Name                             |                 | Bit 7 | 6         | 5      | 4      | 3      | 2      | 1      | Bit 0   |
|--------|-------------------------------------------|-----------------|-------|-----------|--------|--------|--------|--------|--------|---------|
|        | CAN Module Control                        | Read:           | 0     | 0         | 0      | SYNCH  | TLNKEN | Slpak  | SLPRQ  | SFTRES  |
| \$0500 | Register 0                                | Write:          | R     | R         | R      | R      |        | R      | SLING  | SITTES  |
|        | (CMCR0)                                   | Reset:          | 0     | 0         | 0      | 0      | 0      | 0      | 0      | 0       |
|        | CAN Module Control                        | Read:           | 0     | 0         | 0      | 0      | 0      | LOOPB  | WUPM   | CLKSRC  |
| \$0501 | Register 1<br>(CMCR1)                     | Write:          | R     | R         | R      | R      | R      | 2001 0 | WOT M  | GERGING |
|        | (CINCR I)                                 | Reset:          | 0     | 0         | 0      | 0      | 0      | 0      | 0      | 0       |
| \$0502 | CAN Bus Timing Register 0<br>(CBTR0)      | Read:<br>Write: | SJW1  | SJW0      | BRP5   | BRP4   | BRP3   | BRP2   | BRP1   | BRP0    |
|        | , , , , , , , , , , , , , , , , , , ,     | Reset:          | 0     | 0         | 0      | 0      | 0      | 0      | 0      | 0       |
| \$0503 | CAN Bus Timing Register 1<br>(CBTR1)      | Read:<br>Write: | SAMP  | TSEG22    | TSEG21 | TSEG20 | TSEG13 | TSEG12 | TSEG11 | TSEG10  |
|        |                                           | Reset:          | 0     | 0         | 0      | 0      | 0      | 0      | 0      | 0       |
| \$0504 | CAN Receiver Flag Register<br>(CRFLG)     | Read:<br>Write: | WUPIF | RWRNIF    | TWRNIF | RERRIF | TERRIF | BOFFIF | OVRIF  | RXF     |
|        |                                           | Reset:          | 0     | 0         | 0      | 0      | 0      | 0      | 0      | 0       |
| \$0505 | CAN Receiver Interrupt<br>Enable Register | Read:<br>Write: | WUPIE | RWRNIE    | TWRNIE | RERRIE | TERRIE | BOFFIE | OVRIE  | RXFIE   |
|        | (CRIER)                                   | Reset:          | 0     | 0         | 0      | 0      | 0      | 0      | 0      | 0       |
|        | CAN Transmitter                           | Read:           | 0     | ABTAK2    | ABTAK1 | ABTAK0 | 0      | TXE2   | TXE1   | TXE0    |
| \$0506 | Flag Register                             | Write:          | R     | R         | R      | R      | R      | INEZ   |        | INEO    |
|        | (CTFLG)                                   | Reset:          | 0     | 0         | 0      | 0      | 0      | 1      | 1      | 1       |
|        |                                           |                 | R     | = Reserve | ed     |        |        |        |        |         |

Figure 22-13. MSCAN08 Control Register Struture (Sheet 1 of 3)

## **CAN Controller**

| Addr.  | Register Name                           |                 | Bit 7  | 6         | 5      | 4          | 3          | 2      | 1      | Bit 0  |
|--------|-----------------------------------------|-----------------|--------|-----------|--------|------------|------------|--------|--------|--------|
| \$0507 | CAN Transmitter<br>Control Register     | Read:<br>Write: | 0<br>R | ABTRQ2    | ABTRQ1 | ABTRQ0     | 0<br>R     | TXEIE2 | TXEIE1 | TXEIE0 |
|        | (CTCR)                                  | Reset:          | 0      | 0         | 0      | 0          | 0          | 1      | 1      | 1      |
| ¢AEAO  | CAN Identifier Acceptance               | Read:           | 0      | 0         |        |            | 0          | 0      | IDHIT1 | IDHIT0 |
| \$0508 | Control Register                        | Write:          | R      | R         | IDAM1  | DAM1 IDAM0 | R          | R      | R      | R      |
|        | (CIDAC)                                 | Reset:          | 0      | 0         | 0      | 0          | 0          | 0      | 0      | 0      |
|        | CAN Receiver Error                      | Read:           | RXERR7 | RXERR6    | RXERR5 | RXERR4     | RXERR3     | RXERR2 | RXERR1 | RXERR0 |
| \$050E | Counter Register                        | Write:          | R      | R         | R      | R          | R          | R      | R      | R      |
|        | (CRXERR)                                | Reset:          | 0      | 0         | 0      | 0          | 0          | 0      | 0      | 0      |
|        | CAN Transmitter Error                   | Read:           | TXERR7 | TXERR6    | TXERR5 | TXERR4     | TXERR3     | TXERR2 | TXERR1 | TXERR0 |
| \$050F | 050F Counter Register                   | Write:          | R      | R         | R      | R          | R          | R      | R      | R      |
|        | (CTXERR)                                | Reset:          | 0      | 0         | 0      | 0          | 0          | 0      | 0      | 0      |
| \$0510 | CAN Identifier Acceptance<br>Register 0 | Read:<br>Write: | AC7    | AC6       | AC5    | AC4        | AC3        | AC2    | AC1    | AC0    |
|        | (CIDAR0)                                | Reset:          |        |           |        | Unaffected | d by reset |        |        |        |
| \$0511 | CAN Identifier Acceptance<br>Register 1 | Read:<br>Write: | AC7    | AC6       | AC5    | AC4        | AC3        | AC2    | AC1    | AC0    |
|        | (CIDAR1)                                | Reset:          |        |           |        | Unaffected | d by reset |        |        |        |
| \$0512 | CAN Identifier Acceptance<br>Register 2 | Read:<br>Write: | AC7    | AC6       | AC5    | AC4        | AC3        | AC2    | AC1    | AC0    |
|        | (CIDAR2)                                | Reset:          |        |           |        | Unaffected | d by reset |        |        |        |
| \$0513 | CAN Identifier Acceptance<br>Register 3 | Read:<br>Write: | AC7    | AC6       | AC5    | AC4        | AC3        | AC2    | AC1    | AC0    |
|        | (CIDAR3)                                |                 |        | •         |        | Unaffected | d by reset |        |        |        |
| \$0514 | CAN Identifier Mask<br>Register 0       |                 | AM7    | AM6       | AM5    | AM4        | AM3        | AM2    | AM1    | AMO    |
|        | (CIDMR0)                                | Reset:          |        | 1         |        | Unaffected | d by reset |        |        |        |
|        |                                         |                 | R      | = Reserve | ed     |            |            |        |        |        |

Figure 22-13. MSCAN08 Control Register Struture (Sheet 2 of 3)

| Addr.  | Register Name                            | Bit 7               | 6                   | 5   | 4          | 3          | 2   | 1   | Bit 0 |  |  |
|--------|------------------------------------------|---------------------|---------------------|-----|------------|------------|-----|-----|-------|--|--|
| \$0515 | CAN Identifier Mask<br>Register 1 Write: | AM7                 | AM6                 | AM5 | AM4        | AM3        | AM2 | AM1 | AM0   |  |  |
|        | (CIDMR1) Reset:                          |                     | Unaffected by reset |     |            |            |     |     |       |  |  |
| \$0516 | CAN Identifier Mask<br>Register 0 Write: | AM7                 | AM6                 | AM5 | AM4        | AM3        | AM2 | AM1 | AM0   |  |  |
|        | (CIDMR0) Reset:                          | Unaffected by reset |                     |     |            |            |     |     |       |  |  |
| \$0517 | CAN Identifier Mask<br>Register 1 Write: | AM7                 | AM6                 | AM5 | AM4        | AM3        | AM2 | AM1 | AM0   |  |  |
|        | (CIDMR1) CIDMR1 Reset:                   |                     |                     |     | Unaffected | d by reset |     |     |       |  |  |
|        |                                          | R                   | ] = Reserve         | ed  |            |            |     |     |       |  |  |



#### 22.14.1 MSCAN08 Module Control Register

| Address: | \$0500 |           |   |       |        |       |        |        |
|----------|--------|-----------|---|-------|--------|-------|--------|--------|
|          | Bit 7  | 6         | 5 | 4     | 3      | 2     | 1      | Bit 0  |
| Read:    | 0      | 0         | 0 | SYNCH | TLNKEN | SLPAK | SLPRQ  | SFTRES |
| Write:   | R      | R         | R | R     |        | R     | JLF NU | SETTES |
| Reset:   | 0      | 0         | 0 | 0     | 0      | 0     | 0      | 0      |
|          | R      | = Reserve | d |       |        |       |        |        |

#### Figure 22-14. CAN Module Control Register 0 (CMCR0)

#### SYNCH — Synchronized Status Bit

This bit indicates whether the MSCAN08 is synchronized to the CAN bus and as such can participate in the communication process.

- 1 = MSCAN08 synchronized to the CAN bus
- 0 = MSCAN08 not synchronized to the CAN bus

TLNKEN — Timer Enable Flag

This flag is used to establish a link between the MSCAN08 and the on-chip timer (see **22.10 Timer Link**).

- 1 = The MSCAN08 timer signal output is connected to the timer.
- 0 = No connection

#### SLPAK — Sleep Mode Acknowledge Flag

This flag indicates whether the MSCAN08 is in module internal sleep mode. It shall be used as a handshake for the sleep mode request (see **22.9.1 MSCAN08 Internal Sleep Mode**).

- 1 = Sleep MSCAN08 in internal sleep mode
- 0 = Wakeup MSCAN08 will function normally
- SLPRQ Sleep Request, Go to Internal Sleep Mode Flag

This flag allows a request for the MSCAN08 to go into an internal power-saving mode (see **22.9.1 MSCAN08 Internal Sleep Mode**).

- 1 = Sleep The MSCAN08 will go into internal sleep mode if and as long as there is no activity on the bus.
- 0 = Wakeup The MSCAN08 will function normally. If SLPAK is cleared by the CPU, then the MSCAN08 will wake up, but will not issue a wakeup interrupt.

#### SFTRES — Soft Reset Bit

When this bit is set by the CPU, the MSCAN08 immediately enters the soft reset state. Any ongoing transmission or reception is aborted and synchronization to the bus is lost.

These registers will go into the same state as out of hard reset: CMCR0, CRFLG, CRIER, CTFLG, and CTCR.

The registers CMCR1, CBTR0, CBTR1, CIDAC, CIDAR0–CIDAR3, and CIDMR0–CIDMR3 can be written only by the CPU when the MSCAN08 is in soft reset state. The values of the error counters are not affected by soft reset.

When this bit is cleared by the CPU, the MSCAN08 will try to synchronize to the CAN bus. If the MSCAN08 is not in bus-off state, it will be synchronized after 11 recessive bits on the bus; if the MSCAN08 is in bus-off state, it continues to wait for 128 occurrences of 11 recessive bits.

- 1 = MSCAN08 in soft reset state
- 0 = Normal operation

#### 22.14.2 MSCAN08 Module Control Register



Figure 22-15. CAN Module Control Register 1 (CMCR1)

#### LOOPB — Loop Back Self-Test Mode Bit

When this bit is set, the MSCAN08 performs an internal loop back which can be used for self-test operation and the bit stream output of the transmitter is fed back to the receiver. The CANRx input pin is ignored and the CANTx output goes to the recessive state (1). Note that in this state, the MSCAN08 ignores the ACK bit to ensure proper reception of its own message and will treat messages being received while in transmission as received messages from remote nodes.

- 1 = Activate loop back self-test mode
- 0 = Normal operation
- WUPM Wakeup Mode Flag

This flag defines whether the integrated low-pass filter is applied to protect the MSCAN08 from spurious wakeups (see 22.9.4

#### Programmable Wakeup Function).

- 1 = MSCAN08 will wake up the CPU only in cases of a dominant pulse on the bus which has a length of at least  $t_{wup}$ .
- 0 = MSCAN08 will wake up the CPU after any recessive to dominant edge on the CAN bus.
- CLKSRC Clock Source Flag

This flag defines which clock source the MSCAN08 module is driven from (see **22.11 Clock System**).

- 1 = The MSCAN08 clock source is CGMOUT (see Figure 22-7).
- 0 = The MSCAN08 clock source is CGMXCLK/2 (see Figure 22-7).
- **NOTE:** The CMCR1 register can be written only if the SFTRES bit in the MSCAN08 module control register is set

MC68HC08QA24

#### 22.14.3 MSCAN08 Bus Timing Register 0

| Address:        | \$0502 |      |      |      |      |      |      |       |
|-----------------|--------|------|------|------|------|------|------|-------|
|                 | Bit 7  | 6    | 5    | 4    | 3    | 2    | 1    | Bit 0 |
| Read:<br>Write: | SJW1   | SJW0 | BRP5 | BRP4 | BRP3 | BRP2 | BRP1 | BRP0  |
| Reset:          | 0      | 0    | 0    | 0    | 0    | 0    | 0    | 0     |

#### Figure 22-16. CAN Bus Timing Register 0 (CBTR0)

SJW1 and SJW0 — Synchronization Jump Width Bits

The synchronization jump width (SJW) defines the maximum number of system clock ( $t_{SCL}$ ) cycles by which a bit may be shortened, or lengthened, to achieve resynchronization on data transitions on the bus (see Table 22-4).

Table 22-4. Synchronization Jump Width

| SJW1 | SJW0 | Synchronization Jump Width |
|------|------|----------------------------|
| 0    | 0    | 1 t <sub>SCL</sub> cycle   |
| 0    | 1    | 2 t <sub>SCL</sub> cycles  |
| 1    | 0    | 3 t <sub>SCL</sub> cycles  |
| 1    | 1    | 4 t <sub>SCL</sub> cycles  |

BRP5-BRP0 — Baud Rate Prescaler Bits

These bits determine the MSCAN08 system clock cycle time ( $t_{SCL}$ ), which is used to build up the individual bit timing, according to **Table 22-5**.

| BRP5 | BRP4 | BRP3 | BRP2 | BRP1 | BRP0 | Prescaler Value (P) |
|------|------|------|------|------|------|---------------------|
| 0    | 0    | 0    | 0    | 0    | 0    | 1                   |
| 0    | 0    | 0    | 0    | 0    | 1    | 2                   |
| 0    | 0    | 0    | 0    | 1    | 0    | 3                   |
| 0    | 0    | 0    | 0    | 1    | 1    | 4                   |
| :    | :    | :    | :    | :    | :    | :                   |
| :    | :    | :    | :    | :    | :    | :                   |
| 1    | 1    | 1    | 1    | 1    | 1    | 64                  |

**NOTE:** The CBTR0 register can be written only if the SFTRES bit in the MSCAN08 module control register is set.

#### 22.14.4 MSCAN08 Bus Timing Register 1

| Address:        | \$0503 |        |        |        |        |        |        |        |
|-----------------|--------|--------|--------|--------|--------|--------|--------|--------|
|                 | Bit 7  | 6      | 5      | 4      | 3      | 2      | 1      | Bit 0  |
| Read:<br>Write: | SAMP   | TSEG22 | TSEG21 | TSEG20 | TSEG13 | TSEG12 | TSEG11 | TSEG10 |
| Reset:          | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |

#### Figure 22-17. CAN Bus Timing Register 1 (CBTR1)

#### SAMP — Sampling Bit

This bit determines the number of serial bus samples to be taken per bit time. If set, three samples per bit are taken, the regular one (sample point) and two preceding samples, using a majority rule. For higher bit rates, SAMP should be cleared, which means that only one sample will be taken per bit.

- 1 = Three samples per bit
- 0 = One sample per bit

#### TSEG22–TSEG20 and TSEG13–TSEG10 — Time Segment Bits

Time segments within the bit time fix the number of clock cycles per bit time and the location of the sample point.

| Time Segment   | Action                                                                                                                                                                    |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SYNC_SEG       | System expects transitions to occur on the bus during this period.                                                                                                        |
| Transmit point | A node in transmit mode will transfer a new value to the CAN bus at this point.                                                                                           |
| Sample point   | A node in receive mode will sample the bus at this point. If<br>the three samples per bit option are selected, then this<br>point marks the position of the third sample. |

Time segment 1 (TSEG1) and time segment 2 (TSEG2) are programmable as shown in **Table 22-7** and **Table 22-8**, respectively.

MC68HC08QA24

| TSEG13 | TSEG12 | TSEG11 | TSEG10 | Time<br>Segment 1          |
|--------|--------|--------|--------|----------------------------|
| 0      | 0      | 0      | 0      | 1 t <sub>SCL</sub> cycle   |
| 0      | 0      | 0      | 1      | 2 t <sub>SCL</sub> cycles  |
| 0      | 0      | 1      | 0      | 3 t <sub>SCL</sub> cycles  |
| 0      | 0      | 1      | 1      | 4 t <sub>SCL</sub> cycles  |
|        |        |        |        |                            |
|        |        |        |        |                            |
| 1      | 1      | 1      | 1      | 16 t <sub>SCL</sub> cycles |

 Table 22-7. Time Segment 1 Values

Table 22-8. Time Segment 2 Values

| TSEG22 | TSEG21 | TSEG20 | Time<br>Segment 2         |
|--------|--------|--------|---------------------------|
| 0      | 0      | 0      | 1 t <sub>SCL</sub> cycle  |
| 0      | 0      | 1      | 2 t <sub>SCL</sub> cycles |
|        |        |        |                           |
|        |        |        |                           |
| 1      | 1      | 1      | 8 t <sub>SCL</sub> cycles |

The bit time is determined by the oscillator frequency, the baud rate prescaler, and the number of bus clock cycles ( $t_{SCL}$ ) per bit as shown in Table 22-7 and Table 22-8.

**NOTE:** The CBTR1 register can be written only if the SFTRES bit in the MSCAN08 module control register is set.

#### 22.14.5 MSCAN08 Receiver Flag Register

All bits of this register are read and clear only. A flag can be cleared by writing a 1 to the corresponding bit position. A flag can be cleared only when the condition which caused the setting is valid no more. Writing a 0 has no effect on the flag setting. Every flag has an associated interrupt enable flag in the CRIER register. A hard or soft reset will clear the register.



|        | Bit 7 | 6      | 5      | 4      | 3      | 2      | 1     | Bit 0 |
|--------|-------|--------|--------|--------|--------|--------|-------|-------|
| Read:  | WUPIF | RWRNIF | TWRNIF | RERRIF | TERRIF | BOFFIF | OVRIF | RXF   |
| Write: | WUPIF | RWRINF |        | KEKKIF | IERRIF | DUFFIF | UVRIF | КАГ   |
| Reset: | 0     | 0      | 0      | 0      | 0      | 0      | 0     | 0     |

Figure 22-18. CAN Receiver Flag Register (CRFLG)

#### WUPIF — Wakeup Interrupt Flag

If the MSCAN08 detects bus activity while it is asleep, it clears the SLPAKSLPAK bit in the CMCR0 register; the WUPIF bit will then be set. If not masked, a wakeup interrupt is pending while this flag is set.

- 1 = MSCAN08 has detected activity on the bus and requested wake up.
- 0 = No wake up interrupt has occurred.

RWRNIF — Receiver Warning Interrupt Flag

This bit will be set when the MSCAN08 went into warning status because the receive error counter was in the range of 96 to 127. If not masked, an error interrupt is pending while this flag is set.

1 = MSCAN08 went into warning status.

0 = No warning interrupt has occurred.

TWRNIF — Transmitter Warning Interrupt Flag

This bit will be set when the MSCAN08 went into warning status because the transmit error counter was in the range of 96 to 127. If not masked, an error interrupt is pending while this flag is set.

1 = MSCAN08 went into warning status.

0 = No warning interrupt has occurred.

#### RERRIF — Receiver Error Passive Interrupt Flag

This bit will be set when the MSCAN08 went into error passive status because the receive error counter exceeded 127. If not masked, an error interrupt is pending while this flag is set.

1 = MSCAN08 went into error passive status.

0 = No warning interrupt has occurred.

#### TERRIF — Transmitter Error Passive Interrupt Flag

This bit will be set when the MSCAN08 went into error passive status due to the transmit error counter exceeding 127. If not masked, an error interrupt is pending while this flag is set.

1 = MSCAN08 went into error passive status.

0 = No warning interrupt has occurred.

#### BOFFIF — Bus-Off Interrupt Flag

This bit will be set when the MSCAN08 went into bus-off status, because the transmit error counter exceeded 255. If not masked, an error interrupt is pending while this flag is set.

1 = MSCAN08 went into warning status.

0 = No warning interrupt has occurred.

#### OVRIF — Overrun Interrupt Flag

This bit will be set when a data overrun condition occurred. If not masked, an error interrupt is pending while this flag is set.

1 = A data overrun has been detected.

0 = No data overrun has occurred.

#### RXF — Receive Buffer Full Flag

The RXF flag is set by the MSCAN08 when a new message is available in the foreground receive buffer. This flag indicates whether the buffer is loaded with a correctly received message. After the CPU has read that message from the receive buffer, the RXF flag must be handshaked to release the buffer. A set RXF flag prohibits the exchange of the background receive buffer into the foreground buffer. In that case the MSCAN08 will signal an overload condition. If not masked, a receive interrupt is pending while this flag is set.

1 = The receive buffer is full. A new message is available.

0 = The receive buffer is released (not full).

#### 22.14.6 MSCAN08 Receiver Interrupt Enable Register

Addrossy \$0505

| Audress.        | \$0202 |        |        |        |        |        |       |       |
|-----------------|--------|--------|--------|--------|--------|--------|-------|-------|
|                 | Bit 7  | 6      | 5      | 4      | 3      | 2      | 1     | Bit 0 |
| Read:<br>Write: | WUPIE  | RWRNIE | TWRNIE | RERRIE | TERRIE | BOFFIE | OVRIE | RXFIE |
| Reset:          | 0      | 0      | 0      | 0      | 0      | 0      | 0     | 0     |

#### Figure 22-19. CAN Receiver Interrupt Enable Register (CRIER)

#### WUPIE — Wakeup Interrupt Enable Bit

- 1 = A wakeup event will result in a wakeup interrupt.
- 0 = No interrupt will be generated from this event.

RWRNIE — Receiver Warning Interrupt Enable Bit

- 1 = A receiver warning status event will result in an error interrupt.
- 0 = No interrupt will be generated from this event.
- TWRNIE Transmitter Warning Interrupt Enable Bit
  - 1 = A transmitter warning status event will result in an error interrupt.
  - 0 = No interrupt will be generated from this event.

#### RERRIE — Receiver Error Passive Interrupt Enable Bit

- 1 = A receiver error passive status event will result in an error interrupt.
- 0 = No interrupt will be generated from this event.

#### TERRIE — Transmitter Error Passive Interrupt Enable Bit

- 1 = A transmitter error passive status event will result in an error interrupt.
- 0 = No interrupt will be generated from this event.

#### BOFFIE — Bus-Off Interrupt Enable Bit

- 1 = A bus-off event will result in an error interrupt.
- 0 = No interrupt will be generated from this event.

#### OVRIE — Overrun Interrupt Enable Bit

- 1 = An overrun event will result in an error interrupt.
- 0 = No interrupt will be generated from this event.
- RXFIE Receiver Full Interrupt Enable Bit
  - 1 = A receive buffer full (successful message reception) event will result in a receive interrupt.
  - 0 = No interrupt will be generated from this event.

#### 22.14.7 MSCAN08 Transmitter Flag Register

All bits of this register are read and clear only. A flag can be cleared by writing a 1 to the corresponding bit position. Writing a 0 has no effect on the flag setting. Every flag has an associated interrupt enable flag in the CTCR register. A hard or soft reset will clear the register.

| Address: | \$0506       |        |        |        |   |      |      |       |  |  |  |
|----------|--------------|--------|--------|--------|---|------|------|-------|--|--|--|
|          | Bit 7        | 6      | 5      | 4      | 3 | 2    | 1    | Bit 0 |  |  |  |
| Read:    | 0            | ABTAK2 | ABTAK1 | ABTAK0 | 0 | TXE2 | TXE1 | TXE0  |  |  |  |
| Write:   | R            | R      | R      | R      | R | INEZ | IAEI | TAEU  |  |  |  |
| Reset:   | 0            | 0      | 0      | 0      | 0 | 1    | 1    | 1     |  |  |  |
| [        | R = Reserved |        |        |        |   |      |      |       |  |  |  |

Figure 22-20. CAN Transmitter Flag Register (CTFLG)

ABTAK2-ABTAK0 — Abort Acknowledge Flag

This flag acknowledges that a message has been aborted due to a pending abort request from the CPU. After a particular message buffer has been flagged empty, this flag can be used by the application software to identify whether the message has been aborted successfully or has been sent. The flag is reset implicitly whenever the associated TXE flag is set to 0.

- 1 = The message has been aborted.
- 0 = The message has not been aborted, thus has been sent out.

### TXE2–TXE0 — Transmitter Empty Flag

This flag indicates that the associated transmit message buffer is empty, thus not scheduled for transmission. The CPU must handshake (clear) the flag after a message has been set up in the transmit buffer and is due for transmission. The MSCAN08 will set the flag after the message has been sent successfully. The flag also will be set by the MSCAN08 when the transmission request was successfully aborted due to a pending abort request (see 22.13.5 Transmit Buffer Priority Registers). If not masked, a receive interrupt is pending while this flag is set.

A reset of this flag also will reset the abort acknowledge (ABTAK) and the abort request (ABTRQ) flags of the particular buffer. See **22.14.8 MSCAN08 Transmitter Control Register**.

- 1 = The associated message buffer is empty (not scheduled).
- 0 = The associated message buffer is full (loaded with a message due for transmission).



#### 22.14.8 MSCAN08 Transmitter Control Register



#### ABTRQ2-ABTRQ0 - Abort Request Flags

The CPU sets this flag to request that an already scheduled message buffer (TXE = 0) be aborted. The MSCAN08 will grant the request when the message is not already under transmission. When a message is aborted the associated TXE and the abort acknowledge flag (ABTAK) (see 22.14.7 MSCAN08 Transmitter Flag Register)

will be set and an TXE interrupt will occur if enabled. The CPU cannot reset this flag. The flag is reset implicitly whenever the associated TXE flag is set.

- 1 = Abort request pending
- 0 = No abort request

TXEIE2-TXEIE0 — Transmitter Empty Interrupt Enable Bits

- 1 = A transmitter empty (transmit buffer available for transmission) event will result in a transmitter empty interrupt.
- 0 = No interrupt will be generated from this event.

#### 22.14.9 MSCAN08 Identifier Acceptance Control Register



Control Register (CIDAC)

IDAM1–IDAM0— Identifier Acceptance Mode Flags

The CPU sets these flags to define the identifier acceptance filter organization (see **22.6 Identifier Acceptance Filter**). **Table 22-7** summarizes the different settings. In "filter closed" mode no messages will be accepted so that the foreground buffer will never be reloaded.

| IDAM1 | IDAM0 | Identifier Acceptance Mode      |
|-------|-------|---------------------------------|
| 0     | 0     | Single 32-bit acceptance filter |
| 0     | 1     | Two 16-bit acceptance filter    |
| 1     | 0     | Four 8-bit acceptance filters   |
| 1     | 1     | Filter closed                   |

 Table 22-9. Identifier Acceptance Mode Settings

IDHIT1–IDHIT0— Identifier Acceptance Hit Indicator Flags

The MSCAN08 sets these flags to indicate an identifier acceptance hit (see **22.6 Identifier Acceptance Filter**). **Table 22-7** summarizes the different settings.

 Table 22-10. Identifier Acceptance Hit Indication

| IDHIT1 | IDHIT0 | Identifier Acceptance Hit |
|--------|--------|---------------------------|
| 0      | 0      | Filter 0 hit              |
| 0      | 1      | Filter 1 hit              |
| 1      | 0      | Filter 2 hit              |
| 1      | 1      | Filter 3 hit              |

The IDHIT indicators are always related to the message in the foreground buffer. When a message gets copied from the background to the foreground buffer, the indicators are updated as well.

**NOTE:** The CIDAC register can be written only if the SFTRES bit in the MSCAN08 module control register is set.

## 22.14.10 MSCAN08 Receive Error Counter Register

| Address: | \$050E       |        |        |        |        |        |        |        |  |  |
|----------|--------------|--------|--------|--------|--------|--------|--------|--------|--|--|
|          | Bit 7        | 6      | 5      | 4      | 3      | 2      | 1      | Bit 0  |  |  |
| Read:    | RXERR7       | RXERR6 | RXERR5 | RXERR4 | RXERR3 | RXERR2 | RXERR1 | RXERR0 |  |  |
| Write:   | R            | R      | R      | R      | R      | R      | R      | R      |  |  |
| Reset:   | 0            | 0      | 0      | 0      | 0      | 0      | 0      | 0      |  |  |
|          | R = Reserved |        |        |        |        |        |        |        |  |  |

#### Figure 22-23. CAN Receiver Error Counter Register (CRXERR)

This register reflects the status of the MSCAN08 receive error counter. The register is read only.

#### 22.14.11 MSCAN08 Transmit Error Counter Register

| Address: | \$050F       |        |        |        |        |        |        |        |  |
|----------|--------------|--------|--------|--------|--------|--------|--------|--------|--|
|          | Bit 7        | 6      | 5      | 4      | 3      | 2      | 1      | Bit 0  |  |
| Read:    | TXERR7       | TXERR6 | TXERR5 | TXERR4 | TXERR3 | TXERR2 | TXERR1 | TXERR0 |  |
| Write:   | R            | R      | R      | R      | R      | R      | R      | R      |  |
| Reset:   | 0            | 0      | 0      | 0      | 0      | 0      | 0      | 0      |  |
|          | R = Reserved |        |        |        |        |        |        |        |  |

#### Figure 22-24. CAN Transmit Error Counter Register (CTXERR)

This register reflects the status of the MSCAN08 transmit error counter. The register is read only.

**NOTE:** For both error counters, there is no hardware synchronization between the write accesses to those registers from the MSCAN08 side and the read accesses by the CPU. It is the user's responsibility to verify that a stable value has been read by executing a second validation read and comparing the two values.

MC68HC08QA24

#### 22.14.12 MSCAN08 Identifier Acceptance Registers

On reception each message is written into the background receive buffer. The CPU is only signalled to read the message. However, if it passes the criteria in the identifier acceptance and identifier mask registers (accepted); otherwise, the message will be overwritten by the next message (dropped).

The acceptance registers of the MSCAN08 are applied on the IDR0 to IDR3 registers of incoming messages in a bit by bit manner.

For extended identifiers, all four acceptance and mask registers are applied. For standard identifiers only the first two (IDAR0 and IDAR1) are applied. In the latter case, the mask register, CIDMR1, the three last bits (AC2–AC0) must be programmed to don't care.

| Register Name and Address: CIDAR0 — \$0510 |       |                     |     |           |            |     |     |       |  |
|--------------------------------------------|-------|---------------------|-----|-----------|------------|-----|-----|-------|--|
|                                            | Bit 7 | 6                   | 5   | 4         | 3          | 2   | 1   | Bit 0 |  |
| Read:<br>Write:                            | AC7   | AC6                 | AC5 | AC4       | AC3        | AC2 | AC1 | AC0   |  |
| Reset:                                     |       |                     | -   | Unaffecte | d by reset |     |     |       |  |
| Register Name and Address: CIDAR1 — \$0511 |       |                     |     |           |            |     |     |       |  |
|                                            | Bit 7 | 6                   | 5   | 4         | 3          | 2   | 1   | Bit 0 |  |
| Read:<br>Write:                            | AC7   | AC6                 | AC5 | AC4       | AC3        | AC2 | AC1 | AC0   |  |
| Reset:                                     |       | Unaffected by reset |     |           |            |     |     |       |  |

Figure 22-25. CAN Identifier Acceptance Registers (CIDAR0–CIDAR3)

## **CAN Controller**

|                                                                       | Bit 7               | 6   | 5   | 4         | 3          | 2   | 1   | Bit 0 |  |
|-----------------------------------------------------------------------|---------------------|-----|-----|-----------|------------|-----|-----|-------|--|
| Read:<br>Write:                                                       | AC7                 | AC6 | AC5 | AC4       | AC3        | AC2 | AC1 | AC0   |  |
| Reset:                                                                |                     |     |     | Unaffecte | d by reset |     |     |       |  |
| Register Name and Address: CIDAR3 — \$0513<br>Bit 7 6 5 4 3 2 1 Bit 0 |                     |     |     |           |            |     |     |       |  |
| Read:<br>Write:                                                       | AC7                 | AC6 | AC5 | AC4       | AC3        | AC2 | AC1 | AC0   |  |
| Reset:                                                                | Unaffected by reset |     |     |           |            |     |     |       |  |

Register Name and Address: CIDAR2 — \$0512

### Figure 22-25. CAN Identifier Acceptance Registers (CIDAR0–CIDAR3) (Continued)

AC7-AC0 — Acceptance Code Bits

AC7–AC0 comprise a user-defined sequence of bits with which the corresponding bits of the related identifier register (IDRn) of the receive message buffer are compared. The result of this comparison is then masked with the corresponding identifier mask register.

**NOTE:** The CIDAR0–CIDAR3 registers can be written only if the SFTRES bit in the MSCAN08 module control register is set.

#### 22.14.13 MSCAN08 Identifier Mask Registers

The identifier mask registers specify which of the corresponding bits in the identifier acceptance register are relevant for acceptance filtering.

|                                                                                  | Dit 7                               | 4                                 | E                                  | 4                                                              | 2                                   | 2               | 1        | Dit O        |
|----------------------------------------------------------------------------------|-------------------------------------|-----------------------------------|------------------------------------|----------------------------------------------------------------|-------------------------------------|-----------------|----------|--------------|
| Г                                                                                | Bit 7                               | 6                                 | 5                                  | 4                                                              | 3                                   | 2               | 1        | Bit 0        |
| Read:                                                                            | AM7                                 | AM6                               | AM5                                | AM4                                                            | AM3                                 | AM2             | AM1      | AMO          |
| Write:                                                                           |                                     |                                   |                                    |                                                                |                                     |                 |          |              |
| Reset:                                                                           |                                     |                                   |                                    | Unaffecte                                                      | ed by reset                         |                 |          |              |
| egister Na                                                                       | ame and Ac                          | ddress: C                         | IDMR1 — \$                         | 0515                                                           |                                     |                 |          |              |
|                                                                                  | Bit 7                               | 6                                 | 5                                  | 4                                                              | 3                                   | 2               | 1        | Bit 0        |
| Read:                                                                            |                                     |                                   |                                    |                                                                |                                     |                 |          |              |
| Write:                                                                           | AM7                                 | AM6                               | AM5                                | AM4                                                            | AM3                                 | AM2             | AM1      | AM0          |
| L<br>Reset:                                                                      |                                     |                                   |                                    | Unaffecte                                                      | d by reset                          |                 |          |              |
| Nesei.                                                                           |                                     |                                   |                                    | 0.1.0.000                                                      |                                     |                 |          |              |
| NUSUI.                                                                           |                                     |                                   |                                    | enanoott                                                       | <i>a a</i> j 10001                  |                 |          |              |
|                                                                                  | ame and Ar                          | ldrass, C                         | IDMD2 \$                           |                                                                |                                     |                 |          |              |
| egister Na                                                                       | ame and Ac                          |                                   | IDMR2 — \$                         | 0516                                                           |                                     | 2               | 1        | Dit 0        |
| egister Na                                                                       | ame and Ac<br>Bit 7                 | ddress: C<br>6                    | IDMR2 — \$<br>5                    |                                                                | 3                                   | 2               | 1        | Bit 0        |
| egister Na<br>Read:                                                              |                                     |                                   |                                    | 0516                                                           |                                     | 2<br>AM2        | 1<br>AM1 | Bit 0        |
| egister Na                                                                       | Bit 7                               | 6                                 | 5                                  | 0516                                                           | 3                                   |                 |          |              |
| egister Na<br>Read:                                                              | Bit 7                               | 6                                 | 5                                  | 0516<br>4<br>AM4                                               | 3                                   |                 |          |              |
| egister Na<br>Read:<br>Write:                                                    | Bit 7                               | 6                                 | 5                                  | 0516<br>4<br>AM4                                               | 3<br>AM3                            |                 |          |              |
| egister Na<br>Read: [<br>Write: [<br>Reset:                                      | Bit 7                               | 6<br>AM6                          | 5                                  | 0516<br>4<br>AM4<br>Unaffecte                                  | 3<br>AM3                            |                 |          |              |
| egister Na<br>Read: [<br>Write: [<br>Reset:                                      | Bit 7<br>AM7                        | 6<br>AM6                          | 5<br>AM5                           | 0516<br>4<br>AM4<br>Unaffecte                                  | 3<br>AM3                            |                 |          |              |
| egister Na<br>Read: [<br>Write: [<br>Reset:                                      | Bit 7<br>AM7<br>ame and Ac          | 6<br>AM6<br>ddress: C             | 5<br>AM5<br>IDMR3 — \$             | 0516<br>4<br>AM4<br>Unaffecte<br>0517                          | 3<br>AM3<br>ed by reset             | AM2             | AM1      | AMO          |
| egister Na<br>Read: [<br>Write: [<br>Reset:<br>egister Na<br>Read: [             | Bit 7<br>AM7<br>ame and Ac          | 6<br>AM6<br>ddress: C             | 5<br>AM5<br>IDMR3 — \$             | 0516<br>4<br>AM4<br>Unaffecte<br>0517                          | 3<br>AM3<br>ed by reset             | AM2             | AM1      | AMO          |
| egister Na<br>Read: [<br>Write: [<br>Reset:<br>egister Na<br>Read: [<br>Write: [ | Bit 7<br>AM7<br>ame and Ac<br>Bit 7 | 6<br>AM6<br>ddress: C<br>6        | 5<br>AM5<br>IDMR3 — \$<br>5        | 0516<br>4<br>AM4<br>Unaffecte<br>0517<br>4<br>AM4              | 3<br>AM3<br>ed by reset<br>3<br>AM3 | AM2<br>2        | AM1      | AM0<br>Bit 0 |
| egister Na<br>Read: [<br>Write: [<br>Reset:<br>egister Na<br>Read: [             | Bit 7<br>AM7<br>ame and Ac<br>Bit 7 | 6<br>AM6<br>ddress: C<br>6<br>AM6 | 5<br>AM5<br>IDMR3 — \$<br>5<br>AM5 | 0516<br>4<br>AM4<br>Unaffecte<br>0517<br>4<br>AM4<br>Unaffecte | 3<br>AM3<br>ed by reset             | AM2<br>2<br>AM2 | AM1      | AM0<br>Bit 0 |

#### AM7–AM0 — Acceptance Mask Bits

If a particular bit in this register is cleared, this indicates that the corresponding bit in the identifier acceptance register must be the same as its identifier bit before a match will be detected. The message will be accepted if all such bits match. If a bit is set, it indicates that the state of the corresponding bit in the identifier acceptance register will not affect whether or not the message is accepted.

- 1 = Ignore corresponding acceptance code register bit.
- 0 = Match corresponding acceptance code register and identifier bits.
- **NOTE:** The CIDMR0-CIDMR3 registers can be written only if the SFTRES bit in the MSCAN08 module control register is set.

# **Section 23. Electrical Specifications**

## 23.1 Contents

| 23.2  | Maximum Ratings                                               |
|-------|---------------------------------------------------------------|
| 23.3  | Functional Operating Range                                    |
| 23.4  | Thermal Characteristics                                       |
| 23.5  | DC Electrical Characteristics                                 |
| 23.6  | Control Timing                                                |
| 23.7  | ADC Characteristics                                           |
| 23.8  | 5.0 Vdc $\pm$ 10% Serial Peripheral Interface (SPI) Timing389 |
| 23.9  | CGM Operating Conditions                                      |
| 23.10 | CGM Component Information                                     |
| 23.11 | CGM Acquisition/Lock Time Information                         |
| 23.12 | Timer Module Characteristics                                  |
| 23.13 | Memory Characteristics                                        |

## 23.2 Maximum Ratings

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 **23.5 DC Electrical Characteristics** for guaranteed operating conditions.

| Rating                                                                   | Symbol            | Value                                  | Unit |
|--------------------------------------------------------------------------|-------------------|----------------------------------------|------|
| Supply voltage                                                           | V <sub>DD</sub>   | -0.3 to +6.0                           | V    |
| Input voltage                                                            | V <sub>in</sub>   | $V_{SS}$ –0.3 to $V_{DD}$ +0.3         | V    |
| Maximum current per pin<br>excluding V <sub>DD</sub> and V <sub>SS</sub> | I                 | ± 25                                   | mA   |
| Storage temperature                                                      | T <sub>stg</sub>  | –55 to +150                            | °C   |
| Maximum current out of $V_{SS}$                                          | I <sub>MVSS</sub> | 100                                    | mA   |
| Maximum current into V <sub>DD</sub>                                     | I <sub>MVDD</sub> | 100                                    | mA   |
| Reset IRQ input voltage                                                  | V <sub>HI</sub>   | V <sub>DD</sub> to V <sub>DD</sub> + 2 | V    |

Note: Voltages are referenced to  $V_{SS}$ .

**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_{In}$  and  $V_{Out}$  be constrained to the range  $V_{SS} \leq (V_{In} \text{ or } V_{Out}) \leq V_{DD}$ . Reliability of operation is enhanced if unused inputs are connected to an appropriate logic voltage level (for example, either  $V_{SS}$  or  $V_{DD}$ ).

## 23.3 Functional Operating Range

| Rating                      | Symbol          | Value        | Unit |
|-----------------------------|-----------------|--------------|------|
| Operating temperature range | T <sub>A</sub>  | -40 to 125   | °C   |
| Operating voltage range     | V <sub>DD</sub> | $5.0\pm10\%$ | V    |

## **23.4 Thermal Characteristics**

| Characteristic                    | Symbol           | Value                                                                                           | Unit |
|-----------------------------------|------------------|-------------------------------------------------------------------------------------------------|------|
| Thermal resistance PLCC (52 pins) | θ <sub>JA</sub>  | 50                                                                                              | °C/W |
| I/O pin power dissipation         | P <sub>I/O</sub> | User determined                                                                                 | W    |
| Power dissipation <sup>(1)</sup>  | P <sub>D</sub>   | $P_D = (I_{DD} \times V_{DD}) + P_{I/O} = K/(T_J + 273^{\circ}C)$                               | W    |
| Constant <sup>(2)</sup>           | к                | P <sub>D</sub> x (T <sub>A</sub> + 273°C)<br>+ (P <sub>D</sub> <sup>2</sup> x θ <sub>JA</sub> ) | W/°C |
| Average junction temperature      | TJ               | $T_A = P_D X \theta_{JA}$                                                                       | °C   |
| Maximum junction temperature      | T <sub>JM</sub>  | 150                                                                                             | ٥C   |

1. Power dissipation is a function of temperature.

2. K is a constant unique to the device. K can be determined from a known  $T_A$  and measured  $P_D$ . With this value of K,  $P_D$  and  $T_J$  can be determined for any value of  $T_A$ .

### 23.5 DC Electrical Characteristics

| Characteristic <sup>(1)</sup>                                                                                    | Symbol                              | Min                   | Typ <sup>(2)</sup> | Max                                                                      | Unit     |
|------------------------------------------------------------------------------------------------------------------|-------------------------------------|-----------------------|--------------------|--------------------------------------------------------------------------|----------|
| Output high voltage<br>(I <sub>Load</sub> = -2.0 mA) all ports                                                   | V <sub>OH</sub>                     | V <sub>DD</sub> –0.8  |                    | _                                                                        | V        |
| Output low voltage<br>(I <sub>Load</sub> = 1.6 mA) all ports                                                     | V <sub>OL</sub>                     | _                     |                    | 0.4                                                                      | V        |
| Input high voltage<br>All ports, IRQS, RESET, OSC1                                                               | V <sub>IH</sub>                     | 0.7 x V <sub>DD</sub> |                    | V <sub>DD</sub>                                                          | V        |
| Input low voltage<br>Port A, IRQS, RESET, OSC1<br>Port B<br>Ports C, D, E, F                                     | V <sub>IL</sub>                     | V <sub>SS</sub>       |                    | 0.3 x V <sub>DD</sub><br>0.16 x V <sub>DD</sub><br>0.2 x V <sub>DD</sub> | V        |
| $V_{DD} + V_{DDA}/V_{DDAREF}$ supply current<br>Run <sup>(3)</sup><br>Wait <sup>(4)</sup><br>Stop <sup>(5)</sup> | I <sub>DD</sub>                     | _                     | _                  | 35<br>15                                                                 | mA<br>mA |
| –40°C to +125°C<br>–40°C to +125°C with LVI enabled                                                              |                                     | —                     |                    | 100<br>500                                                               | μΑ<br>μΑ |
| I/O ports hi-z leakage current                                                                                   | ۱L                                  | _                     | —                  | ± 1                                                                      | μΑ       |
| Input current                                                                                                    | l <sub>In</sub>                     | _                     | —                  | ± 1                                                                      | μΑ       |
| Capacitance<br>Ports (as input or output)                                                                        | C <sub>Out</sub><br>C <sub>In</sub> |                       | _                  | 12<br>8                                                                  | pF       |
| Low-voltage reset inhibit                                                                                        | V <sub>LVII</sub>                   | 4.0                   | 4.5                | 4.75                                                                     | V        |
| Low-voltage reset inhibit/recover hysteresis                                                                     | H <sub>LVI</sub>                    | _                     | 200                | _                                                                        | mV       |
| POR re-arm voltage <sup>(6)</sup>                                                                                | V <sub>POR</sub>                    | 0                     | _                  | 200                                                                      | mV       |
| POR reset voltage <sup>(7)</sup>                                                                                 | V <sub>PORRST</sub>                 | 0                     | —                  | 800                                                                      | mV       |
| POR rise time ramp rate <sup>(8)</sup>                                                                           | R <sub>POR</sub>                    | 0.02                  | —                  | —                                                                        | V/ms     |
| High COP disable voltage <sup>(9)</sup>                                                                          | V <sub>HI</sub>                     | V <sub>DD</sub>       | _                  | V <sub>DD</sub> + 2                                                      | V        |

 V<sub>DD</sub> = 5.0 Vdc ± 10%, V<sub>SS</sub> = 0 Vdc, T<sub>A</sub> = -40°C to +125°C, unless otherwise noted.
 Typical values reflect average measurements at midpoint of voltage range, 25°C only.
 Run (operating) I<sub>DD</sub> measured using external square wave clock source (f<sub>OP</sub> = 8.4 MHz). All inputs 0.2 V from rail. No dc loads. Less than 100 pF on all outputs. C<sub>L</sub> = 20 pF on OSC2. All ports configured as inputs. OSC2 capacitance linearly affects run I<sub>DD</sub>. Measured with all model. modules enabled.

4. Wait I<sub>DD</sub> measured using external square wave clock source (f<sub>OP</sub> = 8.4 MHz). All inputs 0.2 Vdc from rail. No dc loads. Less than 100 pF on all outputs, C<sub>L</sub> = 20 pF on OSC2. All ports configured as inputs. OSC2 capacitance linearly affects wait I<sub>DD</sub>. Measured with all modules enabled.

5. Stop  $I_{DD}$  measured with OSC1 = V<sub>SS</sub>. 6. Maximum is highest voltage that POR is guaranteed. 7. Maximum is highest voltage that POR is possible.

8. If minimum V<sub>DD</sub> is not reached before the internal POR reset is released, RST must be driven low externally until minimum V<sub>DD</sub> is reached.

9. See 14.9 COP Module During Break Interrupts.

## 23.6 Control Timing

| Characteristic <sup>(1)</sup>                                                                                   | Symbol                                                | Min         | Мах | Unit             |
|-----------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|-------------|-----|------------------|
| Bus operating frequency (4.5–5.5 V — $V_{DD}$ only)                                                             | f <sub>BUS</sub>                                      |             | 8.4 | MHz              |
| RESET pulse width low                                                                                           | t <sub>RL</sub>                                       | 1.5         | _   | t <sub>cyc</sub> |
| IRQ interrupt pulse width low (edge-triggered)                                                                  | t <sub>ILHI</sub>                                     | 1.5         | —   | t <sub>cyc</sub> |
| IRQ interrupt pulse period                                                                                      | t <sub>ILIL</sub>                                     | Note 3      | —   | t <sub>cyc</sub> |
| EEPROM programming time per byte                                                                                | t <sub>EEPGM</sub>                                    | 10          |     | ms               |
| EEPROM erasing time per byte                                                                                    | t <sub>EBYTE</sub>                                    | 10          | _   | ms               |
| EEPROM erasing time per block                                                                                   | t <sub>EBLOCK</sub>                                   | 10          | —   | ms               |
| EEPROM erasing time per bulk                                                                                    | t <sub>EBULK</sub>                                    | 10          | _   | ms               |
| EEPROM programming voltage discharge period                                                                     | t <sub>EEFPV</sub>                                    | 100         | _   | μs               |
| Cumulative program time per program cycle <sup>(2)</sup>                                                        | _                                                     | _           | 100 | ms               |
| 16-bit timers <sup>(3)</sup><br>Input capture pulse width <sup>(4)</sup><br>Input capture period <sup>(5)</sup> | t <sub>TH,</sub> t <sub>TL</sub><br>t <sub>TLTL</sub> | 2<br>Note 5 |     | t <sub>cyc</sub> |

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

2. Programming is done in an iterative program / verify loop which is exited upon a successful verify.

3. The 2-bit timer prescaler is the limiting factor in determining timer resolution.

4. Refer to Table 20-2 . Mode, Edge, and Level Selection and supporting note.

5. The minimum period  $t_{TLTL}$  or  $t_{ILIL}$  should not be less than the number of cycles it takes to execute the capture interrupt service routine plus TBD  $t_{cyc}$ .

## 23.7 ADC Characteristics

| Characteristic                                                               | Min               | Max                         | Unit                   | Comments                             |  |  |
|------------------------------------------------------------------------------|-------------------|-----------------------------|------------------------|--------------------------------------|--|--|
| Resolution                                                                   | 8                 | 8                           | Bits                   |                                      |  |  |
| Absolute accuracy<br>( $V_{REFL} = 0 V, V_{DDA} = V_{REFH} = 5 V \pm 10\%$ ) | -1                | +1                          | LSB                    | Includes quantization                |  |  |
| Conversion range <sup>(1)</sup>                                              | V <sub>REFL</sub> | V <sub>REFH</sub>           | V                      | V <sub>REFL</sub> = V <sub>SSA</sub> |  |  |
| Powerup time                                                                 | 16                | 17                          | μs                     | Conversion Time<br>period            |  |  |
| Input leakage <sup>(2)</sup><br>Ports B and D                                | _                 | ± 1                         | μA                     |                                      |  |  |
| Conversion time                                                              | 16                | 17                          | ADC<br>clock<br>cycles | Includes sampling<br>time            |  |  |
| Monotonicity                                                                 |                   | Inherent within total error |                        |                                      |  |  |
| Zero input reading                                                           | 00                | 01                          | Hex                    | V <sub>In</sub> = V <sub>REFL</sub>  |  |  |
| Full-scale reading                                                           | FE                | FF                          | Hex                    | V <sub>In</sub> = V <sub>REFH</sub>  |  |  |
| Sample time <sup>(3)</sup>                                                   | 5                 | _                           | ADC<br>clock<br>cycles |                                      |  |  |
| Input capacitance                                                            | —                 | 8                           | pF                     | Not tested                           |  |  |
| ADC internal clock                                                           | 500 k             | 1.048 M                     | Hz                     | Tested only at 1 MHz                 |  |  |
| Analog input voltage                                                         | -0.3              | V <sub>DD</sub> + 0.3       | V                      |                                      |  |  |

 $1. \ V_{DD} = 5.0 \ Vdc \pm 10\%, \ V_{SS} = 0 \ Vdc, \ V_{DDA}/V_{DDAREF} = 5.0 \ Vdc \pm 10\%, \ V_{SSA} = 0 \ Vdc, \ V_{REFH} = 5.0 \ Vdc \pm 10\%$ 

2. The external system error caused by input leakage current is approximately equal to the product of R source and input current.

3. Source impedances greater than 10 k $\Omega$  adversely affect internal RC charging time during input sampling.

| Num<br>(1) | Characteristic <sup>(2)</sup>                                        | Symbol                                         | Min                      | Max                                  | Unit             |
|------------|----------------------------------------------------------------------|------------------------------------------------|--------------------------|--------------------------------------|------------------|
|            | Operating frequency <sup>(3)</sup><br>Master<br>Slave                | f <sub>BUS(M)</sub><br>f <sub>BUS(s)</sub>     | f <sub>BUS</sub> /128 dc | f <sub>BUS</sub> /2 f <sub>BUS</sub> | MHz              |
| 1          | Cycle tme<br>Master<br>Slave                                         | t <sub>CYC(M)</sub><br>t <sub>CYC(s)</sub>     | 2<br>1                   | 128<br>—                             | t <sub>CYC</sub> |
| 2          | Enable lead time                                                     | t <sub>Lead</sub>                              | 15                       | —                                    | ns               |
| 3          | Enable lag time                                                      | t <sub>Lag</sub>                               | 15                       | —                                    | ns               |
| 4          | Clock (SCK) high time<br>Master<br>Slave                             | t <sub>w(scкн)м</sub><br>t <sub>w(scкн)s</sub> | 100<br>50                |                                      | ns               |
| 5          | Clock (SCK) low time<br>Master<br>Slave                              | t <sub>w(sckl)m</sub><br>t <sub>w(sckl)s</sub> | 100<br>50                |                                      | ns               |
| 6          | Data setup time, inputs<br>Master<br>Slave                           | t <sub>SU(M)</sub><br>t <sub>SU(S)</sub>       | 45<br>5                  |                                      | ns               |
| 7          | Data hold time, inputs<br>Master<br>Slave                            | t <sub>H(M)</sub><br>t <sub>H(S)</sub>         | 0<br>15                  |                                      | ns               |
| 8          | Access time, slave <sup>(4)</sup><br>CPHA = 0<br>CPHA = 1            | t <sub>A(CP0)</sub><br>t <sub>A(CP1)</sub>     | 0<br>0                   | 40<br>20                             | ns               |
| 9          | Slave disable time, hold time to high-impedance State <sup>(5)</sup> | t <sub>DIS</sub>                               | _                        | 25                                   | ns               |
| 10         | Data valid time after enable edge<br>Master<br>Slave                 | t <sub>v(M)</sub><br>t <sub>v(S)</sub>         | _                        | 10<br>40                             | ns               |
| 11         | Data hold time, outputs, after enable edge<br>Master<br>Slave        | t <sub>HO(M)</sub><br>t <sub>HO(S)</sub>       | 0<br>5                   |                                      | ns               |

## 23.8 5.0 Vdc $\pm$ 10% Serial Peripheral Interface (SPI) Timing

1. Item numbers refer to dimensions in Figure 23-1 and Figure 23-2.

2. All timing is shown with respect to 30%  $V_{DD}$  and 70%  $V_{DD}$ , unless otherwise noted; assumes 100 pF load on all SPI pins.

3.  $f_{Bus}$  = the currently active bus frequency for the microcontroller.

4. Time to data active from high-impedance state

5. Hold time to high-impedance state

#### MC68HC08QA24



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 23-1. SPI Master Timing



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)



## 23.9 CGM Operating Conditions

| Characteristic                 | Symbol            | Min        | Тур       | Max      | Comments                        |
|--------------------------------|-------------------|------------|-----------|----------|---------------------------------|
| Operating voltage              | V <sub>DD</sub>   | 4.5 V      |           | 5.5 V    |                                 |
| Crystal reference frequency    | f <sub>XCLK</sub> | 1          | 4.194 MHz | 8 MHz    |                                 |
| Range nominal multiplier (MHz) | f <sub>NOM</sub>  | _          | 4.194     | _        | 4.5–5.5 V, V <sub>DD</sub> only |
| VCO operating frequency (MHz)  | f <sub>VCLK</sub> | 4.9152 MHz | _         | 32.0 MHz |                                 |

## 23.10 CGM Component Information

| Description                      | Symbol            | Min | Тур                                                        | Max | Comments                                                                                                                                                                                                            |
|----------------------------------|-------------------|-----|------------------------------------------------------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Crystal load capacitance         | CL                | _   | _                                                          |     | Consult crystal<br>manufacturer's data                                                                                                                                                                              |
| Crystal fixed capacitance        | C1                |     | 2 x CL                                                     |     | Consult crystal<br>manufacturer's data                                                                                                                                                                              |
| Crystal tuning capacitance       | C2                |     | 2 x CL                                                     |     | Consult crystal<br>manufacturer's data                                                                                                                                                                              |
| Filter capacitor multiply factor | C <sub>Fact</sub> |     | 0.0154                                                     |     | F/s V                                                                                                                                                                                                               |
| Filter capacitor                 | C <sub>F</sub>    |     | C <sub>Fact</sub> x (V <sub>DDA</sub> /f <sub>XCLK</sub> ) |     | See 9.5.3 External Filter<br>Capacitor Pin (CGMXFC)                                                                                                                                                                 |
| Bypass capacitor                 | C <sub>BYP</sub>  |     | 0.1 μF                                                     |     | $\begin{array}{l} C_{BYP} \text{ must provide low AC} \\ \text{impedance from} \\ f = f_{XCLK} / 100 \text{ to } 100 \text{ x } f_{VCLK}, \\ \text{so series resistance must be} \\ \text{considered.} \end{array}$ |

| Description <sup>(1)</sup>                                              | Symbol             | Min    | Тур     | Мах                                         | Notes                            |
|-------------------------------------------------------------------------|--------------------|--------|---------|---------------------------------------------|----------------------------------|
| Tracking mode entry frequency tolerance                                 | $\Delta_{TRK}$     | 0      | _       | ± 3.6%                                      |                                  |
| Acquisition mode entry frequency tolerance                              | $\Delta_{\sf UNT}$ | ± 6.3% |         | ±7.2%                                       |                                  |
| Lock entry frequency tolerance                                          | $\Delta_{Lock}$    | 0      |         | ± 0.9%                                      |                                  |
| Lock exit frequency tolerance                                           | $\Delta_{\sf UNL}$ | ± 0.9% | _       | ± 1.8%                                      |                                  |
| Reference cycles per acquisition mode measurement                       | n <sub>ACQ</sub>   |        | 32      | _                                           |                                  |
| Reference cycles per tracking mode measurement                          | n <sub>TRK</sub>   |        | 128     | _                                           |                                  |
| Automatic Lock Timer <sup>(2)</sup> , <sup>(3)</sup>                    | t <sub>Lock</sub>  | —      | 4.35 ms | 7.00 ms                                     |                                  |
| PLL jitter, deviation of average bus frequency over 2 ms <sup>(4)</sup> | _                  | 0      |         | ± (f <sub>CRYS</sub> )<br>x (.025%) x (N/4) | N = VCO<br>Freq. Mult.<br>(GBNT) |

## 23.11 CGM Acquisition/Lock Time Information

1.  $V_{DD}$  = 5.0 Vdc ± 10%,  $V_{SS}$  = 0 Vdc,  $T_A$  = -40°C to +125°C, unless otherwise noted. 2. For Typ = 25 C, N/L = 66. For Max:  $T_A$  = -40 C, N/L = 77

3. This parameter is periodically sampled rather than 100% tested.

4. GBNT guaranteed but not tested

## 23.12 Timer Module Characteristics

| Characteristic            | Symbol                              | Min                      | Max | Unit |
|---------------------------|-------------------------------------|--------------------------|-----|------|
| Input capture pulse width | t <sub>⊤IH,</sub> t <sub>⊤IL</sub>  | 125                      | _   | ns   |
| Input clock pulse width   | t <sub>TCH</sub> , t <sub>TCL</sub> | (1/f <sub>OP</sub> ) + 5 | _   | ns   |

## 23.13 Memory Characteristics

| Characteristic                                                        | Symbol           | Min | Max    | Unit   |
|-----------------------------------------------------------------------|------------------|-----|--------|--------|
| RAM data retention voltage                                            | V <sub>RDR</sub> | 0.7 |        | V      |
| EEPROM erase / program cycles<br>10 ms write time @ 125°C             | _                | _   | 10,000 | Cycles |
| EEPROM data retention<br>After 10,000 erase / program cycles at 125°C | _                | 10  | _      | Years  |

**Technical Data** 

MC68HC08QA24

## Section 24. Mechanical Data

## 24.1 Contents

| 24.2 | Introduction               | 395 |
|------|----------------------------|-----|
| 24.3 | 52-Pin Plastic Leaded Chip |     |
|      | Carrier Package (Case 778) | 396 |

### 24.2 Introduction

This section describes the dimensions of the 52-pin plastic leaded chip carrier package.

The following figure shows the latest package at the time of this publication. To make sure that you have the latest package specifications, contact one of the following:

- Local Motorola Sales Office
- Motorola Mfax
  - Phone 602-244-6609
  - Email rmfax0@email.sps.mot.com
- World-Wide Web (wwweb) at http://motorola.com/sps/

Follow Mfax or World-Wide Web on-line instructions to retrieve the current mechanical specifications.

MOTOROLA

## 24.3 52-Pin Plastic Leaded Chip Carrier Package (Case 778)



W 0.042

X Y 0.042

Z

K1 0.040

0.048

0.056

0.020 2°

10 9

**G1** 0.710 0.730 18.04 18.54

1.07

1.07

2 °

1.02

1.21

1.42 0.50

10°

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 of thers. Motorola products are not designed, intended, or authorized for use as components in systems intended for surgical implant into the body, or other applications intended to support or sustain life, or for any other application in which the failure of the Motorola product could create a situation where personal injury or death may occur. Should Buyer purchase or use Motorola products for any such unintended or unauthorized application, Buyer shall indemnify and hold Motorola and its officers, employees, subsidiaries, affiliates, and distributors harmless against all claims, costs, damages, and expenses, and reasonable attorney fees arising out of, directly or indirectly, any claim of personal injury or death associated with such unintended or unauthorized use, even if such claim alleges that Motorola was negligent regarding the design or manufacture of the part. Motorola and *w* registered trademarks of Motorola, Inc. is an Equal Opportunity/Affirmative Action Employer.

#### How to reach us:

USA/EUROPE/Locations Not Listed: Motorola Literature Distribution, P.O. Box 5405, Denver, Colorado 80217. 1-800-441-2447 or 1-303-675-2140. Customer Focus Center, 1-800-521-6274

JAPAN: Motorola Japan Ltd.: SPD, Strategic Planning Office, 141, 4-32-1 Nishi-Gotanda, Shinagawa-Ku, Tokyo, Japan, 03-5487-8488

ASIA/PACIFIC: Motorola Semiconductors H.K. Ltd., Silicon Harbour Centre, 2 Dai King Street, Tai Po Industrial Estate, Tai Po, New Territories, Hong Kong, 852-26629298

Mfax™, Motorola Fax Back System: RMFAX0@email.sps.mot.com; http://sps.motorola.com/mfax/;

TOUCHTONE, 1-602-244-6609; US and Canada ONLY, 1-800-774-1848

HOME PAGE: http://motorola.com/sps/

Mfax is a trademark of Motorola, Inc.

© Motorola, Inc., 2000

MC68HC08QA24/D