Order this document by MC68HC08LJ60/D Rev. 1.0



# 68HC08LJ60 68HC908LJ60

**Advance Information** 

This document contains information on a new product.

Specifications and information herein are subject to change without notice.



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

#### **Advance Information**

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., 1999

Advance Information

## Advance Information — MC68HC(9)08LJ60

## **List of Sections**

| Section 1. General Description                           |
|----------------------------------------------------------|
| Section 2. Memory Map                                    |
| Section 3. Random-Access Memory (RAM)49                  |
| Section 4. FLASH Memory                                  |
| Section 5. Central Processor Unit (CPU) 65               |
| Section 6. System Integration Module (SIM) 83            |
| Section 7. Clock Generator Module (CGMB) 107             |
| Section 8. Functional Controller Module (FCM) 139        |
| Section 9. Break Module                                  |
| Section 10. Power-On Reset Module (POR) 163              |
| Section 11. External Interrupt Module (IRQ) 165          |
| Section 12. Serial Communications Interface Module (SCI) |
| Section 13. Serial Peripheral Interface Module (SPI)     |
| Section 14. Alert Output Generator (ALR) 245             |
| Section 15. Liquid Crystal Display Module (LCD) 251      |
| Section 16. Timer Interface Module (TIM) 263             |
| Section 17. Input/Output (I/O) Ports                     |
| Section 18. Monitor ROM (MON)                            |
|                                                          |

MC68HC(9)08LJ60 - Rev. 1.0

## Freescale Semiconductor, Inc.

## **List of Sections**

|     | ĺ | β  | ٩ |
|-----|---|----|---|
|     | ١ | b  | ď |
|     | ( | P  |   |
|     | ( | ì  |   |
|     |   |    |   |
|     |   |    |   |
|     |   |    | i |
|     | ì | S. |   |
|     | j | Ξ  | Ξ |
|     | ( | G  | 2 |
| 'n  | á | Ē  | á |
|     | 7 | ī  | h |
|     | ( | G  | a |
|     | i | ì  | 3 |
|     | i | i  |   |
|     |   | ı  | 3 |
|     | ( | b  | d |
|     | ( | ø  |   |
|     | ì | h  |   |
|     | ( | ø  | ٩ |
|     | ١ | b  | d |
|     | ( | ø  | ٩ |
|     | ١ | b  | ď |
|     | I |    |   |
|     | ( | P  |   |
|     | ĺ | P  |   |
|     | Ì | ı  | ı |
|     | ( |    | В |
|     | ١ | y  | 2 |
| - ( | l | Ø  | 0 |
|     |   | "  |   |
|     |   | _  |   |
|     | ( |    | U |
| 'n  |   | 3  |   |
|     |   | Ξ  | Ξ |
|     | ( | ١  |   |
|     | ì | à  | ĭ |
|     | ( | G  | 1 |
|     | ( | ŭ  | ñ |
|     | 1 | V  | Ŋ |
|     | ( | Ñ  | h |
|     | 1 | ų  | И |
|     | ĺ | Ø  | B |
|     | 1 | Ų  | ď |
|     | Ĭ | h  |   |

| Section 19. Keyboard Interrupt (KBI) Module       | 313 |
|---------------------------------------------------|-----|
| Section 20. Preliminary Electrical Specifications | 319 |
| Section 21. Mechanical Data                       | 333 |
| Section 22. Ordering Information                  | 335 |

Advance Information

## Advance Information — MC68HC(9)08LJ60

## **Table of Contents**

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

| 1.1    | Contents                                                                     | 25 |
|--------|------------------------------------------------------------------------------|----|
| 1.2    | Introduction                                                                 | 26 |
| 1.3    | Features                                                                     | 26 |
| 1.4    | MCU Block Diagram                                                            |    |
| 1.4.1  | Power Supply Pins ( $V_{DD}$ , $V_{SS}$ , $EV_{DD}$ , and $EV_{SS}$ ).       | 29 |
| 1.4.2  | Oscillator Pins (OSC1 and OSC2)                                              |    |
| 1.4.3  | External Reset Pin (RST)                                                     | 30 |
| 1.4.4  | External Interrupt Pin (IRQ1)                                                |    |
| 1.4.5  | External Interrupt Pin (IRQ2)                                                |    |
| 1.4.6  | Analog Ground Pin (V <sub>SSA</sub> )                                        | 31 |
| 1.4.7  | Analog Power Supply Pin (V <sub>DDA</sub> )                                  |    |
| 1.4.8  | External Filter Capacitor Pin (CGMXFC)                                       |    |
| 1.4.9  | Port A I/O Pins (PTA7–PTA0)                                                  |    |
| 1.4.10 | Port B I/O Pins (PTB7–PTB0)                                                  |    |
| 1.4.11 | Port C I/O Pins (PTC7–PTC0)                                                  |    |
| 1.4.12 |                                                                              |    |
| 1.4.13 |                                                                              |    |
| 1.4.14 |                                                                              |    |
| 1.4.15 |                                                                              |    |
| 1.4.16 |                                                                              |    |
| 1.4.17 | SCI Transmit Data (TxD)                                                      |    |
| 1.4.18 |                                                                              |    |
| 1.4.19 | Power Supply Pins (V <sub>LL</sub> , V <sub>LL32</sub> , V <sub>LL12</sub> , |    |
|        | and V <sub>CP4</sub> –V <sub>CP1</sub> )                                     |    |
| 1.4.20 |                                                                              |    |
|        | (FP84–FP0, BP7–BP0)                                                          |    |
| 1.5    | Pin Assignments                                                              |    |

MC68HC(9)08LJ60 - Rev. 1.0

## **Table of Contents**

| Section | 2. | Memory | Мар |
|---------|----|--------|-----|
|         |    |        |     |

| 2.1  | Contents                                   |
|------|--------------------------------------------|
| 2.2  | Introduction                               |
| 2.3  | I/O Section                                |
| 2.4  | Random-Access Memory (RAM)36               |
| 2.5  | Memory Map                                 |
| 2.6  | Monitor Read-Only Memory (ROM)             |
|      | Section 3. Random-Access Memory (RAM)      |
| 3.1  | Contents                                   |
| 3.2  | Introduction                               |
| 3.3  | Functional Description                     |
|      | Section 4. FLASH Memory                    |
| 4.1  | Contents                                   |
| 4.2  | Introduction51                             |
| 4.3  | FLASH1 Functional Description              |
| 4.4  | FLASH2 Functional Description              |
| 4.5  | FLASH1 Control Register54                  |
| 4.6  | FLASH2 Control Register56                  |
| 4.7  | FLASH1 Block Protect Register              |
| 4.8  | FLASH2 Block Protect Register              |
| 4.9  | Block Protection                           |
| 4.10 | Charge Pump Frequency Control61            |
| 4.11 | FLASH Erase Operation61                    |
| 4.12 | FLASH Program and Margin Read Operation 62 |
|      | Section 5. Central Processor Unit (CPU)    |
| 5.1  | Contents                                   |
| 5.2  | Introduction                               |
| 5.3  | Features                                   |
|      |                                            |
|      | MC68HC(9)08LJ60 — Rev. 1.0                 |

| 5.4     | CPU Registers                              | 67  |
|---------|--------------------------------------------|-----|
| 5.4.1   | Accumulator                                | 68  |
| 5.4.2   | Index Register                             | 68  |
| 5.4.3   | Stack Pointer                              |     |
| 5.4.4   | Program Counter                            |     |
| 5.4.5   | Condition Code Register                    | .71 |
|         | Arithmetic/Logic Unit (ALU)                |     |
| 5.6     | CPU During Break Interrupts                | 73  |
| 5.7 I   | Instruction Set Summary                    | .74 |
| 5.8     | Opcode Map                                 | 80  |
|         | Section 6. System Integration Module (SIM) |     |
| 6.1     | Contents                                   | 83  |
|         | Introduction                               |     |
|         | SIM Bus Clock Control and Generation       |     |
| 6.3.1   | Bus Timing                                 |     |
| 6.3.2   | Clock Startup from POR or LVI Reset        |     |
| 6.3.3   | Clocks in Stop Mode and Wait Mode          |     |
| 6.4     | Reset and System Initialization            | 88  |
| 6.4.1   | External Pin Reset                         |     |
| 6.4.2   | Active Resets from Internal Sources        | .90 |
| 6.4.2.1 | Power-On Reset                             | 91  |
| 6.4.2.2 | Computer Operating Properly (COP) Reset    | .92 |
| 6.4.2.3 | Illegal Opcode Reset                       | 92  |
| 6.4.2.4 | Illegal Address Reset                      | 93  |
| 6.4.2.5 | Low-Voltage Inhibit (LVI) Reset            | 93  |
| 6.5     | SIM Counter                                | 93  |
| 6.5.1   | SIM Counter During Power-On Reset          | .93 |
| 6.5.2   | SIM Counter During Stop Mode Recovery      | .94 |
| 6.5.3   | SIM Counter and Reset States               | .94 |
| 6.6 I   | Exception Control                          | 94  |
| 6.6.1   | Interrupts                                 | 95  |
| 6.6.1.1 | Hardware Interrupts                        | 97  |
| 6.6.1.2 | SWI Instruction                            | 98  |
| 6.6.2   | Reset                                      | 99  |
|         |                                            |     |

MC68HC(9)08LJ60 — Rev. 1.0

## **Table of Contents**

| 6.6.3 Bre    | eak Interrupts99                                  |
|--------------|---------------------------------------------------|
|              | tus Flag Protection in Break Mode99               |
| 6.7 Low-Po   | ower Modes                                        |
| 6.7.1 Wa     | it Mode                                           |
| 6.7.2 Sto    | p Mode101                                         |
| 6.8 SIM Re   | egisters                                          |
|              | ∄ Break Status Register                           |
| 6.8.2 SIM    | // Reset Status Register                          |
| 6.8.3 SIM    | Л Break Flag Control Register106                  |
| Soct         | ion 7. Clack Congretor Module (CCMP)              |
|              | ion 7. Clock Generator Module (CGMB)              |
|              | nts                                               |
|              | uction108                                         |
| 7.3 Feature  | es                                                |
| 7.4 Function | onal Description                                  |
| 7.4.1 Cry    | stal Oscillator Circuit                           |
|              | ase-Locked Loop Circuit (PLL)                     |
| 7.4.2.1 P    | PLL Circuits                                      |
| 7.4.2.2 A    | Acquisition and Tracking Modes                    |
|              | Manual and Automatic PLL Bandwidth Modes113       |
|              | Programming the PLL                               |
|              | Special Programming Exceptions                    |
|              | se Clock Selector Circuit118                      |
|              | MB External Connections119                        |
| _            | nals                                              |
| 7.5.1 Cry    | stal Amplifier Input Pin (OSC1)                   |
|              | stal Amplifier Output Pin (OSC2)120               |
|              | ernal Filter Capacitor Pin (CGMXFC)               |
|              | L Analog Power Pin (V <sub>DDA</sub> ) .......121 |
|              | L Analog Ground Pin (V <sub>SSA</sub> )           |
|              | cillator Enable Signal (SIMOSCEN)                 |
|              | stal Output Frequency Signal (CGMXCLK)            |
|              | MB Base Clock Output (CGMOUT)                     |
| 7.5.9 CG     | MB CPU Interrupt (CGMINT)122                      |

**Advance Information** 

| CGMB Registers122                             |
|-----------------------------------------------|
| PLL Control Register124                       |
| PLL Bandwidth Control Register126             |
| PLL Multiplier Select Register High128        |
| PLL Multiplier Select Register Low            |
| PLL VCO Range Select Register                 |
| PLL Reference Divider Select Register         |
| Interrupts132                                 |
| Wait Mode132                                  |
| CGMB During Break Interrupts133               |
| Acquisition/Lock Time Specifications          |
| Acquisition/Lock Time Definitions             |
| Parametric Influences on Reaction Time135     |
| Choosing a Filter Capacitor136                |
| Reaction Time Calculation137                  |
| Section 8. Functional Controller Module (FCM) |
| Contents                                      |
| Introduction140                               |
| Features                                      |
| Functional Description                        |
| Module Description                            |
| Timebase Submodule                            |
| Real-Time Clock Submodule                     |
| COP Watchdog Timer Submodule                  |
| Interrupts145                                 |
| I/O Signals                                   |
| Interrupt Signals (FCM, CPU, and IRQ)         |
| Functional Controller Registers146            |
| Timebase Control Register                     |
| RTC Control Register                          |
| RTC Status Register                           |
| Chronograph Data Register                     |
| Seconds Data Register                         |
| Minutes Data Register155                      |
| Advance Information                           |
|                                               |

## **Table of Contents**

| 8.9.7                          | Hours Data Register                         | 155        |
|--------------------------------|---------------------------------------------|------------|
| 8.9.8                          | Alarm Minutes Register                      | 156        |
| 8.9.9                          | Alarm Hours Register                        | 156        |
|                                | Section 9. Break Module                     |            |
| 9.1                            | Contents                                    | 157        |
| 9.2                            | Introduction                                | 157        |
| 9.3                            | Features                                    | 158        |
| 9.4<br>9.4.1<br>9.4.2<br>9.4.3 | Functional Description                      | 160<br>160 |
| 9.4.4                          | COP During Break Interrupts                 | 160        |
| 9.5<br>9.5.1<br>9.5.2          | Break Module Registers                      | 161        |
| 9.6                            | Low-Power Modes                             | 162        |
| 9.6.1<br>9.6.2                 | Wait Mode                                   |            |
|                                | Section 10. Power-On Reset Module (POR)     |            |
| 10.1                           | Contents                                    | 163        |
| 10.2                           | Introduction                                | 163        |
| 10.3                           | Functional Description                      | 163        |
|                                | Section 11. External Interrupt Module (IRQ) |            |
| 11.1                           | Contents                                    | 165        |
| 11.2                           | Introduction                                | 165        |
| 11.3                           | Features                                    | 165        |
| 11.4<br>11.4.1<br>11.4.2       |                                             | 170        |
| 11.5                           | IRQ Module During Break Interrupts          | 172        |
| 11.6                           | IRQ Status and Control Register             | 172        |
|                                | MC68HC(9)08LJ60 — R                         | ev. 1.0    |

## Section 12. Serial Communications Interface Module (SCI)

MC68HC(9)08LJ60 - Rev. 1.0

## **Table of Contents**

| 12.8.6 SCI Data Register                             |             |
|------------------------------------------------------|-------------|
|                                                      |             |
| Section 13. Serial Peripheral Interface Module (SPI) |             |
| 13.1 Contents                                        | 13          |
| 13.2 Introduction                                    | 14          |
| 13.3 Features                                        | <u>?</u> 14 |
| 13.4 Functional Description                          |             |
| 13.5 Slave Mode                                      |             |
| 13.6 Transmission Formats                            | <u>2</u> 19 |
| 13.6.1 Clock Phase and Polarity Controls             |             |
| 13.6.2 Transmission Format When CPHA = 0             |             |
| 13.6.3 Transmission Format When CPHA = 1             |             |
| 13.6.4 Transmission Initiation Latency               |             |
| 13.8 Error Conditions                                |             |
| 13.8.1 Overflow Error                                |             |
| 13.8.2 Mode Fault Error                              |             |
| 13.9 Interrupts                                      | 231         |
| 13.10 Resetting the SPI                              | 233         |
| 13.11 Wait Mode2                                     | 234         |
| 13.12 SPI During Break Interrupts                    | 234         |
| 13.13 I/O Signals                                    | 235         |
| 13.13.1 Master In/Slave Out (MISO)                   |             |
| 13.13.2 Master Out/Slave In (MOSI)                   |             |
| 13.13.3 Serial Clock (SPSCK)                         |             |
| 13.13.5 Clock Ground (EV <sub>SS</sub> )             |             |
| 13.14 I/O Registers                                  |             |
| 13.14.1 SPI Control Register                         |             |
| 13.14.2 SPI Status and Control Register              |             |
| 13.14.3 SPI Data Register                            | <u>'</u> 44 |

**Advance Information** 

#### Section 14. Alert Output Generator (ALR) 14.1 14.2 14.3 14.4 14.4.1 14.4.2 14.4.3 Section 15. Liquid Crystal Display Module (LCD) 15.1 15.2 15.3 15.4 15.5 15.5.1 LCD Address Register......254 15.5.2 15.5.3 15.6 15.7 15.8 Power Supply Pins (V<sub>LL</sub>, V<sub>LL12</sub>, V<sub>LL32</sub>, Section 16. Timer Interface Module (TIM) 16.1 16.2 16.3 16.4 16.4.1 16.4.2 16.4.3 16.4.3.1 16.4.3.2

MC68HC(9)08LJ60 — Rev. 1.0

## **Table of Contents**

| 16.4.4 Pulse Width Modulation (PWM)               | 271 |
|---------------------------------------------------|-----|
| 16.4.4.1 Unbuffered PWM Signal Generation         |     |
| 16.4.4.2 Buffered PWM Signal Generation           |     |
| 16.4.4.3 PWM Initialization                       | 274 |
| 16.5 Interrupts                                   |     |
| 16.6 Low-Power Modes                              | 276 |
| 16.6.1 Wait Mode                                  | 276 |
| 16.6.2 Stop Mode                                  | 276 |
| 16.7 TIM During Break Interrupts                  | 276 |
| 16.8 I/O Signals                                  |     |
| 16.8.1 TIM Clock Pin (TCLK)                       |     |
| 16.8.2 Timer Channel I/O Pins (TCH0–TCH3)         |     |
| 16.9 I/O Registers                                | 278 |
| 16.9.1 Timer Status and Control Register          | 278 |
| 16.9.2 Timer Counter Registers                    |     |
| 16.9.3 Timer Modulo Registers                     | 282 |
| 16.9.4 Timer Channel Status and Control Registers | 283 |
| 16.9.5 Timer Channel Registers                    | 288 |
| Section 17. Input/Output (I/O) Ports              |     |
| 17.1 Contents                                     | 291 |
| 17.2 Introduction                                 | 291 |
| 17.3 Port A                                       | 293 |
| 17.3.1 Port A Data Register                       |     |
| 17.3.2 Data Direction Register A                  |     |
| 17.4 Port B                                       | 296 |
| 17.4.1 Port B Data Register                       | 296 |
| 17.4.2 Data Direction Register B                  |     |
| 17.5 Port C                                       | 299 |
| 17.5.1 Port C Data Register                       |     |
| 17.5.2 Data Direction Register C                  |     |

**Advance Information** 

14

#### Section 18. Monitor ROM (MON)

| (                                                 |                                                                                                                                                                                                                        |
|---------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Contents                                          | .303                                                                                                                                                                                                                   |
| Introduction                                      | .303                                                                                                                                                                                                                   |
| Features                                          | .303                                                                                                                                                                                                                   |
| Functional Description                            | .304                                                                                                                                                                                                                   |
| Entering Monitor Mode                             | .306                                                                                                                                                                                                                   |
|                                                   |                                                                                                                                                                                                                        |
| _                                                 |                                                                                                                                                                                                                        |
| 3                                                 |                                                                                                                                                                                                                        |
| Baud Rate                                         | .312                                                                                                                                                                                                                   |
| Section 19. Keyboard Interrupt (KBI) Module       |                                                                                                                                                                                                                        |
| Contents                                          | .313                                                                                                                                                                                                                   |
| Introduction                                      | .313                                                                                                                                                                                                                   |
| Features                                          | .313                                                                                                                                                                                                                   |
| Functional Description                            | .315                                                                                                                                                                                                                   |
| Initialization                                    | .316                                                                                                                                                                                                                   |
| Wait Mode                                         | .317                                                                                                                                                                                                                   |
| I/O Registers                                     | .317                                                                                                                                                                                                                   |
|                                                   |                                                                                                                                                                                                                        |
| 2 Keyboard Interrupt Enable Register              | .317                                                                                                                                                                                                                   |
| Section 20. Preliminary Electrical Specifications |                                                                                                                                                                                                                        |
| •                                                 | .319                                                                                                                                                                                                                   |
|                                                   |                                                                                                                                                                                                                        |
| Absolute Maximum Ratings                          | .320                                                                                                                                                                                                                   |
| Functional Operating Range                        | .321                                                                                                                                                                                                                   |
| Thermal Characteristics                           | .321                                                                                                                                                                                                                   |
| 3.0 Volt ± 10% DC Electrical Characteristics      | .322                                                                                                                                                                                                                   |
| 2.0 Volt ± 10% DC Electrical Characteristics      | .323                                                                                                                                                                                                                   |
| 3.0 Volt ± 10% Control Timing                     | .324                                                                                                                                                                                                                   |
| 2.0 Volt ± 10%% Control Timing                    | .324                                                                                                                                                                                                                   |
|                                                   | Data Format Echoing Break Signal Baud Rate  Section 19. Keyboard Interrupt (KBI) Module Contents Introduction Features Functional Description Initialization Wait Mode. I/O Registers IRQ Status and Control Register. |

MC68HC(9)08LJ60 - Rev. 1.0

## **Table of Contents**

| 20.10 | 3.0 Volt $\pm$ 10% Serial Peripheral Interface (SPI) Timing 325 |
|-------|-----------------------------------------------------------------|
| 20.11 | 2.0 Volt $\pm$ 10% Serial Peripheral Interface (SPI) Timing 326 |
| 20.12 | PLL2P12M Electrical Specifications329                           |
| 20.13 | Bus Clock PLL Acquisition/Lock Time Specifications330           |
| 20.14 | PLL2P12M Component Specifications                               |
| 20.15 | RAM Characteristics                                             |
| 20.16 | FLASH Memory Electrical Characteristics                         |
|       | Section 21. Mechanical Data                                     |
| 21.1  | Contents                                                        |
| 21.2  | Introduction                                                    |
| 21.3  | 160 Input/Output, BGA, Thin Map,                                |
|       | 15 x 15 Package (Case #1268)                                    |
|       | Section 22. Ordering Information                                |
| 22.1  | Contents                                                        |
| 22.2  | Introduction                                                    |
| 22.3  | MC Order Numbers                                                |

## Advance Information — MC68HC(9)08LJ60

## **List of Figures**

| Figure                     | Title                                  | Page             |
|----------------------------|----------------------------------------|------------------|
| 1-1                        | MC68HC(9)08LJ60 Block Diagram          | 28               |
| 1-2                        | Power Supply Bypassing                 |                  |
| 1-3                        | Crystal Connections                    | 30               |
| 1-4                        | 160-Pin BGA Pin Assignments            |                  |
| 2-1                        | Memory Map                             | 38               |
| 2-2                        | Control, Status, and Data Registers    |                  |
| 2-3                        | SIM Registers                          | 45               |
| 2-4                        | Vector Addresses in FLASH/ROM          |                  |
| 4-1                        | FLASH Register Summary                 |                  |
| 4-2                        | FLASH1 Control Register (FL1CR)        | 54               |
| 4-3                        | FLASH2 Control Register (FL2CR)        | 56               |
| 4-4                        | FLASH1 Block Protect Register (FL1BPR) | 58               |
| 4-5                        | FLASH2 Block Protect Register (FL2BPR) | 59               |
| 4-6                        | Page Program Algorithm                 | 64               |
| 5-1                        | CPU Registers                          | 67               |
| 5-2                        | Accumulator (A)                        | 68               |
| 5-3                        | Index Register (H:X)                   | 68               |
| 5-4                        | Stack Pointer (SP)                     | 69               |
| 5-5                        | Program Counter (PC)                   | 70               |
| 5-6                        | Condition Code Register (CCR)          |                  |
| 6-1                        | SIM Block Diagram                      |                  |
| 6-2                        | SIM I/O Register Summary               | 86               |
| 6-3                        | CGM Clock Signals                      |                  |
| 6-4                        | External Reset Timing                  | 89               |
| 6-5                        | Internal Reset Timing                  | 90               |
| 6-6                        | Sources of Internal Reset              | 90               |
| MC68HC(9)08LJ60 — Rev. 1.0 | Adv                                    | ance Information |

## List of Figures

| Figure | Title                                          | Page   |
|--------|------------------------------------------------|--------|
| 6-7    | POR Recovery                                   | 91     |
| 6-8    | Interrupt Entry                                | 95     |
| 6-9    | Interrupt Processing                           | 96     |
| 6-10   | Interrupt Recovery                             | 97     |
| 6-11   | Interrupt Recognition Example                  | 98     |
| 6-12   | Wait Mode Entry Timing                         | 100    |
| 6-13   | Wait Recovery from Interrupt or Break          | 101    |
| 6-14   | Wait Recovery from Internal Reset              | 101    |
| 6-15   | Stop Mode Entry Timing                         | 102    |
| 6-16   | Stop Mode Recovery from Interrupt or Break     | 102    |
| 6-17   | SIM Break Status Register (SBSR)               | 103    |
| 6-18   | SIM Reset Status Register (SRSR)               | 105    |
| 6-19   | SIM Break Flag Control Register (SBFCR)        | 106    |
| 7-1    | CGMB Block Diagram                             | 110    |
| 7-2    | CGMB External Connections                      | 120    |
| 7-3    | CGMB I/O Register Summary                      | 123    |
| 7-4    | PLL Control Register (PCTL)                    | 124    |
| 7-5    | PLL Bandwidth Control Register (PBWC)          | 127    |
| 7-6    | PLL Multiplier Select Register High (PMSH)     | 128    |
| 7-7    | PLL Multiplier Select Register Low (PMSL)      | 129    |
| 7-8    | PLL VCO Range Select Register (PVRS)           | 130    |
| 7-9    | PLL Reference Divider Select Register (PRDS)   | 131    |
| 8-1    | Functional Controller Block Diagram            | 141    |
| 8-2    | Real-Time Clock System Block Diagram           | 142    |
| 8-3    | Summary of the Functional Controller Registers | 146    |
| 8-4    | Timebase Control Register (TBCR)               | 147    |
| 8-5    | RTC Control Register (RTCCR)                   | 150    |
| 8-6    | RTC Status Register (RTCSR)                    | 152    |
| 8-7    | Chronograph Data Register (CHRDR)              | 154    |
| 8-8    | Seconds Data Register (SECR)                   | 154    |
| 8-9    | Minutes Data Register (MINR)                   | 155    |
| 8-10   | Hours Data Register (HORR)                     | 155    |
| 8-11   | Alarm Minutes Register (ALRMR)                 | 156    |
| 8-12   | Alarm Hours Register (ALRHR)                   | 156    |
|        | MC68HC(9)08L.I6(                               | )Rev_1 |

|                        | Figure | Title                                      | Page            |
|------------------------|--------|--------------------------------------------|-----------------|
|                        | 9-1    | Break Module Block Diagram                 | 159             |
|                        | 9-2    | Break I/O Register Summary                 | 159             |
|                        | 9-3    | Break Status and Control Register (BRKSCR) |                 |
|                        | 9-4    | Break Address Register High (BRKH)         |                 |
|                        | 9-5    | Break Address Register Low (BRKL)          |                 |
|                        | 10-1   | POR Block Diagram                          | 164             |
|                        | 11-1   | IRQ I/O Register Summary                   | 166             |
|                        | 11-2   | IRQ Module Block Diagram                   |                 |
|                        | 11-3   | IRQ Interrupt Flowchart                    |                 |
|                        | 11-4   | IRQ Status and Control Register (ISCR)     |                 |
|                        | 12-1   | SCI Module Block Diagram                   | 178             |
|                        | 12-2   | SCI Input/Output (I/O) Register Summary    |                 |
|                        | 12-3   | SCI Data Formats                           |                 |
|                        | 12-4   | SCI Transmitter                            | 182             |
|                        | 12-5   | SCI Receiver Block Diagram                 |                 |
|                        | 12-6   | Receiver Data Sampling                     |                 |
|                        | 12-7   | Slow Data                                  |                 |
|                        | 12-8   | Fast Data                                  | 190             |
|                        | 12-9   | SCI Control Register 1 (SCC1)              | 196             |
|                        | 12-10  | SCI Control Register 2 (SCC2)              |                 |
|                        | 12-11  | SCI Control Register 3 (SCC3)              |                 |
|                        | 12-12  | SCI Status Register 1 (SCS1)               |                 |
|                        | 12-13  | SCI Status Register 2 (SCS2)               |                 |
|                        | 12-14  | SCI Data Register (SCDR)                   |                 |
|                        | 12-15  | SCI Baud Rate Register (SCBR)              |                 |
|                        | 13-1   | SPI I/O Register Summary                   | 215             |
|                        | 13-2   | SPI Module Block Diagram                   |                 |
|                        | 13-3   | Full-Duplex Master-Slave Connections       | 218             |
|                        | 13-4   | Transmission Format (CPHA = 0)             |                 |
|                        | 13-5   | CPHA/SS Timing                             |                 |
|                        | 13-6   | Transmission Format (CPHA = 1)             |                 |
|                        | 13-7   | Transmission Start Delay (Master)          |                 |
| MC68HC(9)08LJ60 — Rev. | 1.0    | Adva                                       | nce Information |

## List of Figures

| Figure | Title                                              | Page |
|--------|----------------------------------------------------|------|
| 13-8   | SPRF/SPTE CPU Interrupt Timing                     | 225  |
| 13-9   | Missed Read of Overflow Condition                  | 227  |
| 13-10  | Clearing SPRF When OVRF Interrupt Is Not Enabled   | 228  |
| 13-11  | SPI Interrupt Request Generation                   | 232  |
| 13-12  | CPHA/SS Timing                                     | 237  |
| 13-13  | SPI Control Register (SPCR)                        |      |
| 13-14  | SPI Status and Control Register (SPSCR)            | 241  |
| 13-15  | SPI Data Register (SPDR)                           | 244  |
| 14-1   | Alert Control Register (ALCR)                      | 247  |
| 14-2   | Alert Data Register (ALDR)                         | 248  |
| 14-3   | Block Diagram of SPL Reduction Circuit             | 250  |
| 15-1   | LCD Driver Block Diagram                           | 252  |
| 15-2   | LCD Control Register (LCDCR)                       | 253  |
| 15-3   | LCD Address Register (LCDAR)                       | 254  |
| 15-4   | LCD Data Register (LCDDR)                          | 256  |
| 15-5   | LCD Backplane Waveforms — 3 BP                     | 257  |
| 15-6   | LCD Backplane Waveforms — 5 BP                     | 258  |
| 15-7   | LCD Backplane Waveforms — 8 BP                     |      |
| 15-8   | LCD Backplane Waveforms with Anti-Ghosting — 3 BP  |      |
| 15-9   | LCD Voltage Converter Connections                  | 262  |
| 16-1   | TIM Block Diagram                                  | 265  |
| 16-2   | TIM I/O Register Summary                           | 266  |
| 16-3   | PWM Period and Pulse Width                         |      |
| 16-4   | Timer Status and Control Register (TSC)            |      |
| 16-5   | Timer Counter Register High (TCNTH)                |      |
| 16-6   | Timer Counter Register Low (TCNTL)                 |      |
| 16-7   | Timer Modulo Register High (TMODH)                 |      |
| 16-8   | Timer Modulo Register Low (TMODL)                  |      |
| 16-9   | Timer Channel 0 Status and Control Register (TSC0) |      |
| 16-10  | Timer Channel 1 Status and Control Register (TSC1) |      |
| 16-11  | Timer Channel 2 Status and Control Register (TSC2) |      |
| 16-12  | Timer Channel 3 Status and Control Register (TSC3) |      |
| 16-13  | CHxMAX Latency                                     | 287  |
|        |                                                    |      |

20

| Figure | Title                                      | Page |
|--------|--------------------------------------------|------|
| 16-14  | Timer Channel 0 Register High (TCH0H)      | 288  |
| 16-15  | Timer Channel 0 Register Low (TCH0L)       | 288  |
| 16-16  | Timer Channel 1 Register High (TCH1H)      | 289  |
| 16-17  | Timer Channel 1 Register Low (TCH1L)       | 289  |
| 16-18  | Timer Channel 2 Register High (TCH2H)      | 289  |
| 16-19  | Timer Channel 2 Register Low (TCH2L)       | 289  |
| 16-20  | Timer Channel 3 Register High (TCH3H)      | 290  |
| 16-21  | Timer Channel 3 Register Low (TCH3L)       | 290  |
| 17-1   | I/O Port Register Summary                  | 292  |
| 17-2   | Port A Data Register (PTA)                 | 293  |
| 17-3   | Data Direction Register A (DDRA)           | 294  |
| 17-4   | Port A I/O Circuit                         | 294  |
| 17-5   | Port B Data Register (PTB)                 | 296  |
| 17-6   | Data Direction Register B (DDRB)           | 297  |
| 17-7   | Port B I/O Circuit                         | 297  |
| 17-8   | Port C Data Register (PTC)                 | 299  |
| 17-9   | Data Direction Register C (DDRC)           | 300  |
| 17-10  | Port C I/O Circuit                         | 300  |
| 18-1   | Monitor Mode Circuit                       | 305  |
| 18-2   | Monitor Data Format                        | 307  |
| 18-3   | Sample Monitor Waveforms                   | 307  |
| 18-4   | Read Transaction                           | 308  |
| 18-5   | Break Transaction                          | 308  |
| 19-1   | Block Diagram                              | 314  |
| 19-2   | Keyboard Interrupt Enable Register (KBIER) | 317  |
| 20-1   | SPI Master Timing                          | 327  |
| 20-2   | SPI Slave Timing                           | 328  |

MC68HC(9)08LJ60 — Rev. 1.0

List of Figures

Advance Information

## Advance Information — MC68HC(9)08LJ60

## **List of Tables**

| Table                      | Title                                       | Page               |
|----------------------------|---------------------------------------------|--------------------|
| 4-1                        | Erase Block Sizes of FLASH1                 |                    |
| 4-2                        | Erase Block Sizes of FLASH2                 | 56                 |
| 4-3                        | Charge Pump Clock Frequency                 |                    |
| 5-1                        | Instruction Set Summary                     |                    |
| 5-2                        | Opcode Map                                  |                    |
| 6-1                        | Signal Name Conventions                     |                    |
| 6-2                        | PIN Bit Set Timing                          |                    |
| 6-3                        | SIM Registers                               |                    |
| 7-1                        | Numeric Example of PLL Register Programming | g 117              |
| 7-2                        | PRE1 and PRE0 Programming                   |                    |
| 7-3                        | VPR1 and VPR0 Programming                   |                    |
| 8-1                        | Watchdog Timer Timeout Rates                |                    |
| 8-2                        | Timebase Crystal Options                    | 149                |
| 8-3                        | PRQ1 and PRQ0 RTC Interrupt Periods         |                    |
| 12-1                       | Start Bit Verification                      |                    |
| 12-2                       | Data Bit Recovery                           |                    |
| 12-3                       | Stop Bit Recovery                           |                    |
| 12-4                       | Character Format Selection                  | 198                |
| 12-5                       | SCI Baud Rate Prescaling                    |                    |
| 12-6                       | SCI Baud Rate Selection                     |                    |
| 12-7                       | SCI Baud Rate Selection Examples            |                    |
| 13-1                       | SPI Interrupts                              |                    |
| 13-2                       | SPI Configuration                           |                    |
| MC68HC(9)08LJ60 — Rev. 1.0 | A                                           | dvance Information |

## List of Tables

| Table | Title                                     | Page |
|-------|-------------------------------------------|------|
| 13-3  | SPI Master Baud Rate Selection            | 243  |
| 14-1  | Audio Alert Tone Generator Divider Ratios | 246  |
| 14-2  | Clock Divider and Modulator Selections    | 248  |
| 14-3  | Duty Cycle Selection                      | 249  |
| 15-1  | Duty Cycle Select                         | 253  |
| 15-2  | Frontplane Address Assignments            | 255  |
| 16-1  | Prescaler Selection                       | 280  |
| 16-2  | Mode, Edge, and Level Selection           | 286  |
| 17-1  | Port A Pin Functions                      | 295  |
| 17-2  | Port B Pin Functions                      | 298  |
| 17-3  | Port C Pin Functions                      | 301  |
| 18-1  | Mode Selection                            | 306  |
| 18-2  | Mode Differences                          | 307  |
| 18-3  | READ (Read Memory) Command                | 309  |
| 18-4  | WRITE (Write Memory) Command              | 309  |
| 18-5  | IREAD (Indexed Read) Command              | 310  |
| 18-6  | IWRITE (Indexed Write) Command            |      |
| 18-7  | READSP (Read Stack Pointer) Command       |      |
| 18-8  | RUN (Run User Program) Command            |      |
| 18-9  | Monitor Baud Rate Selection               | 312  |
| 22-1  | MC Order Numbers                          | 335  |

**Advance Information** 

## Advance Information — MC68HC(9)08LJ60

## Section 1. General Description

#### 1.1 Contents

| 1.2    | Introduction                                                                 | 26 |
|--------|------------------------------------------------------------------------------|----|
| 1.3    | Features                                                                     | 26 |
| 1.4    | MCU Block Diagram                                                            | 27 |
| 1.4.1  | Power Supply Pins ( $V_{DD}$ , $V_{SS}$ , $EV_{DD}$ , and $EV_{SS}$ )        | 29 |
| 1.4.2  | Oscillator Pins (OSC1 and OSC2)                                              |    |
| 1.4.3  | External Reset Pin (RST)                                                     | 30 |
| 1.4.4  | External Interrupt Pin (IRQ1)                                                | 31 |
| 1.4.5  | External Interrupt Pin (IRQ2)                                                | 31 |
| 1.4.6  | Analog Ground Pin (V <sub>SSA</sub> )                                        | 31 |
| 1.4.7  | Analog Power Supply Pin (V <sub>DDA</sub> )                                  |    |
| 1.4.8  | External Filter Capacitor Pin (CGMXFC)                                       |    |
| 1.4.9  | Port A I/O Pins (PTA7–PTA0)                                                  | 31 |
| 1.4.10 | Port B I/O Pins (PTB7–PTB0)                                                  | 32 |
| 1.4.11 | Port C I/O Pins (PTC7–PTC0)                                                  | 32 |
| 1.4.12 | SPI Master In Slave Out (MISO)                                               | 32 |
| 1.4.13 | SPI Master Out Slave In (MOSI)                                               | 32 |
| 1.4.14 |                                                                              |    |
| 1.4.15 | SPI Slave Select (SS)                                                        | 32 |
| 1.4.16 | SCI Receive Data (RxD)                                                       | 33 |
| 1.4.17 | SCI Transmit Data (TxD)                                                      | 33 |
| 1.4.18 | Alert Generator Output (ALERT)                                               | 33 |
| 1.4.19 | Power Supply Pins (V <sub>LL</sub> , V <sub>LL32</sub> , V <sub>LL12</sub> , |    |
|        | and V <sub>CP4</sub> –V <sub>CP1</sub> )                                     | 33 |
| 1.4.20 | Frontplane and Backplane Drivers                                             |    |
|        | (FP84–FP0, BP7–BP0)                                                          | 33 |
| 1.5    | Pin Assignments                                                              | 33 |
|        |                                                                              |    |

MC68HC(9)08LJ60 - Rev. 1.0

#### **General Description**

#### 1.2 Introduction

The MC68HC(9)08LJ60 is a member of the low-cost, low-power, 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 MC68HC(9)08LJ60 include:

- High-performance M68HC08 architecture
- Fully upward-compatible object code with M6805, M146805, and M68HC05 Families
- On-chip ROM/FLASH of 60 Kbytes
- 3.5 Kbytes of on-chip MCU RAM
- 24 general-purpose input/output (I/O) pins
- Serial peripheral interface module (SPI)
- Serial communications interface module (SCI)
- Clock generation module (CGMB)
- Functional controller module (FCM) with real-time clock
- LCD module with 85 frontplanes and 8 backplanes
- ALERT generator module
- Two external interrupt request (IRQ) pins
- 16-bit timer interface module (TIM)
- System protection features:
  - Computer operating properly (COP) reset in FCM module
  - Illegal opcode detect with reset
  - Illegal address detect with reset

Advance Information

#### Freescale Semiconductor, Inc.

**General Description** MCU Block Diagram

- 160-pin BGA package or die
- Low-power design, fully static with wait modes
- Stop mode is disabled
- Master reset pin and power-on reset

#### Features of the CPU08 include:

- Enhanced HC05 programming model
- Extensive loop control functions
- 16 addressing modes, 8 more than the HC05
- 16-bit index register and stack pointer
- Fast 8 x 8 multiply instruction
- Fast 16/8 divide instruction
- Binary-coded decimal (BCD) instructions
- Optimization for controller applications
- High-level language (C language) support

#### **NOTE:**

There is no direct memory access module (DMA) in MC68HC(9)08LJ60. User should disable all the DMA functions in all modules. Only three ports (ports A, B, and C) are available; ignore all other ports mentioned. No input capture or output compare pins are available for the timer module.

## 1.4 MCU Block Diagram

Figure 1-1 shows the structure of the MC68HC(9)08LJ60.

#### **General Description**



Figure 1-1. MC68HC(9)08LJ60 Block Diagram

#### 1.4.1 Power Supply Pins (V<sub>DD</sub>, V<sub>SS</sub>, EV<sub>DD</sub>, and EV<sub>SS</sub>)

The two  $V_{DD}$  and two  $V_{SS}$  pins are power supply and ground pins for the digital sections of the MCU. The MCU operates from a single-power supply ranging from 2 volts ( $\pm$  10%) to 3 volts ( $\pm$  10%).

The EV<sub>DD</sub> and EV<sub>SS</sub> pins are power supply and ground pins for the I/O section of the MCU.

Very fast signal transitions on the MCU pins place high, short-duration current demands on the power supply. To prevent noise problems, take special care to provide good power supply bypassing at the MCU as shown in **Figure 1-2**. 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.

EV<sub>SS</sub> pin is also the ground return pin for the serial clock in the serial peripheral interface module (SPI). It enables the user to implement a coplanar transmission line for the SPI clock on printed circuit boards (PCBs) with no ground plane. EV<sub>SS</sub> can help reduce radiated radio frequency (RF) emissions by controlling trace impedance and minimizing radiating loop area. See Section 13. Serial Peripheral Interface Module (SPI) for more information.



Figure 1-2. Power Supply Bypassing

**NOTE:** Component values shown represent typical applications.

MC68HC(9)08LJ60 — Rev. 1.0

#### **General Description**

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

The OSC1 and OSC2 pins are the crystal connections for the on-chip oscillator. Figure 1-3 shows a typical crystal oscillator circuit for a parallel resonant crystal. Follow the crystal supplier's recommendations, as the crystal parameters determine the external component values required to provide reliable startup and maximum stability. The load capacitance values used in the oscillator circuit design should include all stray layout capacitances. To minimize output distortion and radio frequency (RF) emissions, mount the crystal and capacitors as close as possible to the pins. Pay special attention to minimizing the length of the oscillator load capacitors' ground return path.



Figure 1-3. Crystal Connections

**NOTE:** Component values shown represent typical applications. Follow the crystal manufacturer's recommendations.

#### 1.4.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 6. System**Integration Module (SIM) for more information.

Advance Information

General Description MCU Block Diagram

#### 1.4.4 External Interrupt Pin (IRQ1)

IRQ1 is an asynchronous external interrupt pin. See Section 6. System Integration Module (SIM) and Section 11. External Interrupt Module (IRQ) for more information.

#### 1.4.5 External Interrupt Pin (IRQ2)

IRQ2 is an asynchronous external interrupt pin. See See Section 6.

System Integration Module (SIM) and Section 11. External Interrupt

Module (IRQ) for more information.

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

The  $V_{\rm SSA}$  analog ground pin is used only for the ground connections for the analog sections of the clock generator module (CGM) and should be decoupled as per the  $V_{\rm SS}$  digital ground pin. See **7.2 Introduction** for more information.

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

V<sub>DDA</sub> is the power supply pin for the analog portion of the clock generator module (CGM). See **7.2 Introduction** for more information.

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

CGMXFC is an external filter capacitor connection for the CGM. See **7.2 Introduction** for more information.

#### 1.4.9 Port A I/O Pins (PTA7-PTA0)

PTA7–PTA0 are general-purpose bidirectional I/O port pins. See **Section 17. Input/Output (I/O) Ports** for more information.

## Freescale Semiconductor, Inc.

#### **General Description**

#### 1.4.10 Port B I/O Pins (PTB7-PTB0)

PTB7–PBC0 are general-purpose bidirectional I/O port pins. See **Section 17. Input/Output (I/O) Ports** for more information.

#### 1.4.11 Port C I/O Pins (PTC7–PTC0)

PTC7–PTC0 are general-purpose bidirectional I/O port pins. See **Section 17. Input/Output (I/O) Ports** for more information.

#### 1.4.12 SPI Master In Slave Out (MISO)

MISO is used in the SPI to receive/transmit data in the SPI module. See **Section 13. Serial Peripheral Interface Module (SPI)** for more information.

#### 1.4.13 SPI Master Out Slave In (MOSI)

MOSI is used in the SPI to receive/transmit data in the SPI module. See **Section 13. Serial Peripheral Interface Module (SPI)** for more information.

#### 1.4.14 SPI Serial Clock (SPSCK)

SPSCK is the serial clock of the SPI that synchronizes data transmission between master and slave devices. See **Section 13. Serial Peripheral Interface Module (SPI)** for more information.

#### 1.4.15 SPI Slave Select (SS)

SS is the slave select of the SPI that indicate that the slave is enabled to receive data when the pin is at logic 0. See Section 13. Serial Peripheral Interface Module (SPI) for more information.

Advance Information

#### 1.4.16 SCI Receive Data (RxD)

The RxD pin is serial data input to the SCI receiver. See **Section 12**. **Serial Communications Interface Module (SCI)** for more information.

#### 1.4.17 SCI Transmit Data (TxD)

The TxD pin is the serial data output from the SCI transmitter. See **Section 12. Serial Communications Interface Module (SCI)** for more information.

#### 1.4.18 Alert Generator Output (ALERT)

This is the output from the alert generator module. See **Section 14. Alert Output Generator (ALR)** for more information.

#### 1.4.19 Power Supply Pins ( $V_{LL}$ , $V_{LL32}$ , $V_{LL12}$ , and $V_{CP4}$ – $V_{CP1}$ )

These are power supply pins for the LCD (liquid crystal display) voltage converter. These pins should be connected in a certain configuration in order for the charge pump to work correctly. See **Section 15. Liquid Crystal Display Module (LCD)** for detailed hookup configuration.

#### 1.4.20 Frontplane and Backplane Drivers (FP84-FP0, BP7-BP0)

These are frontplane (FP84–FP0) and backplane (BP7–BP0) drivers for an LCD display. See **Section 15. Liquid Crystal Display Module** (LCD) for more information.

#### 1.5 Pin Assignments

The MC68HC(9)08LJ60 is available in a 160-pin BGA package. The pin assignments for this package are shown in **Figure 1-4**.

#### **General Description**



Figure 1-4. 160-Pin BGA Pin Assignments

#### Freescale Semiconductor, Inc.

#### Advance Information — MC68HC(9)08LJ60

## Section 2. Memory Map

#### 2.1 Contents

| 2.2 | Introduction                   |
|-----|--------------------------------|
| 2.3 | I/O Section                    |
| 2.4 | Random-Access Memory (RAM)36   |
| 2.5 | Memory Map                     |
| 2.6 | Monitor Read-Only Memory (ROM) |

#### 2.2 Introduction

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

- 60 Kbytes of FLASH
- 3.5 Kbytes of RAM
- 48 bytes of user-defined vectors
- 240 bytes of monitor ROM

#### **Memory Map**

#### 2.3 I/O Section

Addresses \$0000–\$003F, shown in **Figure 2-2**, contain most of the control, status, and data registers. Additional input/output (I/O) registers (**Figure 2-3**) have these addresses:

- \$FE00, SIM break status register (SBSR)
- \$FE01, SIM reset status register (SRSR)
- \$FE03, SIM break flag control register (SBFCR)
- \$FE09, FLASH2 control register (FL2CR)
- \$FE08, FLASH1 control register (FL1CR)
- \$FE0C and \$FE0D, break address registers (BRKH and BRKL)
- \$FE0E, break status and control register (BRKSCR)

#### 2.4 Random-Access Memory (RAM)

The 3584 addresses from \$0040–\$0E3F are RAM locations. The location of the stack RAM is programmable. The 16-bit stack pointer allows the stack to be anywhere in RAM, allowing all page zero locations to be used for I/O control and user data or code. Within page zero there are 192 bytes of RAM. 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:

To maintain M6805 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 PSHH and PULH instructions.

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 or multiple interrupt levels. The CPU may overwrite data in the RAM during a subroutine or during the interrupt stacking.

### 2.5 Memory Map

See Figure 2-1, Figure 2-2, Figure 2-3, and Figure 2-4.

# Memory Map



Figure 2-1. Memory Map

38



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

MC68HC(9)08LJ60 — Rev. 1.0

## **Memory Map**



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

Advance Information

MC68HC(9)08LJ60 — Rev. 1.0

Memory Map Memory Map



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

MC68HC(9)08LJ60 - Rev. 1.0

**MOTOROLA** 

## **Memory Map**



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

Memory Map Memory Map



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

MC68HC(9)08LJ60 — Rev. 1.0

## **Memory Map**



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

Advance Information

MC68HC(9)08LJ60 — Rev. 1.0



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



Figure 2-3. SIM Registers (Sheet 1 of 2)

MC68HC(9)08LJ60 - Rev. 1.0

## **Memory Map**



Figure 2-3. SIM Registers (Sheet 2 of 2)

| \$FFD0 | Reserved                            |
|--------|-------------------------------------|
| \$FFD1 | Reserved                            |
| \$FFD2 | External IRQ2/KBI Vector (High)     |
| \$FFD3 | External IRQ2/KBI Vector (Low)      |
| \$FFD4 | SCI Module Transmit Vector (High)   |
| \$FFD5 | SCI Module Transmit Vector (Low)    |
| \$FFD6 | SCI Module Receive Vector (High)    |
| \$FFD7 | SCI Module Receive Vector (Low)     |
| \$FFD8 | SCI Module Error Vector (High)      |
| \$FFD9 | SCI Module Error Vector (Low)       |
| \$FFDA | Reserved                            |
| \$FFDB | Reserved                            |
| \$FFDC | Reserved                            |
| \$FFDD | Reserved                            |
| \$FFDE | SPI 1 Module Transmit Vector (High) |
| \$FFDF | SPI 1 Module Transmit Vector (Low)  |
| \$FFE0 | SPI 1 Module Receive Vector (High)  |
| \$FFE1 | SPI 1 Module Receive Vector (Low)   |
| \$FFE2 | Reserved                            |
| \$FFE3 | Reserved                            |
| \$FFE4 | Reserved                            |
| \$FFE5 | Reserved                            |
| \$FFE6 | FCM Module Vector (High)            |
| \$FFE7 | FCM Module Vector (Low)             |
| \$FFE8 | Reserved                            |
| \$FFE9 | Reserved                            |
| \$FFEA | TIM Overflow Vector (High)          |
| \$FFEB | TIM Overflow Vector (Low)           |
| \$FFEC | TIM Channel 3 Vector (High)         |
| \$FFED | TIM Channel 3 Vector (Low)          |
|        |                                     |

Figure 2-4. Vector Addresses in FLASH/ROM (Sheet 1 of 2)

MC68HC(9)08LJ60 — Rev. 1.0

## **Memory Map**

| TIM Channel 2 Vector (High) |
|-----------------------------|
| TIM Channel 2 Vector (Low)  |
| TIM Channel 1 Vector (High) |
| TIM Channel 1 Vector (Low)  |
| TIM Channel 0 Vector (High) |
| TIM Channel 0 Vector (Low)  |
| Reserved                    |
| Reserved                    |
| Reserved                    |
| Reserved                    |
| PLL Module Vector (High)    |
| PLL Module Vector (Low)     |
| IRQ1 Vector (High)          |
| IRQ1 Vector (Low)           |
| SWI Vector (High)           |
| SWI Vector (Low)            |
| Reset Vector (High)         |
| Reset Vector (Low)          |
|                             |

Figure 2-4. Vector Addresses in FLASH/ROM (Sheet 2 of 2)

## 2.6 Monitor Read-Only Memory (ROM)

The 240 bytes at addresses \$FE10–\$FEFF are reserved ROM addresses that contain instructions for the monitor functions. For more information, see **Section 18. Monitor ROM (MON)**.

### Advance Information — MC68HC(9)08LJ60

# Section 3. Random-Access Memory (RAM)

#### 3.1 Contents

| 3.2 | Introduction           | 16 |
|-----|------------------------|----|
| 3.3 | Functional Description | 19 |

#### 3.2 Introduction

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

### 3.3 Functional Description

Addresses \$0040–\$0E3F are RAM locations. The location of the stack RAM is programmable. The 16-bit stack pointer allows the stack to be anywhere in the 64-Kbyte memory space.

### **NOTE:** For

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 I/O (input/output) 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 M6805 compatibility, the H register is not stacked.

MC68HC(9)08LJ60 - Rev. 1.0

## **Random-Access Memory (RAM)**

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 may overwrite data in the RAM during a subroutine or during the interrupt stacking operation.

# Advance Information — MC68HC(9)08LJ60

# Section 4. FLASH Memory

#### 4.1 Contents

| 4.2  | Introduction51                          |
|------|-----------------------------------------|
| 4.3  | FLASH1 Functional Description           |
| 4.4  | FLASH2 Functional Description           |
| 4.5  | FLASH1 Control Register                 |
| 4.6  | FLASH2 Control Register                 |
| 4.7  | FLASH1 Block Protect Register           |
| 4.8  | FLASH2 Block Protect Register           |
| 4.9  | Block Protection                        |
| 4.10 | Charge Pump Frequency Control61         |
| 4.11 | FLASH Erase Operation                   |
| 4.12 | FLASH Program and Margin Read Operation |

#### 4.2 Introduction

This section describes the operation of the embedded 60-Kbyte FLASH memory. The FLASH memory consists of two modules:

- FLASH1 ~32 Kbytes, address range is \$8000–\$FDFF and \$FFD0–\$FFFF
- FLASH2 28 Kbytes, address range \$1000-\$7FFF

FLASH memory is non-volatile and can be read, programmed, and erased from a single external supply.

MC68HC(9)08LJ60 — Rev. 1.0

## **FLASH Memory**



Figure 4-1. FLASH Register Summary

## 4.3 FLASH1 Functional Description

The FLASH1 memory array contains 32,304 bytes. An erased bit reads as a logic 0 and a programmed bit reads as a logic 1. Program and erase operations are facilitated through control bits in a memory mapped register. For additional details, see 4.11 FLASH Erase Operation and 4.12 FLASH Program and Margin Read Operation.

Memory in the FLASH array is organized into pages and rows. There are eight pages of memory per row, and for this array, there are eight bytes per page. The minimum erase block size is a single row, 64 bytes. Programming is performed on a per-page basis, or for this array, eight bytes at a time. These are the address ranges for the 32-Kbyte FLASH memory:

- \$8000–\$FDFF, user FLASH array
- \$FFD0-\$FFFF, user vector space

Advance Information

MC68HC(9)08LJ60 — Rev. 1.0

**FLASH Memory** FLASH2 Functional Description

When programming the FLASH, just enough program time must be utilized via an iterative programming algorithm. Too much program time can result in a disturb condition in which an erased bit becomes programmed. This can be prevented as long as no more than eight program operations are performed per row before again performing an erase operation. Each programmed page is read in margin mode to ensure that the bits are programmed enough for data retention over the device's lifetime. The row architecture for this array is:

\$8000-\$803F Row 0 \$8040-\$807F Row 1 \$8080-\$80BF Row 2  $\downarrow$ 1 \$FFD0-\$FFFF Row 504

## 4.4 FLASH2 Functional Description

The FLASH2 memory array contains 28,672 bytes. An erased bit reads as a logic 0 and a programmed bit reads as a logic 1. Program and erase operations are facilitated through control bits in a memory mapped register. Details for these operations appear later in this section.

Memory in the FLASH array is organized into pages and rows. There are eight pages of memory per row, and for this array, there are eight bytes per page. The minimum erase block size is a single row, 64 bytes. Programming is performed on a per page basis, or for this array, eight bytes at a time. Address range for the 28-Kbyte FLASH memory is \$1000-\$7FFF.

When programming the FLASH, just enough program time must be utilized via an iterative programming algorithm. Too much program time can result in a disturb condition in which an erased bit becomes programmed. This can be prevented as long as no more than eight program operations are performed per row before again performing an erase operation. Each programmed page is read in margin mode to ensure that the bits are programmed enough for data retention over the device's lifetime.

MC68HC(9)08LJ60 — Rev. 1.0

## **FLASH Memory**

### 4.5 FLASH1 Control Register

The FLASH1 control register (FL1CR) controls FLASH program, erase, and margin operations.



Figure 4-2. FLASH1 Control Register (FL1CR)

#### **CAUTION:**

Devices with more than one FLASH have multiple control registers (FLCRs.) Only one flash control register should be accessed at a time. So, while accessing one control register, ensure that any others are cleared.

FDIV0 — Frequency divide control bit

This bit selects the factor by which CGMVCLK is divided to derive the charge pump frequency. See **Table 4-3**.

### NOTE: FDIV1 has no effect.

BLK1 and BLK0 — Block erase control bits

These bits control erasing of blocks of varying size. **Table 4-1** shows the various block sizes which can be erased in one erase operation.

In step 4 of the erase operation (see **4.11 FLASH Erase Operation**), the upper addresses are latched and used to determine the location of the block to be erased. For the full array, the only requirement is that the target address points to any byte in this array. Writing to any address in the array will enable the erase.

HVEN — High voltage enable bit

This read/write bit enables high voltage from the charge pump to the memory for either program or erase operation. It can only be set if either PGM or ERASE is set.

1 = High voltage enabled to array and charge pump on

0 = High voltage disabled to array and charge pump off

FLASH Memory FLASH1 Control Register

Table 4-1. Erase Block Sizes of FLASH1

| BLK1 | BLK0 | Block size                | Row boundaries                                                                                       |
|------|------|---------------------------|------------------------------------------------------------------------------------------------------|
| 0    | 0    | Full array: 32 Kbytes     | 0-504 (\$8000-\$FFFF)                                                                                |
| 0    | 1    | One-half array: 16 Kbytes | 0-255 (\$8000-\$BFFF)<br>256-504 (\$C000-\$FFFF)                                                     |
| 1    | 0    | Eight rows: 512 bytes     | 0-7 (\$8000-\$81FF)<br>8-15 (\$8200-\$83FF)<br>16-23 (\$8400-\$85FF)<br>↓<br>496-503 (\$FC00-\$FDFF) |
| 1    | 1    | Single row: 64 bytes      | 0 (\$8000–\$803F)<br>1 (\$8040–\$807F)<br>↓<br>504 (\$FFD0–\$FFFF)                                   |

### MARG — Program margin control bit

This read/write bit configures the memory for a program margin operation. It cannot be set if the HVEN bit is set, and if it is set when HVEN is set, it will automatically return to 0.

- 1 = Margin operation selected
- 0 = Margin operation unselected

#### ERASE — Erase control bit

This read/write bit configures the memory for erase operation. It is interlocked with the PGM bit such that both bits cannot be set to 1 at the same time.

- 1 = Erase operation selected
- 0 = Erase operation unselected

#### PGM — Program control bit

This read/write bit configures the memory for program operation. It is interlocked with the ERASE bit such that both bits cannot be equal to 1 or set to 1 at the same time.

- 1 = Program operation selected
- 0 = Program operation unselected

## **FLASH Memory**

### 4.6 FLASH2 Control Register

The FLASH2 control register controls FLASH program, erase, and margin operations.



Figure 4-3. FLASH2 Control Register (FL2CR)

FDIV0 — Frequency Divide Control Bit

This bit selects the factor by which CGMVCLK is divided to derive the charge pump frequency. See **Table 4-3**.

**NOTE:** FDIV1 has no effect.

0

1

1

1

0

1

BLK1 and BLK0 — Block erase control bits

These bits control erasing of blocks of varying size. **Table 4-2** shows the various block sizes which can be erased in one erase operation.

 BLK1
 BLK0
 Block size
 Row boundaries

 0
 0
 Full array: 28 Kbytes
 \$1000-\$7FFF

 12 Kbytes; \$1000-\$3FFF
 \$12 Kbytes; \$1000-\$3FFF

One-half array

Eight rows: 512 bytes

Single row: 64 bytes

Table 4-2. Erase Block Sizes of FLASH2

In step 4 of the erase operation (see **4.11 FLASH Erase Operation**), the upper addresses are latched and used to determine the location of the block to be erased. For the full array, the only requirement is that the target address points to any byte in this array. Writing to any address in the array will enable the erase.

Advance Information MC68HC(9)08LJ60 — Rev. 1.0

16 Kbytes; \$4000-\$7FFF

FLASH Memory FLASH2 Control Register

#### HVEN — High-voltage enable bit

This read/write bit enables high voltage from the charge pump to the memory for either program or erase operation. It can only be set if either PGM or ERASE is set.

- 1 = High voltage enabled to array and charge pump on
- 0 = High voltage disabled to array and charge pump off

#### MARG — Program margin control bit

This read/write bit configures the memory for a program margin operation. It cannot be set if the HVEN bit is set, and if it is set when HVEN is set, it will automatically return to 0.

- 1 = Margin operation selected
- 0 = Margin operation unselected

#### ERASE — Erase control bit

This read/write bit configures the memory for erase operation. It is interlocked with the PGM bit such that both bits cannot be set to 1 at the same time.

- 1 = Erase operation selected
- 0 = Erase operation unselected

#### PGM — Program control bit

This read/write bit configures the memory for program operation. It is interlocked with the ERASE bit such that both bits cannot be equal to 1 or set to 1 at the same time.

- 1 = Program operation selected
- 0 = Program operation unselected

Semiconductor, Inc

## **FLASH Memory**

### 4.7 FLASH1 Block Protect Register

The block protect register is implemented as an I/O register. Each bit, when programmed, protects a range of addresses in the FLASH.



Figure 4-4. FLASH1 Block Protect Register (FL1BPR)

BPR3 — Block protect register bit 3

This bit protects the memory contents in the address range \$C000–\$FFFF.

- 1 = Address range protected from erase or program
- 0 = Address range open to erase or program

BPR2 — Block protect register bit 2

This bit protects the memory contents in the address range \$A000–\$FFFF.

- 1 = Address range protected from erase or program
- 0 = Address range open to erase or program

BPR1 — Block protect register bit 1

This bit protects the memory contents in the address range \$9000–\$FFFF.

- 1 = Address range protected from erase or program
- 0 = Address range open to erase or program

BPR0 — Block protect register bit 0

This bit protects the memory contents in the address range \$8000–\$FFFF.

- 1 = Address range protected from erase or program
- 0 = Address range open to erase or program

Advance Information

MC68HC(9)08LJ60 — Rev. 1.0

FLASH Memory FLASH2 Block Protect Register

By programming the block protect bits, a portion of the memory will be locked so that no further erase or program operations may be performed. Programming more than one bit at a time is redundant. For instance, if both BPR3 and BPR2 are set, the address range \$A000–\$FFFF is locked. If all bits are cleared, then all of the memory is available for erase and program.

### 4.8 FLASH2 Block Protect Register

The block protect register is implemented as an I/O register. Each bit, when programmed, protects a range of addresses in the FLASH.



Figure 4-5. FLASH2 Block Protect Register (FL2BPR)

#### BPR3 — Block protect register bit 3

This bit protects the upper half portion of full-size 32-K array. Since FLASH2 is 28 Kbytes, the block protect address range is \$4000–\$7FFF.

- 1 = Address range protected from erase or program
- 0 = Address range open to erase or program

#### BPR2 — Block protect register bit 2

This bit protects the upper 3/4 portion of full-size 32-K array. Since FLASH2 is 28 Kbytes, the block protect address range is \$2000–\$7FFF.

- 1 = Address range protected from erase or program
- 0 = Address range open to erase or program

MC68HC(9)08LJ60 — Rev. 1.0

**MOTOROLA** 

### **FLASH Memory**

BPR1 — Block protect register bit 1

This bit protects the upper 7/8 portion of a full size 32-K array. Since FLASH2 is 28 Kbytes, the block protect address range is \$1000–\$7FFF.

- 1 = Address range protected from erase or program
- 0 = Address range open to erase or program

BPR0 — Block protect register bit 0

This bit protects all the memory contents in the address range \$1000–\$7FFF.

- 1 = Address range protected from erase or program
- 0 = Address range open to erase or program

By programming the block protect bits, a portion of the memory will be locked so that no further erase or program operations may be performed. Programming more than one bit at a time is redundant. If both BPR3 and BPR2 are set, for instance, the address range \$2000–\$7FFF is locked. If all bits are cleared, then all of the memory is available for erase and program.

#### 4.9 Block Protection

Because of the ability of the on-board charge pump to erase and program the FLASH memory in the target application, provision is made for protecting blocks of memory from unintentional erase or program operations. This protection is done by reserving a location in the I/O space for block protect information. If the address range for an erase or program operation includes a protected block, the PGM or ERASE bit is cleared which prevents the HVEN bit in the FLASH control register from being set so that no high voltage is allowed in the array.

When the block protect register is cleared, the entire memory is accessible for program and erase. When bits within the register are programmed, they lock blocks of memory address ranges as shown in 4.7 FLASH1 Block Protect Register and 4.8 FLASH2 Block Protect Register.

Advance Information

MC68HC(9)08LJ60 — Rev. 1.0

FLASH Memory Charge Pump Frequency Control

## 4.10 Charge Pump Frequency Control

The internal charge pump for this array is to be operated over the specified frequency range (refer to **Table 4-3**). The PLL output clock, CGMVCLK, is used to derive the two quadrature clocks, VCLK12 and VCLK23, which are one-half CGMVCLK. Additional pump frequency control is provided using the FDIV0 bit in order to keep the VCLKs within the specified range. The PLL must be ON and locked (but not necessarily engaged) before program/erase operations can be performed.

**Table 4-3. Charge Pump Clock Frequency** 

| FDIV0 | Pump clock frequency |
|-------|----------------------|
| 0     | CGMVCLK ÷ 2          |
| 1     | CGMVCLK ÷ 4          |

### 4.11 FLASH Erase Operation

NOTE:

After a total of eight program operations has been applied to a row, the row must be erased before further use in order to avoid a disturb condition. An erased byte will read \$00.

In 20.16 FLASH Memory Electrical Characteristics, a detailed description of the times used in this algorithm is given.

Use this procedure to erase a block of FLASH memory:

- 1. Establish pump frequency by configuring PLL.
- 2. Unprotect target portion of the array, BPR0-BPR3.
- 3. Set the ERASE bit, the BLK0, BLK1, and FDIV0 bits in the FLASH control register.
- 4. Write to any FLASH address with any data within the block address range desired.
- Set the HVEN bit.
- 6. Wait for a time, t<sub>Erase</sub>.

MC68HC(9)08LJ60 — Rev. 1.0

### **FLASH Memory**

- 7. Clear the HVEN bit.
- 8. Wait for a time, t kill for the high voltages to dissipate.
- 9. Clear the ERASE bit.
- 10. After time, t<sub>HVD</sub>, the memory can be accessed in read mode again.

#### **CAUTION:**

These operations must be performed in the order as shown, but other unrelated operations may occur between the steps. Do not exceed  $t_{ERASE}$  maximum.

## 4.12 FLASH Program and Margin Read Operation

Programming of this FLASH array is done on a page basis where one page equals eight bytes. The purpose of the margin read mode is to ensure that data has been programmed with sufficient margin for long term data retention. During a margin read, the control gates of the selected memory bits are held at a slightly negative voltage by an internal charge pump. Reading the data in margin mode is the same as for ordinary read mode except that a built-in counter stretches the data access for an additional eight cycles to allow sensing of the lower cell current. In short, a margin read applies a more stringent condition on the bitcell during read which ensures the data will be valid throughout the life of the product. A margin read can only follow a program operation. Refer to Section 20. Preliminary Electrical Specifications.

The procedure for programming the FLASH memory is:

- 1. Establish pump frequency by configuring the PLL.
- 2. Set the PGM bit and program FDIV0 appropriately. This configures the memory for program operation and enables the latching of address and data for programming.
- 3. Write data to the page (eight bytes) being programmed.
- 4. Set the HVEN bit.
- 5. Wait for time, t<sub>STEP</sub>.
- 6. Clear the HVEN bit.
- 7. Wait for time, t<sub>HVTV</sub>.

Advance Information

MC68HC(9)08LJ60 — Rev. 1.0

FLASH Program and Margin Read Operation

- 8. Set the MARG bit.
- 9. Wait for time, t<sub>VTP</sub>.
- 10. Clear the PGM bit.
- 11. Wait for time, t<sub>HVD</sub>.
- 12. Read the page of data (this is in margin mode.)
- 13. Clear the MARG bit.
- 14. If any programmed bits do not read correctly, repeat the process from step 2 through step 13 up to maximum program pulses (see Section 20. Preliminary Electrical Specifications).

## **FLASH Memory**



Figure 4-6. Page Program Algorithm

Advance Information

64

MC68HC(9)08LJ60 — Rev. 1.0

### Advance Information — MC68HC(9)08LJ60

# Section 5. Central Processor Unit (CPU)

### 5.1 Contents

| 5.2   | Introduction                |
|-------|-----------------------------|
| 5.3   | Features                    |
| 5.4   | CPU Registers               |
| 5.4.1 | Accumulator                 |
| 5.4.2 | Index Register              |
| 5.4.3 | Stack Pointer               |
| 5.4.4 | Program Counter70           |
| 5.4.5 | Condition Code Register     |
| 5.5   | Arithmetic/Logic Unit (ALU) |
| 5.6   | CPU During Break Interrupts |
| 5.7   | Instruction Set Summary74   |
| 5.8   | Opcode Map                  |

#### 5.2 Introduction

This section describes the central processor unit (CPU8, version A). 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.

### **Central Processor Unit (CPU)**

#### 5.3 Features

#### Features of the CPU include:

- Fully upward, object-code compatibility with M68HC05 Family
- 16-bit stack pointer with stack manipulation instructions
- 16-bit index register with X-register manipulation instructions
- 4-MHz CPU internal bus frequency characterized at 3 volts
- 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

**NOTE:** Stop mode is disabled on the MC68HC(9)08LJ60.

Central Processor Unit (CPU)

CPU Registers

## 5.4 CPU Registers

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



Figure 5-1. CPU Registers

### **Central Processor Unit (CPU)**

#### 5.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 5-2. Accumulator (A)

#### 5.4.2 Index Register

The 16-bit index register 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.

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



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

Central Processor Unit (CPU)

CPU Registers

#### 5.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 (LSB) to \$FF and does not affect the most significant byte (MSB). 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.



Figure 5-4. Stack Pointer (SP)

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 to RAM locations only.

## **Central Processor Unit (CPU)**

### 5.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 5-5. Program Counter (PC)

70

Central Processor Unit (CPU)

CPU Registers

### 5.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. Bits 6 and 5 are set permanently to logic 1. The following paragraphs describe the functions of the condition code register.



Figure 5-6. Condition Code Register (CCR)

#### V — Overflow flag

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

The CPU sets the half-carry flag when a carry occurs between accumulator bits 3 and 4 during an ADC (add with carry) or ADD (add without carry) operation. The half-carry flag is required for binary-coded decimal (BCD) arithmetic operations. The DAA (decimal adjust A) 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

### **Central Processor Unit (CPU)**

### I — Interrupt mask

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 M6805 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 PSHH and 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

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

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

Central Processor Unit (CPU)
Arithmetic/Logic Unit (ALU)

#### C — Carry/borrow flag

The CPU sets the carry/borrow flag when an addition operation produces a carry out of bit 7 of the accumulator or when a subtraction operation requires a borrow. Some 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

### 5.5 Arithmetic/Logic Unit (ALU)

The ALU performs the arithmetic and logic operations defined by the instruction set.

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

### 5.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 9. Break Module**.) 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.

# **Central Processor Unit (CPU)**

### 5.7 Instruction Set Summary

**Table 5-1. Instruction Set Summary** 

| Source<br>Form                                                                                | Operation                                            | Description                                      |          | Εf       |   | ct<br>CR |          |          | Address<br>Mode                                                                              | Opcode                                           | Operand                                      | les                                  |
|-----------------------------------------------------------------------------------------------|------------------------------------------------------|--------------------------------------------------|----------|----------|---|----------|----------|----------|----------------------------------------------------------------------------------------------|--------------------------------------------------|----------------------------------------------|--------------------------------------|
| Form                                                                                          | ·                                                    | •                                                | ٧        | Н        | ı | N        | Z        | С        | Add                                                                                          | obc                                              | Ope                                          | Cycles                               |
| ADC #opr<br>ADC opr<br>ADC opr<br>ADC opr,X<br>ADC opr,X<br>ADC,X<br>ADC opr,SP<br>ADC opr,SP | Add with Carry                                       | $A \leftarrow (A) + (M) + (C)$                   | <b>‡</b> | \$       | _ | <b>‡</b> | <b>‡</b> | <b>‡</b> | 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,X<br>ADD opr,SP<br>ADD opr,SP | Add without Carry                                    | $A \leftarrow (A) + (M)$                         | <b>‡</b> | <b>‡</b> | _ | <b>‡</b> | <b>‡</b> | <b>‡</b> | 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>4<br>3<br>2<br>4<br>5 |
| AIS #opr                                                                                      | Add Immediate Value (Signed) to SP                   | SP ← (SP) + (16 <b>«</b> M)                      | -        | -        | _ | _        | -        | -        | IMM                                                                                          | A7                                               | ii                                           | 2                                    |
| AIX #opr                                                                                      | Add Immediate Value (Signed) to H:X                  | $H:X \leftarrow (H:X) + (16 \text{ 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        | _        | _ | <b>‡</b> | <b>‡</b> | _        | 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 | 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 |
| ASL opr<br>ASLA<br>ASLX<br>ASL opr,X<br>ASL ,X<br>ASL opr,SP                                  | Arithmetic Shift Left<br>(Same as LSL)               | D ← 0 b0 b0                                      | <b>‡</b> | _        | _ | <b>‡</b> | <b>‡</b> | <b>‡</b> | 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>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                               | b7 b0                                            | <b>‡</b> | _        | _ | <b>‡</b> | <b>‡</b> | <b>‡</b> | 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>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 | 4<br>4<br>4<br>4<br>4<br>4<br>4      |
| BCS rel                                                                                       | Branch if Carry Bit Set (Same as BLO)                | PC ← (PC) + 2 + rel? (C) = 1                     | -        | -        | - | -        | -        | -        | REL                                                                                          | 25                                               | rr                                           | 3                                    |
| BEQ rel                                                                                       | Branch if Equal                                      | PC ← (PC) + 2 + rel ? (Z) = 1                    |          |          |   |          | _        | _        | REL                                                                                          | 27                                               | rr                                           | 3                                    |
| BGE opr                                                                                       | Branch if Greater Than or Equal To (Signed Operands) | $PC \leftarrow (PC) + 2 + rel? (N \oplus V) = 0$ | _        | _        | - | _        | _        | _        | REL                                                                                          | 90                                               | rr                                           | 3                                    |

**Advance Information** 

MC68HC(9)08LJ60 — Rev. 1.0

Central Processor Unit (CPU)
Instruction Set Summary

**Table 5-1. Instruction Set Summary (Continued)** 

| Source<br>Form                                                                         | Operation                                         | Description                                           |   | Ef | _ | ct (     |          |          | de<br>de                                                                                     | Opcode                                       | Operand                                                              | Cycles                               |
|----------------------------------------------------------------------------------------|---------------------------------------------------|-------------------------------------------------------|---|----|---|----------|----------|----------|----------------------------------------------------------------------------------------------|----------------------------------------------|----------------------------------------------------------------------|--------------------------------------|
| Form                                                                                   |                                                   | -                                                     | ٧ | Н  | I | N        | Z        | С        | Addres<br>Mode                                                                               | ď                                            | ď                                                                    | ပ်                                   |
| BGT opr                                                                                | Branch if Greater Than (Signed Operands)          | $PC \leftarrow (PC) + 2 + rel?(Z)   (N \oplus V) = 0$ | - | -  | - | _        | 1        | -        | REL                                                                                          | 92                                           | rr                                                                   | 3                                    |
| BHCC rel                                                                               | Branch if Half Carry Bit Clear                    | PC ← (PC) + 2 + rel? (H) = 0                          | - | -  | - | -        | -        | -        | REL                                                                                          | 28                                           | rr                                                                   | 3                                    |
| BHCS rel                                                                               | Branch if Half Carry Bit Set                      | PC ← (PC) + 2 + rel? (H) = 1                          | _ | _  | - | -        | -        | _        | REL                                                                                          | 29                                           | rr                                                                   | 3                                    |
| BHI rel                                                                                | Branch if Higher                                  | $PC \leftarrow (PC) + 2 + rel?(C)   (Z) = 0$          | - | _  | _ | -        | -        | -        | REL                                                                                          | 22                                           | rr                                                                   | 3                                    |
| BHS rel                                                                                | Branch if Higher or Same<br>(Same as BCC)         | PC ← (PC) + 2 + rel? (C) = 0                          | _ | _  | _ | _        | -        | _        | REL                                                                                          | 24                                           | rr                                                                   | 3                                    |
| BIH rel                                                                                | Branch if IRQ Pin High                            | PC ← (PC) + 2 + <i>rel</i> ? <del>IRQ</del> = 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,X<br>BIT opr,X<br>BIT opr,X<br>BIT opr,SP<br>BIT opr,SP | Bit Test                                          | (A) & (M)                                             | 0 | _  | _ | <b>‡</b> | <b>‡</b> | _        | 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     |                                                                      | 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 + rel?(Z)   (N \oplus V) = 1$ | - | _  | - | -        | -        | -        | REL                                                                                          | 93                                           | rr                                                                   | 3                                    |
| BLO rel                                                                                | Branch if Lower (Same as BCS)                     | PC ← (PC) + 2 + rel? (C) = 1                          |   |    |   | _        | ı        | _        | REL                                                                                          | 25                                           | rr                                                                   | 3                                    |
| BLS rel                                                                                | Branch if Lower or Same                           | $PC \leftarrow (PC) + 2 + rel?(C)   (Z) = 1$          | _ | _  | ı | _        | ı        | _        | REL                                                                                          | 23                                           | rr                                                                   | 3                                    |
| BLT opr                                                                                | Branch if Less Than (Signed Operands)             | $PC \leftarrow (PC) + 2 + rel? (N \oplus V) = 1$      | - | -  | _ | -        | -        | -        | REL                                                                                          | 91                                           | rr                                                                   | 3                                    |
| BMC rel                                                                                | Branch if Interrupt Mask Clear                    | $PC \leftarrow (PC) + 2 + rel? (I) = 0$               | _ | _  | _ | _        | _        | -        | REL                                                                                          | 2C                                           | rr                                                                   | 3                                    |
| BMI rel                                                                                | Branch if Minus                                   | $PC \leftarrow (PC) + 2 + rel? (N) = 1$               | _ | _  | - | _        | -        | -        | REL                                                                                          | 2B                                           | rr                                                                   | 3                                    |
| BMS rel                                                                                | Branch if Interrupt Mask Set                      | PC ← (PC) + 2 + rel? (I) = 1                          | _ | _  | _ | _        | _        | _        | REL                                                                                          | 2D                                           | rr                                                                   | 3                                    |
| BNE rel                                                                                | Branch if Not Equal                               | $PC \leftarrow (PC) + 2 + rel? (Z) = 0$               | _ | _  | _ | _        | _        | _        | REL                                                                                          | 26                                           | rr                                                                   | 3                                    |
| BPL rel                                                                                | Branch if Plus                                    | $PC \leftarrow (PC) + 2 + rel? (N) = 0$               | _ | _  | _ | _        | -        | _        | REL                                                                                          | 2A                                           | rr                                                                   | 3                                    |
| BRA rel                                                                                | Branch Always                                     | PC ← (PC) + 2 + <i>rel</i>                            | _ | _  | _ | _        | -        | -        | 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                 | _ | _  | _ | _        | _        | <b>‡</b> | 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 | 55555555                             |
| BRN rel                                                                                | Branch Never                                      | PC ← (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                 | _ | _  | - | _        | _        | <b>‡</b> | 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 | 55555555                             |

MC68HC(9)08LJ60 - Rev. 1.0

# **Central Processor Unit (CPU)**

**Table 5-1. Instruction Set Summary (Continued)** 

| Source                                                                                                | Operation                     | Description                                                                                                                                                                                                                                                                                                                                                              |          |   |   | ct (     |          |          | Address<br>Mode                                                         | Opcode                                           | Operand                                         | les                                  |
|-------------------------------------------------------------------------------------------------------|-------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|---|---|----------|----------|----------|-------------------------------------------------------------------------|--------------------------------------------------|-------------------------------------------------|--------------------------------------|
| Form                                                                                                  |                               | •                                                                                                                                                                                                                                                                                                                                                                        | ٧        | Н | I | N        | Z        | С        | Add                                                                     | odo                                              | obe                                             | Cycles                               |
| BSET n,opr                                                                                            | Set Bit <i>n</i> in M         | Mn ← 1                                                                                                                                                                                                                                                                                                                                                                   | _        | _ | _ | _        | _        | _        | DIR (b0) DIR (b1) DIR (b2) DIR (b3) DIR (b4) DIR (b5) DIR (b6) DIR (b7) | 10<br>12<br>14<br>16<br>18<br>1A<br>1C           | dd<br>dd<br>dd<br>dd<br>dd<br>dd<br>dd<br>dd    | 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}{c} 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 | 5 4 4 5 4 6                          |
| CLC                                                                                                   | Clear Carry Bit               | C ← 0                                                                                                                                                                                                                                                                                                                                                                    | _        | - | - | -        | -        | 0        | INH                                                                     | 98                                               |                                                 | 1                                    |
| CLI                                                                                                   | Clear Interrupt Mask          | I ← 0                                                                                                                                                                                                                                                                                                                                                                    | _        | - | 0 | -        | -        | -        | INH                                                                     | 9A                                               |                                                 | 2                                    |
| CLR opr<br>CLRA<br>CLRX<br>CLRH<br>CLR opr,X<br>CLR ,X<br>CLR opr,SP                                  | Clear                         | $\begin{array}{l} M \leftarrow \$00 \\ A \leftarrow \$00 \\ X \leftarrow \$00 \\ X \leftarrow \$00 \\ H \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>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)                                                                                                                                                                                                                                                                                                                                                                | \$       | _ | _ | <b>‡</b> | \$       | <b>‡</b> | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP1<br>SP2                     | A1<br>B1<br>C1<br>D1<br>E1<br>F1<br>9EE1         | ii<br>dd<br>hh II<br>ee ff<br>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 ,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 (\overline{X}) = \$FF - (M) \\ M \leftarrow (\overline{M}) = \$FF - (M) \end{array}$                          | 0        | _ | _ | <b>‡</b> | <b>‡</b> | 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>1<br>4<br>3<br>5           |
| CPHX #opr<br>CPHX opr                                                                                 | Compare H:X with M            | (H:X) – (M:M + 1)                                                                                                                                                                                                                                                                                                                                                        | <b>‡</b> | - | _ | \$       | \$       | \$       | 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)                                                                                                                                                                                                                                                                                                                                                                |          | _ | _ | <b>‡</b> | \$       | <b>‡</b> | 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>ff<br>ee ff | 2<br>3<br>4<br>4<br>3<br>2<br>4<br>5 |
| DAA                                                                                                   | Decimal Adjust A              | (A) <sub>10</sub>                                                                                                                                                                                                                                                                                                                                                        | U        | _ | - | <b>‡</b> | <b>‡</b> | <b>‡</b> | INH                                                                     | 72                                               |                                                 | 2                                    |

**Advance Information** 

MC68HC(9)08LJ60 — Rev. 1.0

Central Processor Unit (CPU) Instruction Set Summary

**Table 5-1. Instruction Set Summary (Continued)** 

| Source                                                                                                       | Operation                        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |          | Ef |   | ct (     |          |    | Address<br>Mode                                     | Opcode                                           | Operand                                   | les                                  |
|--------------------------------------------------------------------------------------------------------------|----------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|----|---|----------|----------|----|-----------------------------------------------------|--------------------------------------------------|-------------------------------------------|--------------------------------------|
| Form                                                                                                         |                                  | •                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | ٧        | Н  | I | N        | Z        | С  | Add                                                 | odo                                              | obe                                       | 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}? \text{ (result)} \neq 0 \\ PC \leftarrow (PC) + 2 + \mathit{rel}? \text{ (result)} \neq 0 \\ PC \leftarrow (PC) + 2 + \mathit{rel}? \text{ (result)} \neq 0 \\ PC \leftarrow (PC) + 3 + \mathit{rel}? \text{ (result)} \neq 0 \\ PC \leftarrow (PC) + 2 + \mathit{rel}? \text{ (result)} \neq 0 \\ PC \leftarrow (PC) + 2 + \mathit{rel}? \text{ (result)} \neq 0 \\ PC \leftarrow (PC) + 4 + \mathit{rel}? \text{ (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>rr<br>ff rr<br>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}$                                                                                                                                                                                                                                                                                                                                                                                                                         | <b>‡</b> | _  | _ | <b>‡</b> | <b>‡</b> | _  | 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>1<br>4<br>3<br>5           |
| DIV                                                                                                          | Divide                           | A ← (H:A)/(X)<br>H ← 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 \leftarrow (A \oplus M)$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | 0        | _  | _ | <b>‡</b> | <b>‡</b> | _  | 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 |                                           | 2<br>3<br>4<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}$                                                                                                                                                                                                                                                                                                                                                                                                                         | <b>‡</b> | _  | _ | <b>‡</b> | <b>‡</b> | _  | 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>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 ← 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               | $PC \leftarrow (PC) + n (n = 1, 2, \text{ or } 3)$<br>$Push (PCL); SP \leftarrow (SP) - 1$<br>$Push (PCH); SP \leftarrow (SP) - 1$<br>$PC \leftarrow Unconditional Address$                                                                                                                                                                                                                                                                                                                                                                                                                         | _        | _  | _ | _        | _        | _  | 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,X<br>LDA opr,X<br>LDA opr,X<br>LDA opr,SP<br>LDA opr,SP<br>LDA opr,SP         | Load A from M                    | A ← (M)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |          | _  | _ | <b>‡</b> | <b>‡</b> | _  | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP1<br>SP2 | A6<br>B6<br>C6<br>D6<br>E6<br>F6<br>9EE6         | 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 |
| LDHX #opr<br>LDHX opr                                                                                        | Load H:X from M                  | H:X ← (M:M + 1)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |          | -  | - | <b>‡</b> | <b>‡</b> | -  | IMM<br>DIR                                          | 45<br>55                                         | ii jj<br>dd                               | 3 4                                  |
| LDX #opr<br>LDX opr<br>LDX opr,<br>LDX opr,X<br>LDX opr,X<br>LDX,X<br>LDX opr,SP<br>LDX opr,SP<br>LDX opr,SP | Load X from M                    | X ← (M)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |          | _  | _ | <b>‡</b> | \$       | _  | 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 |

MC68HC(9)08LJ60 - Rev. 1.0

# **Central Processor Unit (CPU)**

**Table 5-1. Instruction Set Summary (Continued)** 

| Source                                                                                        | Operation                           | Description                                                                                                                                                                                           |          | Εſ | fe<br>C |          | on       |          | Address<br>Mode                                     | Opcode                                           | Operand                    | les                                  |
|-----------------------------------------------------------------------------------------------|-------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|----|---------|----------|----------|----------|-----------------------------------------------------|--------------------------------------------------|----------------------------|--------------------------------------|
| Form                                                                                          | ·                                   | •                                                                                                                                                                                                     | ٧        | Н  | ı       | N        | Z        | С        | Add                                                 | odo                                              | obe                        | Cycles                               |
| 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 ←                                                                                                                                                                                                   | <b>‡</b> | _  | _       | <b>‡</b> | <b>‡</b> | <b>‡</b> | 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>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 - C b7 b0                                                                                                                                                                                           | <b>‡</b> | _  | _       | 0        | <b>‡</b> | <b>‡</b> | 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>1<br>4<br>3<br>5           |
| MOV opr,opr<br>MOV opr,X+<br>MOV #opr,opr<br>MOV X+,opr                                       | Move                                | $(M)_{Destination} \leftarrow (M)_{Source}$ $H:X \leftarrow (H:X) + 1 (IX+D, DIX+)$                                                                                                                   | 0        | _  | _       | <b>‡</b> | <b>‡</b> | _        | 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 ,X<br>NEG opr,SP                                  | Negate (Two's Complement)           | $\begin{array}{c} M \leftarrow -(M) = \$00 - (M) \\ A \leftarrow -(A) = \$00 - (A) \\ X \leftarrow -(X) = \$00 - (X) \\ M \leftarrow -(M) = \$00 - (M) \\ M \leftarrow -(M) = \$00 - (M) \end{array}$ | <b>‡</b> | _  | _       | <b>‡</b> | <b>‡</b> | <b>‡</b> | 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>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,X<br>ORA opr,SP<br>ORA opr,SP | Inclusive OR A and M                | A ← (A)   (M)                                                                                                                                                                                         | 0        | _  | _       | <b>‡</b> | <b>‡</b> | _        | 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>4<br>3<br>2<br>4<br>5 |
| PSHA                                                                                          | Push A onto Stack                   | Push (A); SP ← (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 ← (SP) – 1                                                                                                                                                                               | -        | -  | -       | -        | -        | -        | INH                                                 | 89                                               |                            | 2                                    |
| PULA                                                                                          | Pull A from Stack                   | SP ← (SP + 1); Pull (A)                                                                                                                                                                               | -        | -  | -       | _        | -        | _        | INH                                                 | 86                                               |                            | 2                                    |
| PULH                                                                                          | Pull H from Stack                   | SP ← (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           | D                                                                                                                                                                                                     | <b>‡</b> | _  | _       | <b>‡</b> | <b>‡</b> | <b>‡</b> | 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>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          | b7 b0                                                                                                                                                                                                 | <b>‡</b> | _  | _       | <b>‡</b> | <b>‡</b> | <b>‡</b> | 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>1<br>4<br>3<br>5           |

**Advance Information** 

MC68HC(9)08LJ60 — Rev. 1.0

Central Processor Unit (CPU)
Instruction Set Summary

**Table 5-1. Instruction Set Summary (Continued)** 

| Source                                                                                         | Operation                       | Description                                                                                                                                                                                                                                                                                                                                                                                                          |          | Εf       |          | ct<br>CR |          | l        | Address<br>Mode                                     | Opcode                                           | Operand | les                                  |
|------------------------------------------------------------------------------------------------|---------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|----------|----------|----------|----------|----------|-----------------------------------------------------|--------------------------------------------------|---------|--------------------------------------|
| Form                                                                                           | -                               | ·                                                                                                                                                                                                                                                                                                                                                                                                                    | ٧        | Н        | I        | N        | Z        | С        | Adc                                                 | Opc                                              | Ope     | Cycles                               |
| RSP                                                                                            | Reset Stack Pointer             | SP ← \$FF                                                                                                                                                                                                                                                                                                                                                                                                            | 1-       | -        | -        | -        | -        | -        | 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}$                                                                                                                                                                                      | <b>‡</b> | <b>‡</b> | <b>‡</b> | <b>‡</b> | <b>‡</b> | <b>‡</b> | INH                                                 | 80                                               |         | 7                                    |
| RTS                                                                                            | Return from Subroutine          | $\begin{array}{c} 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 opr,SP<br>SBC opr,SP  | Subtract with Carry             | $A \leftarrow (A) - (M) - (C)$                                                                                                                                                                                                                                                                                                                                                                                       | <b>‡</b> | _        | _        | <b>‡</b> | <b>‡</b> | <b>‡</b> | 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                                                                                                                                                                                                                                                                                                                                                                                                                | <u> </u> | -        | -        | -        | -        | 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        | _        | _        | <b>‡</b> | <b>‡</b> | _        | 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       |         | 3<br>4<br>4<br>3<br>2<br>4<br>5      |
| STHX opr                                                                                       | Store H:X in M                  | (M:M + 1) ← (H:X)                                                                                                                                                                                                                                                                                                                                                                                                    | 0        | -        | -        | \$       | <b>‡</b> | -        | DIR                                                 | 35                                               | dd      | 4                                    |
| STOP                                                                                           | Enable IRQ Pin; Stop Oscillator | I ← 0; Stop Oscillator                                                                                                                                                                                                                                                                                                                                                                                               | -        | -        | 0        | -        | -        | -        | INH                                                 | 8E                                               |         | 1                                    |
| STX opr<br>STX opr<br>STX opr,X<br>STX opr,X<br>STX ,X<br>STX opr,SP<br>STX opr,SP             | Store X in M                    | $M \leftarrow (X)$                                                                                                                                                                                                                                                                                                                                                                                                   | 0        | _        | _        | <b>‡</b> | <b>‡</b> | _        | 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       |         | 3<br>4<br>4<br>3<br>2<br>4<br>5      |
| SUB #opr<br>SUB opr<br>SUB opr,<br>SUB opr,X<br>SUB opr,X<br>SUB,X<br>SUB opr,SP<br>SUB opr,SP | Subtract                        | A ← (A) − (M)                                                                                                                                                                                                                                                                                                                                                                                                        | <b>‡</b> | _        | _        | <b>‡</b> | <b>‡</b> | <b>‡</b> | 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;  Push  (CCR) \\ SP \leftarrow (SP) - 1;  I \leftarrow 1 \\ PCH \leftarrow Interrupt  Vector  High  Byte \\ PCL \leftarrow Interrupt  Vector  Low  Byte \\ \end{array}$ | _        | _        | 1        | _        | _        | _        | INH                                                 | 83                                               |         | 9                                    |
| TAP                                                                                            | Transfer A to CCR               | CCR ← (A)                                                                                                                                                                                                                                                                                                                                                                                                            | \$       | <b>1</b> | <b>‡</b> | <b>‡</b> | <b>1</b> | <b>‡</b> | INH                                                 | 84                                               |         | 2                                    |
| TAX                                                                                            | Transfer A to X                 | X ← (A)                                                                                                                                                                                                                                                                                                                                                                                                              | -        | -        | _        | _        | -        | _        | INH                                                 | 97                                               |         | 1                                    |
| TPA                                                                                            | Transfer CCR to A               | $A \leftarrow (CCR)$                                                                                                                                                                                                                                                                                                                                                                                                 |          |          |          | -        | -        | -        | INH                                                 | 85                                               |         | 1                                    |

MC68HC(9)08LJ60 - Rev. 1.0

# **Central Processor Unit (CPU)**

**Table 5-1. Instruction Set Summary (Continued)** 

| Source<br>Form                                               | Operation                 | Description                            |             | Εſ |   | ct<br>CR |          | 1 | dress<br>de                           | Opcode                             | Operand        | Cycles                     |
|--------------------------------------------------------------|---------------------------|----------------------------------------|-------------|----|---|----------|----------|---|---------------------------------------|------------------------------------|----------------|----------------------------|
| FOIIII                                                       |                           | -                                      | V H I N Z C |    |   |          |          |   | Addre<br>Mode                         | obc                                | obe            | S                          |
| TST opr<br>TSTA<br>TSTX<br>TST opr,X<br>TST ,X<br>TST opr,SP | Test for Negative or Zero | (A) – \$00 or (X) – \$00 or (M) – \$00 | 0           | _  | _ | \$       | <b>‡</b> | _ | 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>1<br>3<br>2<br>4 |
| TSX                                                          | Transfer SP to H:X        | H:X ← (SP) + 1                         | -           | -  | - | -        | -        | - | INH                                   | 95                                 |                | 2                          |
| TXA                                                          | Transfer X to A           | A ← (X)                                | -           | -  | - | -        | -        | - | INH                                   | 9F                                 |                | 1                          |
| TXS                                                          | Transfer H:X to SP        | (SP) ← (H:X) – 1                       | -           | -  | - | -        | -        | - | INH                                   | 94                                 |                | 2                          |

| Α     | Accumulator                                                         | n            | Any bit                                     |
|-------|---------------------------------------------------------------------|--------------|---------------------------------------------|
| С     | Carry/borrow bit                                                    | opr          | Operand (one or two bytes)                  |
| CCR   | Condition code register                                             | PC           | Program counter                             |
| dd    | Direct address of operand                                           | PCH          | Program counter high byte                   |
| dd rr | Direct address of operand and relative offset of branch instruction | PCL          | Program counter low byte                    |
| DD    | Direct to direct addressing mode                                    | REL          | Relative addressing mode                    |
| DIR   | Direct addressing mode                                              | rel          | Relative program counter offset byte        |
| DIX+  | Direct to indexed with post increment addressing mode               | rr           | Relative program counter offset byte        |
| ee ff | High and low bytes of offset in indexed, 16-bit offset addressing   | SP1          | Stack pointer, 8-bit offset addressing mode |
| EXT   | Extended addressing mode                                            | SP2          | Stack pointer 16-bit offset addressing mode |
| ff    | Offset byte in indexed, 8-bit offset addressing                     | SP           | Stack pointer                               |
| Н     | Half-carry bit                                                      | U            | Undefined                                   |
| Н     | Index register high byte                                            | V            | Overflow bit                                |
| hh II | High and low bytes of operand address in extended addressing        | Χ            | Index register low byte                     |
| 1     | Interrupt mask                                                      | Z            | Zero bit                                    |
| ii    | Immediate operand byte                                              | &            | Logical AND                                 |
| IMD   | Immediate source to direct destination addressing mode              |              | Logical OR                                  |
| IMM   | Immediate addressing mode                                           | $\oplus$     | Logical EXCLUSIVE OR                        |
| INH   | Inherent addressing mode                                            | ()           | Contents of                                 |
| IX    | Indexed, no offset addressing mode                                  | -( )         | Negation (two's complement)                 |
| IX+   | Indexed, no offset, post increment addressing mode                  | #            | Immediate value                             |
| IX+D  | Indexed with post increment to direct addressing mode               | <b>«</b>     | Sign extend                                 |
| IX1   | Indexed, 8-bit offset addressing mode                               | $\leftarrow$ | Loaded with                                 |
| IX1+  | Indexed, 8-bit offset, post increment addressing mode               | ?            | If                                          |
| IX2   | Indexed, 16-bit offset addressing mode                              | :            | Concatenated with                           |
| M     | Memory location                                                     | <b>‡</b>     | Set or cleared                              |
| Ν     | Negative bit                                                        | _            | Not affected                                |
|       |                                                                     |              |                                             |

# 5.8 Opcode Map

See Table 5-2.

Central Processor Unit (CPU) Opcode Map

High Byte of Opcode in Hexadecimal

BRSETO

Low Byte of Opcode in Hexadecimal

Stack Pointer, 8-Bit Offset Stack Pointer, 16-Bit Offset Indexed, No Offset with Post Increment Indexed, 1-Byte Offset with Post Increment

SP1 SP2 IX+ IX+

REL Relative
IX Indexed, No Offset
IX1 Indexed, 8-Bit Offset
IX2 Indexed, 16-Bit Offset
IX2 Indexed, 16-Bit Offset
IMD Immediate-Direct
DIX+ Direct-Indexed

INH Inherent REL Relative
IMM Immediate IX Indexed, No Offset
DIR Direct
EXT Extended IX2 Indexed, 16-Bit Offset
DD Direct-Direct IMD Immediate-Direct
IX+D Indexed-Direct DIX+ Direct-Indexed
\*Pre-byte for stack pointer indexed instructions

LSB

MC68HC(9)08LJ60 - Rev. 1.0

Central Processor Unit (CPU)

# Advance Information — MC68HC(9)08LJ60

# Section 6. System Integration Module (SIM)

### 6.1 Contents

| 6.2 Introduction                                                                                                 | 84  |
|------------------------------------------------------------------------------------------------------------------|-----|
| 6.3 SIM Bus Clock Control and Generation                                                                         | 87  |
| 6.3.1 Bus Timing                                                                                                 | 87  |
| 6.3.2 Clock Startup from POR or LVI Reset                                                                        | 87  |
| 6.3.3 Clocks in Stop Mode and Wait Mode                                                                          | 88  |
| 6.4 Reset and System Initialization                                                                              |     |
| 6.4.1 External Pin Reset                                                                                         | 89  |
| 6.4.2 Active Resets from Internal Sources                                                                        | 90  |
| 6.4.2.1 Power-On Reset                                                                                           | 91  |
| 6.4.2.2 Computer Operating Properly (COP) Reset                                                                  | 92  |
| 6.4.2.3 Illegal Opcode Reset                                                                                     | 92  |
| 6.4.2.4 Illegal Address Reset                                                                                    | 93  |
| 6.4.2.5 Low-Voltage Inhibit (LVI) Reset                                                                          | 93  |
| 6.5 SIM Counter                                                                                                  | 93  |
| 6.5.1 SIM Counter During Power-On Reset                                                                          | 93  |
| 6.5.2 SIM Counter During Stop Mode Recovery                                                                      | 94  |
| 6.5.3 SIM Counter and Reset States                                                                               | 94  |
| 6.6 Exception Control                                                                                            | 94  |
| 6.6.1 Interrupts                                                                                                 | 95  |
| 6.6.1.1 Hardware Interrupts                                                                                      | 97  |
| 6.6.1.2 SWI Instruction                                                                                          | 98  |
| 6.6.2 Reset                                                                                                      | 99  |
| 6.6.3 Break Interrupts                                                                                           | 99  |
| 6.6.4 Status Flag Protection in Break Mode                                                                       | 99  |
| 6.7 Low-Power Modes                                                                                              | 100 |
| 6.7.1 Wait Mode                                                                                                  |     |
| 6.7.2 Stop Mode                                                                                                  |     |
| 6.8 SIM Registers                                                                                                | 103 |
| - Carlotte and the Carlotte |     |

MC68HC(9)08LJ60 - Rev. 1.0

### **System Integration Module (SIM)**

| 6.8.1 | SIM Break Status Register       | .103 |
|-------|---------------------------------|------|
| 6.8.2 | SIM Reset Status Register       | .105 |
| 6.8.3 | SIM Break Flag Control Register | .106 |

#### 6.2 Introduction

This section describes the system integration module (SIM24, version C), which supports up to 24 external and/or internal interrupts. Together with the CPU, the SIM controls all MCU activities. A block diagram of the SIM is shown in **Figure 6-1**. **Figure 6-2** is a summary of the SIM I/O (input/output) registers. The SIM is a system state controller that coordinates CPU and exception timing. 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 COP timeout
- Interrupt control:
  - Acknowledge timing
  - Arbitration control timing
  - Vector address generation
- CPU enable/disable timing
- Modular architecture expandable to 128 interrupt sources

#### NOTE:

All references to LVI and DMA and stop mode operation in this section should be ignored.

System Integration Module (SIM) Introduction



Figure 6-1. SIM Block Diagram

# **System Integration Module (SIM)**

| Addr.   | Register Name                                  | Bit 7 | 6         | 5   | 4    | 3         | 2       | 1      | Bit 0 |
|---------|------------------------------------------------|-------|-----------|-----|------|-----------|---------|--------|-------|
|         | Read                                           | R     | R         | R   | R    | R         | R       | SBSW   | R     |
| \$FE00  | SIM Break Status Register (SBSR) Write:        |       | K         | K   | K    | K         | K       | Note 1 | K     |
|         | Reset                                          |       |           |     |      |           |         | 0      |       |
|         | Read                                           | POR   | PIN       | COP | ILOP | ILAD      | 0       | LVI    | 0     |
| \$FE01  | SIM Reset Status Register (SRSR) Write:        |       |           |     |      |           |         |        |       |
|         | Reset                                          | 1     | 0         | 0   | 0    | 0         | 0       | 0      | 0     |
|         | Read                                           | BCFE  | R         | R   | R    | R         | R       | R      | R     |
| \$FE03  | SIM Break Flag Control Register (SBFCR) Write: | DOFE  | K         | ĸ   | K    | K         | K       | K      | K     |
|         | Reset                                          | 0     |           |     |      |           |         |        |       |
| Note 1. | Writing a logic 0 clears SBSW.                 | R     | = Reserve | ed  |      | = Unimple | emented |        |       |

Figure 6-2. SIM I/O Register Summary

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

**Table 6-1. Signal Name Conventions** 

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

System Integration Module (SIM) SIM Bus Clock Control and Generation

#### 6.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 6-3**. This clock can come from either an external oscillator or from the on-chip PLL. (See **7.2 Introduction**.)

#### 6.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 **7.2 Introduction**.)

#### 6.3.2 Clock Startup from POR or LVI Reset

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

**NOTE:** The MC68HC(9)08LJ60 does not have an LVI module.



Figure 6-3. CGM Clock Signals

MC68HC(9)08LJ60 — Rev. 1.0

### **System Integration Module (SIM)**

#### 6.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 6.7.2 Stop Mode.)

**NOTE:** The MC68HC(9)08LJ60 does not allow stop mode operation.

In wait mode, the CPU clocks are inactive. The SIM also produces two sets of clocks for other modules. 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.

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

All of these resets produce the vector \$FFFE–FFFF (\$FEFE–FEFF in monitor mode) and assert 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 6.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 6.8 SIM Registers.)

System Integration Module (SIM) Reset and System Initialization

#### 6.4.1 External Pin Reset

Pulling the asynchronous  $\overline{RST}$  pin low halts all processing. The PIN bit of the SIM reset status register (SRSR) is set as long as  $\overline{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 6-2** for details. **Figure 6-4** shows the relative timing.

**Table 6-2. PIN Bit Set Timing** 

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



Figure 6-4. External Reset Timing

### **System Integration Module (SIM)**

#### 6.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 6-5.) An internal reset can be caused by an illegal address, illegal opcode, COP timeout, LVI, or POR. (See Figure 6-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 6-5.



Figure 6-5. Internal Reset Timing

The COP reset is asynchronous to the bus clock.



Figure 6-6. Sources of Internal Reset

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

System Integration Module (SIM) Reset and System Initialization

#### 6.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 (RST) is held low while the SIM counter counts out 4096 CGMXCLK cycles. Sixty-four 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 6-7. POR Recovery

MC68HC(9)08LJ60 — Rev. 1.0

### **System Integration Module (SIM)**

#### 6.4.2.2 Computer Operating Properly (COP) Reset

An input to the SIM is reserved for the COP reset signal. The overflow of the COP counter causes an internal reset and sets the COP bit in the SIM reset status register (SRSR). The SIM actively pulls down the RST pin for all internal reset sources.

To prevent a COP module timeout, write any value to location \$FFFF. Writing to location \$FFFF clears the COP counter and bits 12 through 4 of the SIM counter. The SIM counter output, which occurs at least every  $2^{13} - 2^4$  CGMXCLK cycles, drives the COP counter. The COP should be serviced as soon as possible out of reset to guarantee the maximum amount of time before the first timeout.

The COP module is disabled if the  $\overline{RST}$  pin or the  $\overline{IRQ1}$  pin is held at  $V_{DD}$  +  $V_{HI}$  while the MCU is in monitor mode. The COP module can be disabled only through combinational logic conditioned with the high voltage signal on the  $\overline{RST}$  or the  $\overline{IRQ1}$  pin. This prevents the COP from becoming disabled as a result of external noise. During a break state,  $V_{DD}$  +  $V_{HI}$  on the  $\overline{RST}$  pin disables the COP module.

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

If the stop enable bit, STOP, in the mask option register is logic 0, the SIM treats the STOP instruction as an illegal opcode and causes an illegal opcode reset. The SIM actively pulls down the  $\overline{\text{RST}}$  pin for all internal reset sources.

System Integration Module (SIM)
SIM Counter

#### 6.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. The SIM actively pulls down the RST pin for all internal reset sources.

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

The low-voltage inhibit module (LVI) asserts its output to the SIM when the  $V_{DD}$  voltage falls to the LVI<sub>TRIPF</sub> voltage. The LVI bit in the SIM reset status register (SRSR) is set, and the external reset pin ( $\overline{RST}$ ) is held low while the SIM counter counts out 4096 CGMXCLK cycles. Sixty-four CGMXCLK cycles later, the CPU is released from reset to allow the reset vector sequence to occur. The SIM actively pulls down the  $\overline{RST}$  pin for all internal reset sources.

**NOTE:** The MC68HC(9)08LJ60 does not have an LVI module.

#### 6.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 module (COP). The SIM counter overflow supplies the clock for the COP module. The SIM counter is 13 bits long and is clocked by the falling edge of CGMXCLK.

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

MC68HC(9)08LJ60 — Rev. 1.0

### 6.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 mask option register. 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.

**NOTE:** The MC68HC(9)08LJ60 does not allow stop mode operation.

#### 6.5.3 SIM Counter and Reset States

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

## 6.6 Exception Control

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

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

94

System Integration Module (SIM) Exception Control

#### 6.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 RTI instruction recovers the CPU register contents from the stack so that normal processing can resume. **Figure 6-8** shows interrupt entry timing. **Figure 6-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 may take precedence, regardless of priority, until the latched interrupt is serviced (or the I bit is cleared). (See Figure 6-9.)



Figure 6-8. Interrupt Entry

### **System Integration Module (SIM)**



Figure 6-9. Interrupt Processing

**Advance Information** 

MC68HC(9)08LJ60 — Rev. 1.0

System Integration Module (SIM) Exception Control



Figure 6-10. Interrupt Recovery

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

### **System Integration Module (SIM)**



Figure 6-11. Interrupt Recognition Example

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 M6805 Family, 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.

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

System Integration Module (SIM)
Exception Control

#### 6.6.2 Reset

All reset sources always have equal and highest priority and cannot be arbitrated.

#### 6.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 9. Break Module.**) 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 each module is affected by the break state.

#### 6.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 whether flags are protected from being cleared by properly initializing the break clear flag enable bit (BCFE) in the SIM break flag control register (SBFCR).

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

### **System Integration Module (SIM)**

#### 6.7 Low-Power Modes

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

**NOTE:** The MC68HC(9)08LJ60 does not allow stop mode operation.

#### 6.7.1 Wait Mode

In wait mode, the CPU clocks are inactive while the peripheral clocks continue to run. **Figure 6-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. In wait mode, the CPU clocks are inactive. 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.

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 mask option register is logic 0, then the computer operating properly module (COP) is enabled and remains active in wait mode.



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

Figure 6-12. Wait Mode Entry Timing

Advance Information

MC68HC(9)08LJ60 — Rev. 1.0

System Integration Module (SIM) Low-Power Modes

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



NOTE: EXITSTOPWAIT =  $\overline{RST}$  pin OR CPU interrupt OR break interrupt

Figure 6-13. Wait Recovery from Interrupt or Break



Figure 6-14. Wait Recovery from Internal Reset

#### 6.7.2 Stop Mode

**NOTE:** The MC68HC(9)08LJ60 does not allow stop mode operation.

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 SSREC bit in the mask option register (MOR). If SSREC is set, stop recovery is reduced from the normal delay of 4096 CGMXCLK cycles down to 32. This is ideal for

MC68HC(9)08LJ60 — Rev. 1.0

### **System Integration Module (SIM)**

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 6-15** shows stop mode entry timing.



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

Figure 6-15. Stop Mode Entry Timing



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

System Integration Module (SIM)
SIM Registers

### 6.8 SIM Registers

The SIM has three memory mapped registers. **Table 6-3** shows the mapping of these registers.

Table 6-3. SIM Registers

| Address | Register                                | Access Mode |
|---------|-----------------------------------------|-------------|
| \$FE00  | SBSR — SIM break status register        | User        |
| \$FE01  | SRSR — SIM reset status register        | User        |
| \$FE03  | SBFCR — SIM break flag control register | User        |

#### 6.8.1 SIM Break Status Register

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



Figure 6-17. SIM Break Status Register (SBSR)

#### SBSW — SIM break stop/wait

This status bit is useful in applications requiring a return to wait 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 was exited by break interrupt.
- 0 = Stop mode or wait mode was not exited by break interrupt.

### **System Integration Module (SIM)**

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
          EOU
 LOBYTE
                 6
          EQU
          If not SBSW, do RTI
                 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.
                                     ; Else deal with high byte, too.
          DEC
                 HIBYTE, SP
 DOLO
          DEC
                                     ; Point to WAIT/STOP opcode.
                 LOBYTE, SP
 RETURN
          PULH
                                     ; Restore H register.
          RTI
```

System Integration Module (SIM)
SIM Registers

#### 6.8.2 SIM Reset Status Register

This register contains six flags that show the source of the last reset. Clear the SIM reset status register by reading it. A power-on reset sets the POR bit and clears all other bits in the register.



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

POR — Power-on reset bit

1 = Last reset caused by POR circuit

0 = Read of SRSR

PIN — External reset bit

1 = Last reset caused by external reset pin ( $\overline{RST}$ )

0 = POR or read of SRSR

COP — Computer operating properly reset bit

1 = Last reset caused by COP counter

0 = POR or read of SRSR

ILOP — Illegal opcode reset bit

1 = Last reset caused by an illegal opcode

0 = POR or read of SRSR

ILAD — Illegal address reset bit (opcode fetches only)

1 = Last reset caused by an opcode fetch from an illegal address

0 = POR or read of SRSR

LVI — Low-voltage inhibit reset bit

1 = Last reset caused by the LVI circuit

0 = POR or read of SRSR

MC68HC(9)08LJ60 — Rev. 1.0

### **System Integration Module (SIM)**

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



Figure 6-19. SIM Break Flag Control Register (SBFCR)

BCFE — Break clear flag enable bit

This read/write bit enables software to clear status bits by accessing status registers while the MCU is in a break state. To clear status bits during the break state, the BCFE bit must be set.

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

# Advance Information — MC68HC(9)08LJ60

# Section 7. Clock Generator Module (CGMB)

### 7.1 Contents

| 7.2 Introduc | tion                                      | 108 |
|--------------|-------------------------------------------|-----|
| 7.3 Features | S                                         | 109 |
| 7.4 Function | nal Description                           | 109 |
| 7.4.1 Crys   | tal Oscillator Circuit                    | 111 |
| 7.4.2 Phas   | e-Locked Loop Circuit (PLL)               | 111 |
| 7.4.2.1 PL   | L Circuits                                | 111 |
| 7.4.2.2 Ac   | quisition and Tracking Modes              | 113 |
| 7.4.2.3 Ma   | inual and Automatic PLL Bandwidth Modes . | 113 |
| 7.4.2.4 Pro  | ogramming the PLL                         | 115 |
| 7.4.2.5 Sp   | ecial Programming Exceptions              | 118 |
| 7.4.3 Base   | Clock Selector Circuit                    | 118 |
| 7.4.4 CGM    | IB External Connections                   | 119 |
| 7.5 I/O Sign | als                                       | 120 |
| 7.5.1 Crys   | tal Amplifier Input Pin (OSC1)            | 120 |
| 7.5.2 Cryst  | tal Amplifier Output Pin (OSC2)           | 120 |
| 7.5.3 Exter  | rnal Filter Capacitor Pin (CGMXFC)        | 120 |
| 7.5.4 PLL    | Analog Power Pin (V <sub>DDA</sub> )      | 121 |
| 7.5.5 PLL    | Analog Ground Pin (V <sub>SSA</sub> )     | 121 |
| 7.5.6 Oscil  | llator Enable Signal (SIMOSCEN)           | 121 |
| 7.5.7 Crys   | tal Output Frequency Signal (CGMXCLK)     | 121 |
| 7.5.8 CGM    | IB Base Clock Output (CGMOUT)             | 122 |
| 7.5.9 CGM    | IB CPU Interrupt (CGMINT)                 | 122 |
| 7.6 CGMB F   | Registers                                 | 122 |
| 7.6.1 PLL    | Control Register                          | 124 |
| 7.6.2 PLL    | Bandwidth Control Register                | 126 |
| 7.6.3 PLL    | Multiplier Select Register High           | 128 |
| 7.6.4 PLL    | Multiplier Select Register Low            | 129 |
|              |                                           |     |

MC68HC(9)08LJ60 — Rev. 1.0

### **Clock Generator Module (CGMB)**

| 7.6.5  | PLL VCO Range Select Register             |
|--------|-------------------------------------------|
| 7.6.6  | PLL Reference Divider Select Register     |
| 7.7    | Interrupts132                             |
| 7.8    | Wait Mode                                 |
| 7.9    | CGMB During Break Interrupts133           |
| 7.10   | Acquisition/Lock Time Specifications      |
| 7.10.1 | Acquisition/Lock Time Definitions         |
| 7.10.2 | Parametric Influences on Reaction Time135 |
| 7.10.3 | Choosing a Filter Capacitor136            |
| 7.10.4 | Reaction Time Calculation137              |

#### 7.2 Introduction

This section describes the clock generator module (CGM, version B). 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 fully functional frequency generator designed for use with crystals or ceramic resonators. The PLL can generate a 4-MHz bus frequency without using a 16-MHz crystal.

Clock Generator Module (CGMB)
Features

#### 7.3 Features

#### Features of the CGMB include:

- Phase-locked loop with output frequency in integer multiples of an integer dividend of the crystal reference
- Low-frequency crystal operation with low-power operation and high-output frequency resolution
- Programmable reference divider for even greater resolution
- Programmable prescaler for power-of-two increases in frequency
- 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

## 7.4 Functional Description

The CGMB 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 7-1 shows the structure of the CGM.

## **Clock Generator Module (CGMB)**



Figure 7-1. CGMB Block Diagram

110

Clock Generator Module (CGMB)
Functional Description

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

The CGMXCLK signal is the output of the crystal oscillator circuit and runs at a rate equal to the crystal frequency. CGMXCLK is then buffered to produce CGMRCLK, the PLL reference clock.

CGMXCLK can be used by other modules which require precise timing for operation. The duty cycle of CGMXCLK is not guaranteed to be 50% 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.

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

#### 7.4.2.1 PLL Circuits

The PLL consists of:

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

MC68HC(9)08LJ60 — Rev. 1.0

Advance Information

## **Clock Generator Module (CGMB)**

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. 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}$ , (38.4 kHz) times a linear factor, L, and a power-of-two factor, E, or  $(L \times 2^E) f_{NOM}$ .

CGMRCLK is the PLL reference clock, a buffered version of CGMXCLK. CGMRCLK runs at a frequency,  $f_{RCLK}$ , and is fed to the PLL through a programmable modulo reference divider, which divides  $f_{RCLK}$  by a factor R. This feature allows frequency steps of higher resolution. The divider's output is the final reference clock, CGMRDV, running at a frequency  $f_{RDV} = f_{RCLK}/R$ .

The VCO's output clock, CGMVCLK, running at a frequency  $f_{VCLK}$ , is fed back through a programmable prescale divider and a programmable modulo divider. The prescaler divides the VCO clock by a power-of-two factor, P, and the modulo divider reduces the VCO clock by a factor, N. The divider's output is the VCO feedback clock, CGMVDV, running at a frequency  $f_{VDV} = f_{VCLK}/(N \times 2^P)$ . (See **7.4.2.4 Programming the PLL** for more information.)

The phase detector then compares the VCO feedback clock, CGMVDV, with the final reference clock, CGMRDV. 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 7.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 final reference clock, CGMRDV. Therefore, the speed of the lock detector is directly proportional to the final reference frequency  $f_{RDV}$ . The circuit determines the mode of the PLL and the lock condition based on this comparison.

Clock Generator Module (CGMB)
Functional Description

#### 7.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. This mode is used at PLL start-up 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 7.6.2 PLL Bandwidth Control Register.)
- Tracking mode In tracking mode, the filter makes only small corrections to the frequency of the VCO. 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 7.4.3 Base Clock Selector Circuit.) The PLL is in tracking mode automatically when not in acquisition mode or when the ACQ bit is set.

#### 7.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 7.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 start-up, 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 7.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 software must take appropriate action, depending on the application. (See 7.7 Interrupts for information and precautions on using interrupts.)

MC68HC(9)08LJ60 — Rev. 1.0

Advance Information

## **Clock Generator Module (CGMB)**

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

- The ACQ bit (see 7.6.2 PLL Bandwidth Control Register) is a read-only indicator of the mode of the filter. (See 7.4.2.2 Acquisition and Tracking Modes.)
- The  $\overline{ACQ}$  bit is set when the VCO frequency is within a certain tolerance,  $\Delta_{TRK}$ , and is cleared when the VCO frequency is out of a certain tolerance,  $\Delta_{UNT}$ . (See **7.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, Δ<sub>LOCK</sub>, and is cleared when the VCO frequency is out of a certain tolerance, Δ<sub>UNL</sub>. (See 7.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 7.6.1 PLL Control Register.)

The PLL also may 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 7.10 Acquisition/Lock Time Specifications), after turning on the PLL by setting PLLON in the PLL control register (PCTL).
- 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 CGMB are disabled.

Advance Information

This procedure shows how to program the PLL.

**NOTE:** The round function in the following equations means that the real number should be rounded to the nearest integer number.

- Choose the desired bus frequency, f<sub>BUSDES</sub>.
- 2. Calculate the desired VCO frequency (four times the desired bus frequency).

$$f_{VCLKDES} = 4 \times f_{BUSDES}$$

- 3. Choose a practical PLL reference frequency, f<sub>RCLK</sub>.
- 4. Select the prescaler power-of-two multiplier, P.

$$P = integer \left[ \frac{log \left( \frac{2^{PMAX} \times f_{VCLKDES}}{f_{VCLKMAX}} \right)}{log(2)} + 1 \right]$$

5. Select the reference divider based on the resolution desired. For maximum resolution, use the formula below. However, higher degrees of resolution slow down the final reference frequency, which may cause acquisition time to increase and may affect the value of the external capacitor. For more information, see 7.10 **Acquisition/Lock Time Specifications.** 

$$R = round \left[ R_{MAX} \times \left\{ \left( \frac{f_{VCLKDES}}{2^{P} \times f_{RCLK}} \right) - integer \left( \frac{f_{VCLKDES}}{2^{P} \times f_{RCLK}} \right) \right\} \right]$$

Select a VCO frequency multiplier, N.

$$N = round \left( \frac{R \times f_{VCLKDES}}{2^P \times f_{RCLK}} \right)$$

- 6. For fastest acquisition time, reduce N/R until R is the smallest value possible. For example, if N = 6 and R = 4, N reduces to 3 and R reduces to 2.
- Calculate and verify the adequacy of the VCO and bus frequencies f<sub>VCLK</sub> and f<sub>BUS</sub>.

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

$$f_{VCLK} = (2^P \times N/R) \times f_{RCLK}$$

$$f_{RUS} = (f_{VCLK})/4$$

Select the VCO's power-of-two range multiplier, E. Higher values of E should be used at higher frequencies.

$$E = integer \left[ \frac{log \left( \frac{2^{EMAX} \times f_{VCLK}}{f_{VRSMAX}} \right)}{log(2)} \right] + 1$$

Select a VCO linear range multiplier, L, where  $f_{NOM} = 38.4 \text{ KHz}$ 

$$L = round \left( \frac{f_{VCLK}}{2^E \times f_{NOM}} \right)$$

9. Calculate and verify the adequacy of the VCO programmed center-of-range frequency f<sub>VRS</sub>.

$$f_{VRS} = (L \times 2^E)f_{NOM}$$

10. Verify the choice of P, R, N, E, and L by comparing  $f_{VCLK}$  to  $f_{VRS}$  and  $f_{VCLKDES}$ . For proper operation,  $f_{VCLK}$  must be within the application's tolerance of  $f_{VCLKDES}$ , and  $f_{VRS}$  must be as close as possible to  $f_{VCLK}$ .

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

Clock Generator Module (CGMB)
Functional Description

- 11. Program the PLL registers accordingly:
  - a. In the PRE bits of the PLL control register, program the binary equivalent of P.
  - b. In the VPR bits of the PLL control register, program the binary equivalent of E.
  - c. In the PLL multiplier select register low and the PLL multiplier select register high, program the binary equivalent of N.
  - d. In the PLL VCO range select register, program the binary coded equivalent of L.
  - e. In the PLL reference divider select register, program the binary coded equivalent of R.

Refer to **Table 7-1** for a numeric example with numbers in hexadecimal notation.:

Table 7-1. Numeric Example of PLL Register Programming

| Bus Frequency | E | Р | N  | L  | R |
|---------------|---|---|----|----|---|
| 307,200 Hz    | 1 | 1 | 10 | 10 | 1 |
| 614,400 Hz    | 1 | 1 | 20 | 20 | 1 |
| 652,800 Hz    | 2 | 2 | 11 | 11 | 1 |
| 691,200 Hz    | 2 | 2 | 12 | 12 | 1 |
| 729,600 Hz    | 2 | 2 | 13 | 13 | 1 |
| 768,000 Hz    | 2 | 2 | 14 | 14 | 1 |
| 806,400 Hz    | 2 | 2 | 15 | 15 | 1 |
| 998,400 Hz    | 2 | 2 | 1a | 1a | 1 |

## **Clock Generator Module (CGMB)**

#### 7.4.2.5 Special Programming Exceptions

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

- A 0 value for R or N is interpreted exactly the same as a value of one at the minimum frequency and the VCO range power-of-two bits.
- A 0 value for L disables the PLL and prevents its selection as the source for the base clock. (See 7.4.3 Base Clock Selector Circuit.)

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

Clock Generator Module (CGMB)
Functional Description

#### 7.4.4 CGMB External Connections

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

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

- Crystal, X<sub>1</sub>
- Fixed capacitor, C<sub>1</sub>
- Tuning capacitor, C<sub>2</sub> (can also be a fixed capacitor)
- Feedback resistor, R<sub>R</sub>
- 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 7-2 also shows the external components for the PLL:

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

Routing should be done with great care to minimize signal cross talk and noise.

## **Clock Generator Module (CGMB)**



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

Figure 7-2. CGMB External Connections

## 7.5 I/O Signals

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

#### 7.5.1 Crystal Amplifier Input Pin (OSC1)

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

## 7.5.2 Crystal Amplifier Output Pin (OSC2)

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

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

Advance Information

Clock Generator Module (CGMB)
I/O Signals

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

#### 7.5.4 PLL 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_{DDA}$  carefully for maximum noise immunity and place bypass

capacitors as close as possible to the package.

#### 7.5.5 PLL Analog Ground Pin (V<sub>SSA</sub>)

 $V_{SSA}$  is a ground pin used by the analog portions of the PLL. Connect the  $V_{SSA}$  pin to the same voltage potential as the  $V_{SS}$  pin.

**NOTE:** Route  $V_{SSA}$  carefully for maximum noise immunity and place bypass

capacitors as close as possible to the package.

#### 7.5.6 Oscillator Enable Signal (SIMOSCEN)

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

#### 7.5.7 Crystal Output Frequency Signal (CGMXCLK)

CGMXCLK is the crystal oscillator output signal. It runs at the full speed of the crystal (f<sub>XCLK</sub>) and comes directly from the crystal oscillator circuit. **Figure 7-2** 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.

MC68HC(9)08LJ60 — Rev. 1.0

Advance Information

## **Clock Generator Module (CGMB)**

#### 7.5.8 CGMB Base Clock Output (CGMOUT)

CGMOUT is the clock output of the CGMB. This signal goes to the SIM, which generates the MCU clocks. CGMOUT is a 50% 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.

#### 7.5.9 CGMB CPU Interrupt (CGMINT)

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

#### 7.6 CGMB Registers

These registers control and monitor operation of the CGMB:

- PLL control register (see 7.6.1 PLL Control Register)
- PLL bandwidth control register (see 7.6.2 PLL Bandwidth Control Register)
- PLL multiplier select register high (see 7.6.3 PLL Multiplier Select Register High)
- PLL multiplier select register low (see 7.6.4 PLL Multiplier Select Register Low)
- PLL VCO range select register (see 7.6.5 PLL VCO Range Select Register)
- PLL reference divider select register (see 7.6.6 PLL Reference Divider Select Register)

**Figure 7-3** provides a summary of the CGMB registers.

Clock Generator Module (CGMB)
CGMB Registers



Figure 7-3. CGMB I/O Register Summary

## **Clock Generator Module (CGMB)**

#### 7.6.1 PLL Control Register

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



Figure 7-4. PLL Control Register (PCTL)

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

Clock Generator Module (CGMB)
CGMB Registers

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 **7.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 7.4.3 Base Clock Selector Circuit.) Reset clears 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 7.4.3 Base Clock Selector Circuit.)

PRE1 and PRE0 — Prescaler program bits

These read/write bits control a prescaler that selects the prescaler power-of-two multiplier, P. (See **7.4.2.1 PLL Circuits** and **7.4.2.4 Programming the PLL**.) PRE1 and PRE0 cannot be written when the PLLON bit is set. Reset clears these bits.

## **Clock Generator Module (CGMB)**

Table 7-2. PRE1 and PRE0 Programming

| PRE1 and PRE0 | Р | Prescaler multiplier |
|---------------|---|----------------------|
| 00            | 0 | 1                    |
| 01            | 1 | 2                    |
| 10            | 2 | 4                    |
| 11            | 3 | 8                    |

VPR1 and VPR0 — VCO power-of-two range select bits

These read/write bits control the VCO's hardware power-of-two range multiplier, E, that, in conjunction with L (See 7.4.2.1 PLL Circuits, 7.4.2.4 Programming the PLL, and 7.6.5 PLL VCO Range Select Register.) controls the hardware center-of-range frequency, f<sub>VRS</sub>. VPR1 and VPR0 cannot be written when the PLLON bit is set. Reset clears these bits.

Table 7-3. VPR1 and VPR0 Programming

| VPR1 and VPR0 | E | VCO power-of-two range multiplier |
|---------------|---|-----------------------------------|
| 00            | 0 | 1                                 |
| 01            | 1 | 2                                 |
| 10            | 2 | 4                                 |
| 11            | 3 | 8                                 |

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

Advance Information

Clock Generator Module (CGMB)
CGMB Registers



Figure 7-5. PLL Bandwidth Control Register (PBWC)

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

## **NOTE:** The write function of this bit is reserved for test, so this bit must always be written a 0.

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.

MC68HC(9)08LJ60 — Rev. 1.0

**MOTOROLA** 

Advance Information

## **Clock Generator Module (CGMB)**

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

#### 7.6.3 PLL Multiplier Select Register High

The PLL multiplier select register high (PMSH) contains the programming information for the high byte of the modulo feedback divider.



Figure 7-6. PLL Multiplier Select Register High (PMSH)

#### MUL11–MUL8 — Multiplier select bits

These read/write bits control the high byte of the modulo feedback divider that selects the VCO frequency multiplier N. (See **7.4.2.1 PLL Circuits** and **7.4.2.4 Programming the PLL**.) A value of \$0000 in the multiplier select registers configures the modulo feedback divider the same as a value of \$0001. Reset initializes the registers to \$0040, for a default multiply value of 64.

**NOTE:** The multiplier select bits have built-in protection such that they cannot be written when the PLL is on (PLLON = 1).

Clock Generator Module (CGMB)
CGMB Registers

#### 7.6.4 PLL Multiplier Select Register Low

The PLL multiplier select register (PMSL) low contains the programming information for the low byte of the modulo feedback divider.



Figure 7-7. PLL Multiplier Select Register Low (PMSL)

#### MUL7-MUL0 — Multiplier select bits

These read/write bits control the low byte of the modulo feedback divider that selects the VCO frequency multiplier, N. (See **7.4.2.1 PLL Circuits** and **7.4.2.4 Programming the PLL**.) MUL7–MUL0 cannot be written when the PLLON bit in the PCTL is set. A value of \$0000 in the multiplier select registers configures the modulo feedback divider the same as a value of \$0001. Reset initializes the register to \$40, for a default multiply value of 64.

**NOTE:** The multiplier select bits have built-in protection such that they cannot be written when the PLL is on (PLLON = 1).

## **Clock Generator Module (CGMB)**

#### 7.6.5 PLL VCO Range Select Register

The PLL VCO range select register (PVRS) contains the programming information required for the hardware configuration of the VCO.



Figure 7-8. PLL VCO Range Select Register (PVRS)

VRS7–VRS0 — VCO range select bits

These read/write bits control the hardware center-of-range linear multiplier L which, in conjunction with E (see 7.4.2.1 PLL Circuits, 7.4.2.4 Programming the PLL, and 7.6.1 PLL Control Register), controls the hardware center-of-range frequency, f<sub>VRS</sub>. VRS7–VRS0 cannot be written when the PLLON bit in the PCTL is set (see 7.4.2.5 Special Programming Exceptions).

A value of \$00 in the VCO range select register disables the PLL and clears the BCS bit in the PLL control register. (See **7.4.3 Base Clock Selector Circuit** and **7.4.2.5 Special Programming Exceptions**.). Reset initializes the register to \$40 for a default range multiply value of 64.

**NOTE:** The VCO range select bits have built-in protection such that they cannot be written when the PLL is on (PLLON = 1) and such that the VCO clock cannot be selected as the source of the base clock (BCS = 1) if the VCO range select bits are all clear.

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

Clock Generator Module (CGMB)
CGMB Registers

#### 7.6.6 PLL Reference Divider Select Register

The PLL reference divider select register (PRDS) contains the programming information for the modulo reference divider.



Figure 7-9. PLL Reference Divider Select Register (PRDS)

#### RDS3-RDS0 — Reference divider select bits

These read/write bits control the modulo reference divider that selects the reference division factor R. (See **7.4.2.1 PLL Circuits** and **7.4.2.4 Programming the PLL**.) RDS7–RDS0 cannot be written when the PLLON bit in the PCTL is set.

A value of \$00 in the reference divider select register configures the reference divider the same as a value of \$01. (See **7.4.2.5 Special Programming Exceptions**.) Reset initializes the register to \$01, for a default divide value of 1.

**NOTE:** The reference divider select bits have built-in protection such that they cannot be written when the PLL is on (PLLON = 1).

## **Clock Generator Module (CGMB)**

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

#### 7.8 Wait Mode

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

The WAIT instruction does not affect the CGMB. 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.

Advance Information

Clock Generator Module (CGMB)
CGMB During Break Interrupts

## 7.9 CGMB 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 6.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.

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

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

#### **Clock Generator Module (CGMB)**

For example, consider a system with a 5% 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 ±50 kHz. Fifty kHz = 5% of the 1-MHz step input.
- Or, 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 ±5 kHz. Five kHz = 5% 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 as follows:

- 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%. In automatic bandwidth control mode (see 7.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%. In automatic bandwidth control mode, lock time expires when the LOCK bit becomes set in the PLL bandwidth control register (PBWC). (See 7.4.2.3 Manual and Automatic PLL Bandwidth Modes.)

Advance Information

Clock Generator Module (CGMB)
Acquisition/Lock Time Specifications

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.

#### 7.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 reaction times of the PLL is the reference frequency,  $f_{RDV}$ . 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 crystal frequency  $f_{XCLK}$  and the R value programmed in the reference divider. (See 7.4.2.1 PLL Circuits, 7.4.2.4 Programming the PLL, and 7.6.6 PLL Reference Divider Select Register).

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 **7.10.3 Choosing a Filter Capacitor**.)

Also important is the operating voltage potential applied to  $V_{DDA}$ . 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.

MC68HC(9)08LJ60 — Rev. 1.0

Advance Information

## **Clock Generator Module (CGMB)**

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.

#### 7.10.3 Choosing a Filter Capacitor

As described in **7.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 also is dependent on reference frequency and supply voltage. The value of the capacitor must, therefore, be chosen with supply potential and reference frequency in mind. For proper operation, the external filter capacitor must be chosen according to this equation:

$$C_F = C_{FACT} \left( \frac{V_{DDA}}{f_{RDV}} \right)$$

For acceptable values of  $C_{FACT}$ , see **7.10 Acquisition/Lock Time Specifications**. 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 may become unstable. Also, always choose a capacitor with a tight tolerance (±20% or better) and low dissipation.

Clock Generator Module (CGMB)
Acquisition/Lock Time Specifications

#### 7.10.4 Reaction Time Calculation

The actual acquisition and lock times can be calculated using the equations here. These equations yield nominal values under the following conditions:

- Correct selection of filter capacitor, C<sub>F</sub> (see 7.10.3 Choosing a Filter Capacitor)
- Room temperature operation
- Negligible external leakage on CGMXFC
- Negligible noise

The K factor in the equations is derived from internal PLL parameters.  $K_{ACQ}$  is the K factor when the PLL is configured in acquisition mode, and  $K_{TRK}$  is the K factor when the PLL is configured in tracking mode. (See **7.4.2.2 Acquisition and Tracking Modes**.)

$$t_{ACQ} = \left(\frac{V_{DDA}}{f_{RDV}}\right) \left(\frac{8}{K_{ACQ}}\right)$$
$$t_{AL} = \left(\frac{V_{DDA}}{f_{RDV}}\right) \left(\frac{4}{K_{TRK}}\right)$$
$$t_{LOCK} = t_{ACQ} + t_{AL}$$

**NOTE:** The inverse proportionality between the lock time and the reference frequency.

In automatic bandwidth control mode, the acquisition and lock times are quantized into units based on the reference frequency. (See **7.4.2.3 Manual and Automatic PLL Bandwidth Modes**.) A certain number of clock cycles,  $n_{ACQ}$ , is required to ascertain that the PLL is within the tracking mode entry tolerance,  $\Delta_{TRK}$ , before exiting acquisition mode. A certain number of clock cycles,  $n_{TRK}$ , is required to ascertain that the PLL is within the lock mode entry tolerance,  $\Delta_{LOCK}$ . Therefore, the acquisition time,  $t_{ACQ}$ , is an integer multiple of  $n_{ACQ}/f_{RDV}$ , and the acquisition to lock time,  $t_{AL}$ , is an integer multiple of  $n_{TRK}/f_{RDV}$ . Also, since the average frequency over the entire measurement period must be within the specified tolerance, the total time usually is longer than  $t_{LOCK}$  as calculated above.

MC68HC(9)08LJ60 — Rev. 1.0

Advance Information

## **Clock Generator Module (CGMB)**

In manual mode, it is usually necessary to wait considerably longer than  $t_{LOCK}$  before selecting the PLL clock (see **7.4.3 Base Clock Selector Circuit**), because the factors described in **7.10.2 Parametric Influences on Reaction Time** may slow the lock time considerably.

Advance Information

## Advance Information — MC68HC(9)08LJ60

## Section 8. Functional Controller Module (FCM)

#### 8.1 Contents

| 8.2                            | Introduction                          |
|--------------------------------|---------------------------------------|
| 8.3                            | Features                              |
| 8.4                            | Functional Description                |
| 8.5<br>8.5.1<br>8.5.2<br>8.5.3 | Module Description                    |
| 8.6                            | Interrupts                            |
| 8.7                            | I/O Signals                           |
| 8.8                            | Interrupt Signals (FCM, CPU, and IRQ) |
| 8.9<br>8.9.1                   | Functional Controller Registers       |
| 8.9.2                          | RTC Control Register                  |
| 8.9.3                          | RTC Status Register                   |
| 8.9.4                          | Chronograph Data Register             |
| 8.9.5<br>8.9.6                 | Seconds Data Register                 |
| 8.9.7                          | Minutes Data Register                 |
| 8.9.8                          | Alarm Minutes Register                |
| 8.9.9                          | Alarm Hours Register                  |

## **Functional Controller Module (FCM)**

#### 8.2 Introduction

The FCM provides timekeeping functions and the software computer operating properly (COP) mechanism.

#### 8.3 Features

#### Features of the FCM include:

- Real-time clock with seconds, minutes, and hours counters
- Software chronograph counter
- Watchdog timer
- Alarm clock with interrupts

## 8.4 Functional Description

The functional controller module (FCM) includes several of the functional controller circuits traditionally designed into custom MCUs for paging applications. This module is specifically targeted for use with the HC08 CPU.

The circuits included are:

- Real-time clock (RTC) interrupts with chronograph register
- Watchdog timer, also called the computer operating properly (COP) timer
- Time base circuit which supports 32.000-kHz and 38.400-kHz crystal oscillators

In addition to these two crystal options, a provision to use a crystal with a frequency two times these frequencies has been created. This was designed specifically for use with a 76.8-kHz crystal oscillator.

This module provides nine registers for software control. The clock source of the RTC interrupts and status registers are synchronized to the bus timing to ensure synchronous register access.

Advance Information

Functional Controller Module (FCM)
Functional Description



Figure 8-1. Functional Controller Block Diagram

## **Functional Controller Module (FCM)**



Figure 8-2. Real-Time Clock System Block Diagram

Functional Controller Module (FCM) Module Description

## 8.5 Module Description

The functional controller module is an HC08-compatible module designed for use in paging applications. It connects to the HC08 internal bus and communicates to the HC08 CPU by way of the address bus, data bus, and control signals. The crystal oscillator signal (CGMXCLK) enters the module and connects to the timebase circuit. The timebase creates clock signals which feed the real-time clock.

#### 8.5.1 Timebase Submodule

The timebase submodule is designed to create timing signals equivalent to any binary division of the crystal oscillator frequency. Clock signals created at frequencies of 1 Hz, 2 Hz, and 4 Hz are fed to the real-time clock (RTC) submodule. When a frequency of 4 Hz is selected, the frequency will vary from 5 Hz to 3.3 Hz with an average of 4 Hz. The timebase circuit also generates a 100-Hz clock signal which is fed to the RTC to produce a software chronograph function. In addition, two signals (1 kHz and 2 kHz) are created for use by other MCU modules. Software selectable options are available to support the use of a 32.000-kHz or 38.400-kHz crystal oscillator. The default option is for 38.400 kHz.

#### 8.5.2 Real-Time Clock Submodule

The RTC module consists of the RTC control register, the chronograph data register, the hours, minutes, and seconds registers for timekeeping, and the hours and minutes alarm registers. The real-time clock (RTC) system will provide a periodic interrupt to the CPU of 1 hour, 1 minute, 1 second, 1 Hz, 2 Hz, or 4 Hz for software timekeeping functions and an interrupt with 10 Hz resolution which can be used to generate chronometer functions in software. When a a periodic interrupt of 4 Hz is selected, the periodic interrupt will vary from 5 Hz to 3.3 Hz with an average of 4 Hz. The chronograph data register can be cleared using the CHRC bit in the timebase control register. See Figure 8-4. The timebase counter can also be cleared by setting the TBCLR in the timebase control register. See Figure 8-4.

MC68HC(9)08LJ60 — Rev. 1.0

Advance Information

## **Functional Controller Module (FCM)**

#### NOTE:

This section assumes that a 32.000-kHz oscillator or a 38.400-kHz oscillator is used, according to the software option selected. These crystals will generate precise interrupts. Crystals of a frequency two times these frequencies can also be used to generate accurate RTC clock control. Any other oscillator frequency will not provide accurate 100 Hz and 1 Hz counters.

#### 8.5.3 COP Watchdog Timer Submodule

The computer operating properly (COP) or watchdog timer subsystem is a software selectable feature which will generate a system reset if not serviced within the specified watchdog timeout period. The watchdog timer counter chain is derived from an output of the timebase circuit. This input signal is divided to give the watchdog timer reset rate selected by the first write to the COP select bits in the timebase control register.

A watchdog timer reset is performed by writing any data to address \$FFFF. This will reset the counter chain and begin the timeout countdown again. The watchdog timer counter chain is also cleared when the MCU is in reset.

The value of the two watchdog timer rate select bits in the timebase control register (TBCR) determines the watchdog timer timeout rate. These bits can be written only on the first write to this register after a reset. If these bits are never written to, the watchdog timer reset rate will be set at 1 second when a 32-kHz crystal is used (see **Table 8-1**).

#### NOTE:

Although these bits default to 0, the user should write to these bits to prevent subsequent writes from changing the timeout rate. A bit set/clear for any bit in this register is executed as a read-modify-write of this register. If used as the first write to this register, further writes to CRS[1:0] would not be valid, and the default value would still be set.

The CPU clock halts during wait mode, but the oscillator and the watchdog timer system are still active. The software should exit wait mode to service the watchdog timer system before the COP timeout period.

Advance Information

Functional Controller Module (FCM)
Interrupts

If the STOP instruction is executed on an MCU with stop mode enabled, the watchdog timer circuit will be disabled. The COP timer is enabled when the MCU comes out of reset.

**NOTE:** The MC68HC(9)08LJ60 does not allow stop mode operation.

### 8.6 Interrupts

The RTC submodule is capable of generating interrupts. Three different interrupts can be generated by the clock sections of the real-time clock submodule:

- 1 minute, 1 Hz, 2 Hz, or 4 Hz
- Alarm
- Chronograph, 10 Hz

These interrupts are enabled by setting the corresponding bit in the RTC control register.

**NOTE:** 

When an interrupt of 4 Hz is selected, the periodic interrupt will vary from 5 Hz to 3.3 Hz with an average of 4 Hz.

## 8.7 I/O Signals

The functional controller module is connected to the HC08 bus and has no external pins.

## 8.8 Interrupt Signals (FCM, CPU, and IRQ)

The interrupt signals provide the capability for sending an interrupt request to the CPU. The FCM has one interrupt line coming out of the FCM to the system integration module and is an OR function of the enabled interrupt sources (chronograph alarm, seconds, minutes, hours, or periodic interrupt).

MC68HC(9)08LJ60 — Rev. 1.0

## 8.9 Functional Controller Registers

Figure 8-3 provides a summary of the functional controller registers.

| Addr.  | Name                                         |        | Bit 7 | 6         | 5       | 4        | 3         | 2       | 1       | Bit 0   |
|--------|----------------------------------------------|--------|-------|-----------|---------|----------|-----------|---------|---------|---------|
| \$0035 |                                              | Read:  | RTCE  | 0         | CHRC    | CRS1     | CRS0      | R       | TB2X    | TB0     |
|        | Timebase Control Register (TBCR)             | Write: | RICL  | TBCLR     |         |          | CNSU      | K       | IDZA    | 100     |
|        | , ,                                          | Reset: | 0     | 0         | 0       | 0        | 0         | 0       | 0       | 0       |
|        | DT0.0                                        | Read:  | HRIE  | MINIE     | SECIE   | CHRIE    | CHRCE     | ALIEN   | PRQ1    | PRQ0    |
| \$0036 | RTC Control Register<br>(RTCCR)              | Write: | THAL  |           | 020.2   |          | OTINGE    | ALILIN  | TRQT    | 1100    |
|        |                                              | Reset: | 0     | 0         | 0       | 0        | 0         | 0       | 0       | 0       |
|        | DT0 01 1 D 1 1                               | Read:  | 0     | 0         | PRQF    | HORF     | MINF      | SECF    | AFLG    | CHRF    |
| \$0037 | RTC Status Register<br>(RTCSR)               | Write: |       |           |         |          |           |         |         |         |
|        | ,                                            | Reset: | 0     | 0         | 0       | 0        | 0         | 0       | 0       | 0       |
| \$0038 | Chronograph Data Register<br>(CHRDR)         | Read:  | BIT 7 | BIT 6     | BIT 5   | BIT 4    | BIT 3     | BIT 2   | BIT 1   | BIT 0   |
|        |                                              | Write: |       |           |         |          |           |         |         |         |
|        |                                              | Reset: | 0     | 0         | 0       | 0        | 0         | 0       | 0       | 0       |
|        | RTC Seconds Register<br>(SECR)               | Read:  | 0     | 0         | SEC5    | SEC4     | SEC3      | SEC2    | SEC1    | SEC0    |
| \$0039 |                                              | Write: |       |           |         |          |           |         |         |         |
|        |                                              | Reset: | 0     | 0         | 0       | 0        | 0         | 0       | 0       | 0       |
|        | RTC Minutes Register<br>(MINR)               | Read:  | 0     | 0         | MIN5    | MIN4     | MIN3      | MIN2    | MIN1    | MIN0    |
| \$003A |                                              | Write: |       |           | IVIIIVI | IVIIIV   | IVIIIVO   | IVIIIVZ | IVIIIVI | IVIIIVO |
|        |                                              | Reset: | 0     | 0         | 0       | 0        | 0         | 0       | 0       | 0       |
| \$003B |                                              | Read:  | 0     | 0         | 0       | HOR4     | HOR3      | HOR2    | HOR1    | HOR0    |
|        | RTC Hours Register<br>(HORR)                 | Write: |       |           |         | 110K4    | 11013     | HORZ    | HOKI    | HORO    |
|        | , ,                                          | Reset: | 0     | 0         | 0       | 0        | 0         | 0       | 0       | 0       |
|        |                                              |        |       | = Unimple | emented | R        | = Reserve | d       |         |         |
|        | Figure 0.0 Communication of the Franchism of |        |       |           |         | <u> </u> |           |         |         |         |

Figure 8-3. Summary of the Functional Controller Registers

Functional Controller Module (FCM)
Functional Controller Registers



Figure 8-3. Summary of the Functional Controller Registers (Continued)

#### 8.9.1 Timebase Control Register

This timebase control register (TBCR) is a read/write register containing control bits for the timebase outputs which feed other circuits.



Figure 8-4. Timebase Control Register (TBCR)

RTCE — Real-time clock enable

When set to 1, the real-time clock counters are enabled. This bit is cleared by reset.

**NOTE:** Enabling this bit will affect the clock that increments the seconds counter. It is recommended that this write be performed at the start of the reset sequence, to limit any timing discrepancies resulting from the timebase clocks.

MC68HC(9)08LJ60 — Rev. 1.0

### **Functional Controller Module (FCM)**

TBCLR — Timebase clear

When set to 1, the timebase counter chain is cleared. This bit will automatically clear after the timebase clear function has occurred. This bit will always read a 0 and is cleared by reset.

**NOTE:** Clearing the timebase by setting TBCLR will affect all clocks derived from the timebase, including the real-time clock inputs and the LCD.

CHRC — Chronograph clear

This bit clears all bits in the chronograph data register and holds it at that state until this bit is cleared by software.

0 = Allows chronograph data register to begin counting

1 = Clears chronograph data register and holds value at \$00

CRS1 and CRS0 — COP rate select

The value of these two bits determines the watchdog timer (WDT) timeout rate. These bits can be written only on the first write to this register after reset. If these bits are never written to, the WDT reset rate will be set at one second.

**NOTE:** Although these bits default to 0, the user should write to these bits to prevent subsequent writes from changing the timeout rate.

A bit set/clear for any bit in this register is executed as a read-modifywrite of this register. If used as the first write to this register, further writes to CRS[1:0] would not be valid, and the default value would be set.

**Table 8-1. Watchdog Timer Timeout Rates** 

| CRS1 and CRS0 | Minimum COP rate<br>@32.000 kHz | Minimum COP rate<br>@38.400 kHz |  |  |  |  |
|---------------|---------------------------------|---------------------------------|--|--|--|--|
| 00            | 1 sec                           | 0.85 sec                        |  |  |  |  |
| 01            | 2 sec                           | 1.7 sec                         |  |  |  |  |
| 10            | 4 sec                           | 3.4 sec                         |  |  |  |  |
| 11            | 8 sec                           | 6.8 sec                         |  |  |  |  |

**NOTE:** Watchdog refresh shortens the minimum COP rates, given in **Table 8-1**, by 0.0067 seconds for 38.4K crystal and by 0.008 seconds for 32K crystal.

Advance Information

MC68HC(9)08LJ60 — Rev. 1.0

Functional Controller Module (FCM)
Functional Controller Registers

TB2X — Timebase times 2

When set to 1, the timebase counter chain is divided by two. This bit was added specifically to accommodate the use of the 76.8-kHz crystal oscillator. This bit is cleared by reset.

**NOTE:** This bit can only be set ONCE following a reset and can be written only on the first write to this register after reset.

TBO — Timebase crystal option bit

This bit is used to configure the timebase clocks for the crystal oscillator used to clock the MCU. Refer to **Table 8-2** for the crystal options selected by these bits. This bit is cleared by reset.

**Table 8-2. Timebase Crystal Options** 

| ТВО | Crystal (Hz) |  |  |  |  |
|-----|--------------|--|--|--|--|
| 0   | 38400        |  |  |  |  |
| 1   | 32000        |  |  |  |  |

**NOTE:** The timebase will start up as if the 38.4-kHz option had been chosen until this bit is written to. This bit can only be set ONCE following a reset and can be written only on the first write to this register after reset. It is recommended that this write be performed at the start of the reset sequence, to limit any timing discrepancies resulting from the timebase

MC68HC(9)08LJ60 - Rev. 1.0

clocks.

### **Functional Controller Module (FCM)**

#### 8.9.2 RTC Control Register

The RTC control register (RTCCR) is a read/write register containing eight control bits. These bits enable the chronograph function and control interrupts associated with the RTC status register flags.



Figure 8-5. RTC Control Register (RTCCR)

#### HRIE — Hours interrupt enable

This bit controls whether an interrupt is generated when the HORF bit is set in the RTC status register.

0 = Interrupt disabled

1 = Interrupt enabled

#### MINIE — Minutes interrupt enable

This bit controls whether an interrupt is generated when the MINF bit is set in the RTC status register.

0 = Interrupt disabled

1 = Interrupt enabled

#### SECIE — Seconds interrupt enable

This bit controls whether an interrupt is generated when the SECF bit is set in the RTC status register.

0 = Interrupt disabled

1 = Interrupt enabled

#### CHRIE — Chronograph interrupt enable

This bit controls whether an interrupt is generated when the CHRF bit is set in the RTC status register.

0 = Interrupt disabled

1 = Interrupt enabled

Advance Information

MC68HC(9)08LJ60 — Rev. 1.0

Functional Controller Module (FCM)
Functional Controller Registers

CHRCE — Chronograph clock enable

This bit controls the 100 Hz clock signal to the RTC chronograph register. This bit is cleared by reset.

0 = 100 Hz signal disabled, RTC chronograph off

1 = 100 Hz signal enabled

ALIEN — Alarm interrupt enable

This bit controls whether an interrupt is generated when the AFLG bit is set in the RTC status register.

0 = Interrupt disabled

1 = Interrupt enabled

PRQ1 and PRQ0 — RTC periodic interrupt selection bits

These bits control which frequency pulse should be sent from the RTC to generate a periodic interrupt request. This request is sent to the CPU. These bits select periodic interrupts of 1 Hz, 2 Hz, or 4 Hz as shown in **Table 8-3**.

Table 8-3. PRQ1 and PRQ0 RTC Interrupt Periods

| PRQ1 and PRQ0 | RTC interrupt period      |
|---------------|---------------------------|
| 00            | RTC interrupt is disabled |
| 01            | RTC interrupt is 1 Hz     |
| 10            | RTC interrupt is 2 Hz     |
| 11            | RTC interrupt is 4 Hz     |

**NOTE:** When a periodic interrupt of 4 Hz is selected, the periodic interrupt will vary from 5 Hz to 3.3 Hz with an average of 4 Hz.

## **Functional Controller Module (FCM)**

#### 8.9.3 RTC Status Register

The RTC status register (RTCSR) is a read-only register containing six status bits. See **Figure 8-6**.



Figure 8-6. RTC Status Register (RTCSR)

#### PRQF — Periodic interrupt fag

PRQF is a status bit indicating that the 1 Hz, 2 Hz, or 4 Hz interval has elapsed. When a a periodic interrupt of 4 Hz is selected, the periodic interrupt will vary from 5 Hz to 3.3 Hz with an average of 4 Hz. Reset clears PRQF. A CPU interrupt will be generated if the PRQ1 and PRQ0 bits are set in the RTCCR.

- 0 = Flag cleared by a read of the RTC Status Register with the PRQF flag set, followed by a read of the RTC Control Register.
   Both read operations need not be consecutive.
- 1 = Flag automatically set at 1 Hz, 2 Hz, or 4 Hz intervals. When a a periodic interrupt of 4 Hz is selected, the periodic interrupt will vary from 5 Hz to 3.3 Hz with an average of 4 Hz.

#### HORF — Hours flag

HORF is a status bit indicating that the hours counter has rolled over. Reset clears HORF. A CPU interrupt will be generated if the HRIE bit is set in the RTCCR.

- 0 = Flag cleared by a read of the RTC status register with the HORF flag set, followed by a read of the hours register. Both read operations need not be consecutive.
- 1 = Flag automatically set at 1-hour intervals

Functional Controller Module (FCM)
Functional Controller Registers

#### MINF — Minutes flag

MINF is a status bit indicating that the minutes counter 1 has rolled over. Reset clears MINF. A CPU interrupt will be generated if the MINIE bit is set in the RTCCR.

- 0 = Flag cleared by a read of the RTC status register with the MINF flag set, followed by a read of the minutes register. Both read operations need not be consecutive.
- 1 = Flag automatically set at 1 minute intervals

#### SECF — Seconds flag

SECF is a status bit indicating that the seconds counter 1-Hz interval has elapsed. Reset clears SECF. A CPU interrupt will be generated if the SECIE bit is set in the RTCCR.

- 0 = Flag cleared by a read of the RTC status register with the SECF flag set, followed by a read of the seconds register. Both read operations need not be consecutive.
- 1 = Flag automatically set at 1-Hz intervals

#### AFLG — Alarm flag

AFLG is a status bit indicating that the hours counter matches the alarm hours register and the minutes counter matches the alarm minutes register. Reset clears AFLG. A CPU interrupt will be generated if the ALIEN bit is set in the RTCCR.

- 0 = Flag cleared by a read of the RTC status register with the AFLG flag set, followed by a read of the alarm minutes register. Both read operations need not be consecutive.
- 1 = Flag automatically set at scheduled alarm time

#### CHRF — Chronograph flag

CHRF is a status bit indicating that the chronograph 10-Hz interval has elapsed. A CPU interrupt request will be generated if CHRIE is set. Reset clears CHRF.

- 0 = Flag cleared by a read of the RTC status register with the CHRF flag set, followed by a read of the chronograph data register. Both read operations need not be consecutive.
- 1 = Flag automatically set at 10-Hz intervals

### **Functional Controller Module (FCM)**

#### 8.9.4 Chronograph Data Register

The chronograph data register (CHRDR) is a read-only register containing the value of a counter which is driven by the 100-Hz output of the timebase circuit. This counter has a resolution of 1 ÷ 100 seconds, or 10 ms. The counter rolls over to 0 after reaching \$FF. Appropriate software must be written to convert the value read from this register in real time.



Figure 8-7. Chronograph Data Register (CHRDR)

#### 8.9.5 Seconds Data Register

The seconds data register (SECR) is a read-write register containing the value of a counter which is driven by the 1-Hz output of the timebase circuit. Only six bits are used in this register, which rolls over to 0 when the count reaches 59. Reset clears these bits. Once the correct value is set in this register, the register will contain the current time in seconds.



Figure 8-8. Seconds Data Register (SECR)

Advance Information

MC68HC(9)08LJ60 — Rev. 1.0

Functional Controller Module (FCM)
Functional Controller Registers

#### 8.9.6 Minutes Data Register

The minutes data register (MINR) is a read-write register containing the value of a counter which is driven by the output of the seconds register. Only six bits are used in this register, which rolls over to 0 when the count reaches 59. Reset clears these bits. Once the correct time is written to this register, it will contain the current time in minutes.



Figure 8-9. Minutes Data Register (MINR)

#### 8.9.7 Hours Data Register

The hours data register (HORR) is a read-write register containing the value of a counter which is driven by the output of the minutes register. Only five bits are used in this register, which rolls over to 0 when the count reaches 23. Reset clears these bits. Once the current time is written to this register, it will contain the current time in the 24 hours clock.



Figure 8-10. Hours Data Register (HORR)

MC68HC(9)08LJ60 — Rev. 1.0

## **Functional Controller Module (FCM)**

#### 8.9.8 Alarm Minutes Register

The alarm minutes register (ALRMR) is a read-write register containing the value for alarm generation used to match with the minutes data register. Only six bits are used in this register. Reset clears these bits.



Figure 8-11. Alarm Minutes Register (ALRMR)

#### 8.9.9 Alarm Hours Register

The alarm hours register (ALRHR) is a read-write register containing the value for alarm generation used to match with the hours data register. Only five bits are used in this register. Reset clears these bits.



Figure 8-12. Alarm Hours Register (ALRHR)

## Advance Information — MC68HC(9)08LJ60

## Section 9. Break Module

#### 9.1 Contents

| 9.2                                     | Introduction                                                                                                                                                  |
|-----------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 9.3                                     | Features                                                                                                                                                      |
| 9.4<br>9.4.1<br>9.4.2<br>9.4.3<br>9.4.4 | Functional Description158Flag Protection During Break Interrupts160CPU During Break Interrupts160TIM During Break Interrupts160COP During Break Interrupts160 |
| 9.5<br>9.5.1<br>9.5.2                   | Break Module Registers                                                                                                                                        |
| 9.6<br>9.6.1                            | Low-Power Modes                                                                                                                                               |
| 9.6.2                                   | Stop Mode                                                                                                                                                     |

#### 9.2 Introduction

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

### **Break Module**

#### 9.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
- Computer operating properly (COP) disabling during break interrupts

### 9.4 Functional Description

When the internal address bus matches the value written in the break address registers, the break module issues a breakpoint signal (BKPT) to the system integration module (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 9-1 shows the structure of the break module.

Break Module Functional Description



Figure 9-1. Break Module Block Diagram



Figure 9-2. Break I/O Register Summary

# Break Module

#### 9.4.1 Flag Protection During Break Interrupts

The SIM controls whether or not 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. For further information, see **6.8.3 SIM Break Flag Control Register** and the **Break Interrupts** subsection for each module.

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

### 9.4.3 TIM During Break Interrupts

A break interrupt stops the timer counter.

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

Break Module Break Module Registers

## 9.5 Break Module Registers

Three registers control and monitor operation of the break module:

- Break status and control register (BRKSCR)
- Break address register high (BRKH)
- Break address register low (BRKL)

#### 9.5.1 Break Status and Control Register

The break status and control register (BRKSCR) contains break module enable and status bits.



Figure 9-3. Break Status and Control Register (BRKSCR)

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

MC68HC(9)08LJ60 — Rev. 1.0

#### 9.5.2 Break Address Registers

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



Figure 9-4. Break Address Register High (BRKH)



Figure 9-5. Break Address Register Low (BRKL)

#### 9.6 Low-Power Modes

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

#### 9.6.1 Wait Mode

If enabled, the break module is active in wait mode. In the break routine, the user can subtract one from the return address on the stack if SBSW is set. Clear the SBSW bit by writing logic 0 to it.

#### 9.6.2 Stop Mode

A break interrupt causes exit from stop mode and sets the SBSW bit in the SIM break status register. See **6.8 SIM Registers**.

**NOTE:** The MC68HC(9)08LJ60 does not allow stop mode operation.

162

### Advance Information — MC68HC(9)08LJ60

# Section 10. Power-On Reset Module (POR)

#### 10.1 Contents

| 10.2 | Introduction           |    | 63 |
|------|------------------------|----|----|
| 10.3 | Functional Description | 10 | 63 |

#### 10.2 Introduction

This section describes the power-on reset (POR) module (version B).

## 10.3 Functional Description

The POR module provides a known, stable signal to the MCU at power-on. This signal tracks  $V_{DD}$  until the MCU generates a feedback signal to indicate that it is properly initialized. At this time, the POR drives its output low. The POR is not a brown-out detector, low-voltage detector, or glitch detector.  $V_{DD}$  at the POR must go completely to 0 to reset the MCU. To detect power-loss conditions, use a low-voltage inhibit (LVI) module or other suitable circuit.

## Power-On Reset Module (POR)



#### NOTES:

- 1. PORHI goes high at power-up and is cleared when the SIM sets CNTRCLR.
- 2. Signal names are not necessarily accurate. This diagram is for logical illustration only and may not represent actual circuitry.

Figure 10-1. POR Block Diagram

### Advance Information — MC68HC(9)08LJ60

# Section 11. External Interrupt Module (IRQ)

#### 11.1 Contents

| 11.2   | Introduction                       | 165 |
|--------|------------------------------------|-----|
| 11.3   | Features                           | 165 |
| 11.4   | Functional Description             | 166 |
|        | IRQ1 Pin                           |     |
| 11.4.2 | IRQ2 Pin                           | 171 |
| 11.5   | IRQ Module During Break Interrupts | 172 |
| 11.6   | IRQ Status and Control Register    | 172 |

### 11.2 Introduction

This section describes the external interrupt (IRQ) module, which supports external interrupt functions.

#### 11.3 Features

Features of the IRQ module include:

- Two dedicated external interrupt pins, IRQ1 and IRQ2
- Separate IRQ1 and IRQ2 interrupt masks
- IRQ2 interrupt disable
- · Hysteresis buffers

## **External Interrupt Module (IRQ)**

## 11.4 Functional Description

A logic 0 applied to any of the external interrupt pins can latch a CPU interrupt request. Figure 11-2 shows the structure of the IRQ module.

Interrupt signals on the IRQ1 pin are latched into the IRQ1 latch. Interrupt signals on the IRQ2 pin are latched into the IRQ2 interrupt latch. An interrupt latch remains set until one of the following 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 ACK1 bit clears the IRQ1 latch. Writing a logic 1 to the ACK2 bit clears the IRQ2 interrupt latch.
- Reset A reset automatically clears both interrupt latches.



Figure 11-1. IRQ I/O Register Summary



Figure 11-2. IRQ Module Block Diagram

Advance Information

MC68HC(9)08LJ60 - Rev. 1.0

## **External Interrupt Module (IRQ)**

All of the external interrupt pins are falling-edge-triggered and are software-configurable to be both falling-edge and low-level-triggered. The MODE1 bit in the ISCR controls the triggering sensitivity of the IRQ1 pin. The MODE2 bit controls the triggering sensitivity of the IRQ2 pin and the keyboard interrupt pins.

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, software clear, or reset
- 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.

When set, the IMASK1 and IMASK2 bits in the ISCR mask 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 11-3**.)

External Interrupt Module (IRQ)
Functional Description



Figure 11-3. IRQ Interrupt Flowchart

## **External Interrupt Module (IRQ)**

#### 11.4.1 **IRQ1** Pin

A logic 0 on the IRQ1 pin can latch an interrupt request into the IRQ1 latch. A vector fetch, software clear, or reset clears the IRQ1 latch.

If the MODE1 bit is set, the IRQ1 pin is both falling-edge-sensitive and low-level-sensitive. With MODE1 set, both of these actions must occur to clear the IRQ1 latch:

- Vector fetch, software clear, or reset 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 ACK1 bit in the interrupt status and control register (ISCR). The ACK1 bit is useful in applications that poll the IRQ1 pin and require software to clear the IRQ1 latch. Writing to the ACK1 bit can also prevent spurious interrupts due to noise. Setting ACK1 does not affect subsequent transitions on the IRQ1 pin. A falling edge that occurs after writing to the ACK1 bit latches another interrupt request. If the IRQ1 mask bit, IMASK1, is clear, the CPU loads the program counter with the vector address at locations \$FFFA and \$FFFB.
- Return of the IRQ1 pin to logic 1 As long as the IRQ1 pin is at logic 0, the IRQ1 latch remains set.

The vector fetch or software clear and the return of the  $\overline{IRQ1}$  pin to logic 1 may occur in any order. The interrupt request remains pending as long as the  $\overline{IRQ1}$  pin is at logic 0.

If the MODE1 bit is clear, the IRQ1 pin is falling-edge-sensitive only. With MODE1 clear, a vector fetch or software clear immediately clears the IRQ1 latch.

Use the BIH or BIL instruction to read the logic level on the IRQ1 pin.

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

External Interrupt Module (IRQ) **Functional Description** 

#### 11.4.2 **IRQ2** Pin

When the IRQ2DIS bit is clear, a logic 0 on the IRQ2 pin can latch an interrupt request into the IRQ2/keyboard interrupt latch. A vector fetch, software clear, or reset clears the IRQ2/keyboard interrupt latch.

If the MODE2 bit is set, the IRQ2 pin is both falling-edge-sensitive and low-level-sensitive. With MODE2 set, both of these actions must occur to clear the IRQ2 interrupt latch:

- Vector fetch, software clear, or reset 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 ACK2 bit in the interrupt status and control register (ISCR). The ACK2 bit is useful in applications that poll the IRQ2 pin and require software to clear the IRQ2 interrupt latch. Writing to the ACK2 bit can also prevent spurious interrupts due to noise. Setting ACK2 does not affect subsequent transitions on the IRQ2 pin. A falling edge that occurs after writing to the ACK2 bit latches another interrupt request. If the IRQ2 mask bit, IMASK2, is clear, the CPU loads the program counter with the vector address at locations \$FFD2 and \$FFD3.
- Return of the  $\overline{IRQ2}$  pin to logic 1 As long as the  $\overline{IRQ2}$  pin is at logic 0, the IRQ2 interrupt latch remains set.

The vector fetch or software clear and the return of the IRQ2 pin to logic 1 may occur in any order. The interrupt request remains pending as long as the IRQ2 pin is at logic 0.

If the MODE2 bit is clear, the IRQ2 pin is falling-edge-sensitive only. With MODE2 clear, a vector fetch or software clear immediately clears the IRQ2 interrupt latch.

To determine the logic level on the IRQ2 pin, read the IRQ2 pin state bit, PIN2, in the ISCR. This bit reflects the value of the IRQ2 pin, even when the IRQ2DIS bit is set.

**NOTE:** See Section 19. Keyboard Interrupt (KBI) Module for more information about keyboard interrupt.

MC68HC(9)08LJ60 — Rev. 1.0

## **External Interrupt Module (IRQ)**

## 11.5 IRQ Module During Break Interrupts

The system integration module (SIM) controls whether the IRQ1 and IRQ2 interrupt latches 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 6.8.3 SIM Break Flag Control Register.)

To allow software to clear the IRQ1 latch and the IRQ2 interrupt 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 latches during the break state, write a logic 0 to the BCFE bit. With BCFE at logic 0 (its default state), writing to the ACK1 and ACK2 bits in the IRQ status and control register during the break state has no effect on the IRQ latches. See 11.6 IRQ Status and Control Register.

## 11.6 IRQ Status and Control Register

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

- Shows current state of IRQ2 pin
- Clears the IRQ1 and IRQ2 interrupt latches
- Masks IRQ1 and IRQ2 interrupt requests
- Controls triggering sensitivity of the IRQ1 and IRQ2 interrupt pins
- Disables IRQ2 interrupt requests

External Interrupt Module (IRQ) IRQ Status and Control Register



Figure 11-4. IRQ Status and Control Register (ISCR)

PIN2 — IRQ2 pin state bit

This read-only bit reflects the current logic level of the IRQ2 pin.

 $1 = \overline{IRQ2}$  pin at logic 1

 $0 = \overline{IRQ2}$  pin at logic 0

ACK2 — IRQ2 interrupt request acknowledge bit

Writing a logic 1 to this write-only bit clears the IRQ2/keyboard interrupt latch. ACK2 always reads as logic 0. Reset clears ACK2.

IMASK2 — IRQ2 interrupt mask bit

Writing a logic 1 to this read/write bit prevents the output of the IRQ2/keyboard interrupt latch from generating interrupt requests. Reset clears IMASK2.

 $1 = \overline{IRQ2}$  pin interrupt request disabled

 $0 = \overline{IRQ2}$  pin interrupt request enabled

MODE2 — IRQ2/keyboard interrupt edge/level select bit

This read/write bit controls the triggering sensitivity of the IRQ2 interrupt pin. Reset clears MODE2.

 $1 = \overline{IRQ2}$  interrupt request on falling edges and low levels

 $0 = \overline{IRQ2}$  interrupt request on falling edges only

IRQ2DIS — IRQ2 pin interrupt latch disable bit

This read/write bit prevents the  $\overline{IRQ2}$  pin from latching interrupt requests into the IRQ2 interrupt latch. Reset clears IRQ2DIS.

 $1 = \overline{IRQ2}$  pin interrupt requests not latched

 $0 = \overline{IRQ2}$  pin interrupt requests latched

MC68HC(9)08LJ60 — Rev. 1.0

### **External Interrupt Module (IRQ)**

ACK1 — IRQ1 interrupt request acknowledge bit

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

IMASK1 — IRQ1 interrupt mask bit

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

- 1 = IRQ1 interrupt requests disabled
- 0 = IRQ1 interrupt requests enabled

MODE1 — IRQ1 edge/level select bit

This read/write bit controls the triggering sensitivity of the IRQ1 pin. Reset clears MODE1.

- $1 = \overline{IRQ1}$  interrupt request on falling edges and low levels
- $0 = \overline{IRQ1}$  interrupt request on falling edges only

## Advance Information — MC68HC(9)08LJ60

# Section 12. Serial Communications Interface Module (SCI)

### 12.1 Contents

MC68HC(9)08LJ60 - Rev. 1.0

### Serial Communications Interface Module (SCI)

| 12.8   | I/O Registers          | 195 |
|--------|------------------------|-----|
| 12.8.1 | SCI Control Register 1 | 195 |
| 12.8.2 | SCI Control Register 2 | 199 |
| 12.8.3 | SCI Control Register 3 | 202 |
| 12.8.4 | SCI Status Register 1  | 204 |
| 12.8.5 | SCI Status Register 2  | 207 |
| 12.8.6 | S SCI Data Register    | 208 |
| 12.8.7 | SCI Baud Rate Register | 209 |

#### 12.2 Introduction

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

#### **NOTE:**

References to DMA and associated functions are only valid if the MCU has a DMA module. This MCU does not have the DMA function. Any DMA-related register bits should be left in their reset state for normal MCU operation.

#### 12.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 CPU interrupt requests
- Programmable transmitter output polarity

Serial Communications Interface Module (SCI)

Functional Description

- 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

## 12.4 Functional Description

**Figure 12-1** shows the structure of the SCI module. The SCI allows full-duplex, asynchronous, NRZ serial communication among 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.

# Serial Communications Interface Module (SCI)



Figure 12-1. SCI Module Block Diagram

Serial Communications Interface Module (SCI) Functional Description

| 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    | то       | DMARE   | DMATE     | ORIE       | NEIE  | FEIE | PEIE  |
| \$0015 | SCI Control Register 3 (SCC3)    | Write:          |       | Т8       |         |           |            |       |      |       |
|        | (,                               | Reset:          | U     | U        | 0       | 0         | 0          | 0     | 0    | 0     |
|        | SCI Status Register 1<br>(SCS1)  | Read:           | SCTE  | TC       | SCRF    | IDLE      | OR         | NF    | FE   | PE    |
| \$0016 |                                  | Write:          |       |          |         |           |            |       |      |       |
|        |                                  | Reset:          | 1     | 1        | 0       | 0         | 0          | 0     | 0    | 0     |
|        | SCI Status Register 2<br>(SCS2)  | Read:           |       |          |         |           |            |       | BKF  | RPF   |
| \$0017 |                                  | Write:          |       |          |         |           |            |       |      |       |
|        | ,                                | Reset:          | 1     | 1        | 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   | T0    |
|        | ,                                | Reset:          |       |          |         | Unaffecte | d by reset |       |      |       |
| \$0019 | SCI Baud Rate Register<br>(SCBR) | Read:           |       |          | SCP1    | SCP0      |            | SCR2  | SCR1 | SCR0  |
|        |                                  | Write:          |       |          | 3671    | SCPU      |            | JURZ  | JUKI | JUNU  |
|        | ,                                | Reset:          | 0     | 0        | 0       | 0         | 0          | 0     | 0    | 0     |
|        |                                  |                 |       | = Unimpl | emented |           | U = Unaffe | ected |      |       |
|        |                                  | '               |       | '        |         |           |            |       |      |       |

Figure 12-2. SCI Input/Output (I/O) Register Summary

### Serial Communications Interface Module (SCI)

#### 12.4.1 Data Format

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



Figure 12-3. SCI Data Formats

#### 12.4.2 Transmitter

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

NOTE:

The transmission output pin is enabled by TE bit of SCC2 instead of ENSCI bit of SCC1.

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

#### 12.4.2.2 Character Transmission

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

Advance Information

MC68HC(9)08LJ60 — Rev. 1.0

Serial Communications Interface Module (SCI) Functional Description

#### To initiate an SCI transmission:

- Enable the SCI by writing a logic 1 to the enable SCI bit (ENSCI) in SCI control register 1 (SCC1).
- 2. Enable the transmitter by writing a logic 1 to the transmitter enable bit (TE) in SCI control register 2 (SCC2).
- Clear the SCI transmitter empty bit (SCTE) by reading SCI status register 1 (SCS1).
- 4. Write the data to transmit into the SCDR.
- 5. Repeat steps 3 and 4 for each subsequent transmission.

At the start of a transmission, transmitter control logic automatically loads the transmit shift register with a preamble of 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 position of the transmit shift register. A logic 1 stop bit goes into the most significant bit position.

The SCI transmitter empty bit, SCTE, in 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, SCTIE, in SCC2 is also set, the SCTE bit generates an SCTE CPU interrupt request.

When the transmit shift register is not transmitting a character, the TxD pin goes to the idle condition, logic 1.

### Serial Communications Interface Module (SCI)



Figure 12-4. SCI Transmitter

#### 12.4.2.3 Break Characters

Writing a logic 1 to the send break bit, SBK, in 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 in 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.

Advance Information

MC68HC(9)08LJ60 — Rev. 1.0

Serial Communications Interface Module (SCI) Functional Description

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 these effects on SCI registers:

- Sets the framing error flag, FE
- Sets the SCI receiver full flag, SCRF
- Clears the SCI data register
- Clears the received bit 8, R8
- Sets the break flag, BKF
- May set the overrun flag, OR, noise flag, NF, parity error flag, PE, or the reception in progress flag, RPF

#### 12.4.2.4 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 in SCC1. The preamble is a synchronizing idle character that begins every transmission.

If the TE bit is cleared during a transmission, the 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 TxD pin. Setting TE after the stop bit appears on 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.

### **Serial Communications Interface Module (SCI)**

### 12.4.2.5 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 12.8.1 SCI Control Register 1.)

#### 12.4.2.6 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 an SCTE CPU interrupt request. Setting the SCI transmit interrupt enable bit, SCTIE, in SCC2 enables SCTE CPU interrupts.
- 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 SCI transmitter
  interrupt enable bit, SCTIE, in SCC2 enables TC CPU interrupt
  requests.

#### 12.4.3 Receiver

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

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

Serial Communications Interface Module (SCI) Functional Description



Figure 12-5. SCI Receiver Block Diagram

MC68HC(9)08LJ60 - Rev. 1.0

**Advance Information** 

## Serial Communications Interface Module (SCI)

### 12.4.3.2 Character Reception

During an SCI reception, the receive shift register shifts characters in from the 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, in SCC2 is also set, the SCRF bit generates an SCRF CPU interrupt request.

### 12.4.3.3 Data Sampling

The receiver samples the RxD pin at the RT clock rate. The RT clock is an internal signal with a frequency 16 times the baud-rate frequency. (See **Figure 12-6**.)

- Start bit To locate the start bit, 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 a valid start bit, data recovery logic takes samples at RT3, RT5, and RT7. If any two of these three samples are logic 1s, the RT clock is reset and the search for start bit begins again. If all three samples are logic 0s, start bit verification is successful. If only one of the three samples is logic 1, start bit verification is successful, but the noise flag (NF) becomes set.
- Data bit To detect noise in data bits, recovery logic takes samples at RT8, RT9, and RT10 of every data bit time. If all three samples are not unanimous, the noise flag becomes set.
- Stop bit To detect noise in stop bits, recovery logic takes samples at RT8, RT9, and RT10. If all three samples are not unanimous, the noise flag becomes set.

Advance Information

MC68HC(9)08LJ60 — Rev. 1.0

Serial Communications Interface Module (SCI)
Functional Description



Figure 12-6. Receiver Data Sampling

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

**Table 12-1. Start Bit Verification** 

| RT3, RT5, and RT7 samples | Start bit 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          |

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 12-2** summarizes the results of the data bit samples.

MC68HC(9)08LJ60 — Rev. 1.0

Advance Information

### Serial Communications Interface Module (SCI)

Table 12-2. Data Bit Recovery

| RT8, RT9, and RT10 samples | Data bit 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          |

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

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

Table 12-3. Stop Bit Recovery

| RT8, RT9, and RT10 samples | Framing 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          |

Advance Information

MC68HC(9)08LJ60 — Rev. 1.0

Serial Communications Interface Module (SCI)
Functional Description

### 12.4.3.4 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. A break character also sets the FE flag because a break character has no stop bit. The FE flag is set at the same time that the SCRF bit is set.

#### 12.4.3.5 Baud Rate Tolerance

A transmitting device may be operating at a baud rate below or above the receiver baud rate. Accumulated bit time misalignment can cause one of the three stop bit data samples to fall outside the actual stop bit. Then a noise error occurs. If more than one of the samples is outside the stop bit, a framing error occurs. In most applications, the baud rate tolerance is much more than the degree of misalignment that is likely to occur.

As the receiver samples an incoming character, it resynchronizes the RT clock on any valid falling edge within the character. Resynchronization within characters corrects misalignments between transmitter bit times and receiver bit times.

#### **Slow Data Tolerance**

**Figure 12-7** shows how much a slow received character can be misaligned without causing a noise error or a framing error. The slow stop bit begins at RT8 instead of RT1 but arrives in time for the stop bit data samples at RT8, RT9, and RT10.



Figure 12-7. Slow Data

MC68HC(9)08LJ60 — Rev. 1.0

**Advance Information** 

### Serial Communications Interface Module (SCI)

For an 8-bit character, data sampling of the stop bit takes the receiver 9 bit times  $\times$  16 RT cycles + 10 RT cycles = 154 RT cycles.

With the misaligned character shown in **Figure 12-7**, the receiver counts 154 RT cycles at the point when the count of the transmitting device is

9 bit times  $\times$  16 RT cycles + 3 RT cycles = 147 RT cycles.

The maximum percent difference between the receiver count and the transmitter count of a slow 8-bit character with no errors is

$$\left| \frac{154 - 147}{154} \right| \times 100 = 4.54\%$$

For a 9-bit character, data sampling of the stop bit takes the receiver 10 bit times  $\times$  16 RT cycles + 10 RT cycles = 170 RT cycles.

With the misaligned character shown in **Figure 12-7**, the receiver counts 170 RT cycles at the point when the count of the transmitting device is

10 bit times  $\times$  16 RT cycles + 3 RT cycles = 163 RT cycles.

The maximum percent difference between the receiver count and the transmitter count of a slow 9-bit character with no errors is

$$\left| \frac{170 - 163}{170} \right| \times 100 = 4.12\%$$

#### **Fast Data Tolerance**

**Figure 12-8** shows how much a fast received character can be misaligned without causing a noise error or a framing error. The fast stop bit ends at RT10 instead of RT16 but is still there for the stop bit data samples at RT8, RT9, and RT10.



Figure 12-8. Fast Data

Serial Communications Interface Module (SCI) Functional Description

For an 8-bit character, data sampling of the stop bit takes the receiver 9 bit times  $\times$  16 RT cycles + 10 RT cycles = 154 RT cycles.

With the misaligned character shown in **Figure 12-8**, the receiver counts 154 RT cycles at the point when the count of the transmitting device is

10 bit times  $\times$  16 RT cycles = 160 RT cycles.

The maximum percent difference between the receiver count and the transmitter count of a fast 8-bit character with no errors is

$$\left| \frac{154 - 160}{154} \right| \times 100 = 3.90\%$$

For a 9-bit character, data sampling of the stop bit takes the receiver 10 bit times  $\times$  16 RT cycles + 10 RT cycles = 170 RT cycles.

With the misaligned character shown in **Figure 12-8**, the receiver counts 170 RT cycles at the point when the count of the transmitting device is

11 bit times  $\times$  16 RT cycles = 176 RT cycles.

The maximum percent difference between the receiver count and the transmitter count of a fast 9-bit character with no errors is

$$\left| \frac{170 - 176}{170} \right| \times 100 = 3.53\%$$

#### 12.4.3.6 Receiver Wakeup

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

Depending on the state of the WAKE bit in SCC1, either of two conditions on the RxD pin can bring the MCU 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 flag, SCRF. Software can then compare the character containing the address mark to the user-defined address of the

MC68HC(9)08LJ60 — Rev. 1.0

Advance Information

## Serial Communications Interface Module (SCI)

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.

 Idle input line condition — When the WAKE bit is clear, an idle character on the 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 flag, 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:** With the WAKE bit clear, setting the RWU bit after the RxD pin has been idle may cause the receiver to wake up immediately.

#### 12.4.3.7 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 an SCRF CPU interrupt request. Setting the
  SCI receive interrupt enable bit, SCRIE, in SCC2 enables SCRF
  CPU interrupts.
- Idle input (IDLE) The IDLE bit in SCS1 indicates that 10 or 11 consecutive logic 1s shifted in from the RxD pin. The idle line interrupt enable bit, ILIE, in SCC2 enables IDLE CPU interrupts.

### 12.4.3.8 Error Interrupts

These receiver error conditions can generate CPU interrupt requests:

 Receiver overrun (OR) — The OR bit in SCS1 indicates that the receive shift register shifted in a new character before the previous character was read from the SCDR. The overrun interrupt enable bit, ORIE, in SCC3 enables OR CPU interrupts.

Advance Information

MC68HC(9)08LJ60 — Rev. 1.0

Serial Communications Interface Module (SCI)

Low-Power Modes

- Noise flag (NF) The NF bit in SCS1 is set when the SCI detects noise on incoming data, including start, data, and stop bits. The noise error interrupt enable bit, NEIE, in SCC3 enables NF CPU interrupts.
- 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, in SCC3 enables FE CPU interrupts.
- 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, in SCC3 enables PE CPU interrupts.

### 12.5 Low-Power Modes

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

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

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

**NOTE:** The MC68HC(9)08LJ60 does not allow stop mode operation.

MC68HC(9)08LJ60 — Rev. 1.0

Advance Information

## Serial Communications Interface Module (SCI)

### 12.6 SCI 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 6.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 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.

## 12.7 I/O Signals

Port E shares two of its pins with the SCI module. The two SCI I/O (input/output) pins are:

- TxD Transmit data
- RxD Receive data

#### 12.7.1 TxD Pin, Transmit Data

The TxD pin is the serial data output from the SCI transmitter.

#### 12.7.2 RxD Pin, Receive Data

The RxD pin is the serial data input to the SCI receiver.

Advance Information

MC68HC(9)08LJ60 — Rev. 1.0

Serial Communications Interface Module (SCI)
I/O Registers

## 12.8 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)

### 12.8.1 SCI Control Register 1

The 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

### Serial Communications Interface Module (SCI)



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

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

Serial Communications Interface Module (SCI)
I/O Registers

#### M — Mode (character length) bit

This read/write bit determines whether SCI characters are eight or nine bits long. (See **Table 12-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 may 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 12-4**.) When enabled, the parity function inserts a parity bit in the most significant bit position. (See **Figure 12-3**.) Reset clears the PEN bit.

1 = Parity function enabled

0 = Parity function disabled

## Serial Communications Interface Module (SCI)

PTY — Parity bit

This read/write bit determines whether the SCI generates and checks for odd parity or even parity. (See **Table 12-4**.) Reset clears the PTY bit.

1 = Odd parity

0 = Even parity

**Table 12-4. Character Format Selection** 

| Control bits |         | Character format |           |        |           |                  |
|--------------|---------|------------------|-----------|--------|-----------|------------------|
| М            | PEN:PTY | Start bits       | Data bits | Parity | Stop bits | Character 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          |

Serial Communications Interface Module (SCI)
I/O Registers

### 12.8.2 SCI Control Register 2

The SCI control register 2 (SCC2):

- Enables these interrupts:
  - Transmitter interrupts
  - Transmission complete interrupts
  - Receiver interrupts
  - Idle line interrupts
- Enables the transmitter
- Enables the receiver
- Enables SCI wakeup
- Transmits SCI break characters



Figure 12-10. SCI Control Register 2 (SCC2)

SCTIE — SCI transmit interrupt enable bit

This read/write bit enables SCTE CPU interrupt requests. Setting the SCTIE bit enables SCTE CPU interrupt requests. Reset clears the SCTIE bit.

- 1 = SCTE CPU interrupt requests enabled
- 0 = SCTE CPU interrupt requests disabled

### **Serial Communications Interface Module (SCI)**

TCIE — Transmission complete interrupt enable bit

This read/write bit enables TC CPU interrupt requests. Reset clears the TCIE bit.

- 1 = TC CPU interrupt requests enabled
- 0 = TC CPU interrupt requests disabled

### SCRIE — SCI receive interrupt enable bit

This read/write bit enables SCRF CPU interrupt requests. Setting the SCRIE bit enables SCRF CPU interrupt requests. Reset clears the SCRIE bit.

- 1 = SCRF CPU interrupt requests enabled
- 0 = SCRF CPU interrupt requests disabled

#### ILIE — Idle line interrupt enable bit

This read/write bit enables IDLE CPU interrupt requests when the IDLE bit becomes set. Reset clears the ILIE bit.

- 1 = IDLE CPU interrupts enabled
- 0 = IDLE CPU interrupts disabled

#### 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 TxD pin. If software clears the TE bit, the transmitter completes any transmission in progress before the TxD returns to the idle condition (three-state). Reset clears the TE bit.

- 1 = Transmission enabled
- 0 = Transmission disabled

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

Serial Communications Interface Module (SCI)
I/O Registers

#### RWU — Receiver wakeup bit

This read/write bit puts the receiver in a standby state during which receiver interrupts are disabled. Typically, data transmitted to the receiver clears the RWU bit and returns the receiver to normal operation. The WAKE bit in SCC1 determines whether an idle input or an address mark brings the receiver out of the standby state. 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 being transmitted

### **Serial Communications Interface Module (SCI)**

### 12.8.3 SCI Control Register 3

SCI control register 3 (SCC3):

- Stores the ninth SCI data bit received and the ninth SCI data bit to be transmitted
- Enables SCI receiver full (SCRF) DMA service requests
- Enables SCI transmitter empty (SCTE) DMA service requests
- Enables these interrupts:
  - Receiver overrun interrupts
  - Noise error interrupts
  - Framing error interrupts
- Parity error interrupts



Figure 12-11. SCI Control Register 3 (SCC3)

#### R8 — Received bit 8

When the SCI is receiving 9-bit characters, R8 is the read-only bit 8 of the received character. R8 is received at the same time that the SCDR receives the other 8 bits. 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 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.

Advance Information

MC68HC(9)08LJ60 — Rev. 1.0

Serial Communications Interface Module (SCI)
I/O Registers

DMARE — DMA receive enable bit

This read/write bit enables SCI receiver full (SCRF) DMA service requests. (See 12.8.4 SCI Status Register 1.) Setting the DMARE bit disables SCRF CPU interrupt requests. Reset clears the DMARE bit.

- 1 = SCRF DMA service requests enabled; SCRF CPU interrupt requests disabled
- 0 = SCRF DMA service requests disabled; SCRF CPU interrupt requests enabled

**CAUTION:** There is no DMA module on this device. DMARE should be cleared.

DMATE — DMA transfer enable bit

This read/write bit enables SCI transmitter empty (SCTE) DMA service requests. (See 12.8.4 SCI Status Register 1.) Setting the DMATE bit disables SCTE CPU interrupt requests. Reset clears DMATE.

- 1 = SCTE DMA service requests enabled; SCTE CPU interrupt requests disabled
- 0 = SCTE DMA service requests disabled; SCTE CPU interrupt requests enabled

**CAUTION:** There is no DMA module on this device. DMATE should be cleared.

ORIE — Receiver overrun interrupt enable bit

This read/write bit enables receiver overrun (OR) CPU interrupt requests. (See 12.8.4 SCI Status Register 1.) Reset clears ORIE.

- 1 = OR CPU interrupt requests enabled
- 0 = OR CPU interrupt requests disabled

NEIE — Receiver noise error interrupt enable bit

This read/write bit enables receiver noise error (NE) CPU interrupt requests. (See 12.8.4 SCI Status Register 1.) Reset clears NEIE.

- 1 = NE CPU interrupt requests enabled
- 0 = NE CPU interrupt requests disabled

### **Serial Communications Interface Module (SCI)**

FEIE — Receiver framing error interrupt enable bit

This read/write bit enables receiver framing error (FE) CPU interrupt requests. (See 12.8.4 SCI Status Register 1.) Reset clears FEIE.

1 = FE CPU interrupt requests enabled

0 = FE CPU interrupt requests disabled

PEIE — Receiver parity error interrupt enable bit

This read/write bit enables receiver parity error (PE) CPU interrupt requests. (See 12.8.4 SCI Status Register 1.) Reset clears PEIE.

1 = PE CPU interrupt requests enabled

0 = PE CPU interrupt requests disabled

#### 12.8.4 SCI Status Register 1

SCI status register 1 (SCS1) contains flags to signal these 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



Figure 12-12. SCI Status Register 1 (SCS1)

Advance Information

MC68HC(9)08LJ60 — Rev. 1.0

Serial Communications Interface Module (SCI)
I/O Registers

#### 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 SCTE CPU interrupt request. When the SCTIE bit in SCC2 is set, SCTE generates an SCTE 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

### TC — Transmission complete bit

This clearable, read-only bit is set when the SCTE bit is set, and no data, preamble, or break character is being transmitted. TC generates a TC CPU interrupt request if the TCIE bit in SCC2 is also set. Clear the TC bit by reading SCS1 with TC set and then writing to the SCDR. 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 SCRF CPU interrupt request. When the SCRIE bit in SCC2 is set, SCRF generates an SCRF 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

### Serial Communications Interface Module (SCI)

#### 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 IDLE CPU interrupt request if the ILIE bit in SCC2 is also set. Clear the IDLE bit by reading SCS1 with IDLE set and then reading the SCDR. Once cleared, the IDLE bit can become set again only after the SCRF bit becomes set and another idle character appears on the receiver input. 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 OR 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

#### NF — Receiver noise flag bit

This clearable, read-only bit is set when the SCI detects noise on the 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 occurs during a stop bit time. FE generates an FE 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

Serial Communications Interface Module (SCI)
I/O Registers

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

### 12.8.5 SCI Status Register 2

SCI status register 2 (SCS2) contains flags to signal these conditions:

- · Break character detected
- Incoming data



Figure 12-13. 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 RxD pin. BKF does not generate an 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 RxD pin followed by another break character. Reset clears the BKF bit.

- 1 = Break character detected
- 0 = No break character detected

### Serial Communications Interface Module (SCI)

RPF —Reception in progress flag bit

This read-only bit is set during the RT1 time period of the start bit search. RPF does not generate an interrupt request. RPF is reset after the stop bit or when the SCI detects false start bits, usually from noise or a baud rate mismatch. 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

#### 12.8.6 SCI Data Register

The SCI data register (SCDR) 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.



Figure 12-14. SCI Data Register (SCDR)

R7/T7-R0/T0 — Receive/transmit data bits

Reading SCDR accesses the read-only received data bits, R7–R0. Writing to SCDR writes the data to be transmitted, T7–T0. Reset has no effect on the SCI data register.

Serial Communications Interface Module (SCI)

I/O Registers

### 12.8.7 SCI Baud Rate Register

The SCI baud rate register (SCBR) selects the baud rate for both the receiver and the transmitter.



Figure 12-15. SCI Baud Rate Register (SCBR)

SCP1 and SCP0 — SCI baud rate prescaler bits

These read/write bits select the baud rate prescaler divisor as shown in **Table 12-5**. Reset clears SCP1 and SCP0.

Table 12-5. SCI Baud Rate Prescaling

| SCP1 and 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 12-6**. Reset clears SCR2–SCR0.

## **Serial Communications Interface Module (SCI)**

Table 12-6. SCI Baud Rate Selection

| SCR2, SCR1, and 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{CGMOUT \div 2}{64 \times PD \times BD}$$

where:

CGMOUT ÷ 2 = bus frequency

PD = prescaler divisor

BD = baud rate divisor

**Table 12-7** shows the SCI baud rates that can be generated with a 4.9152-MHz crystal.

Serial Communications Interface Module (SCI)
I/O Registers

**Table 12-7. SCI Baud Rate Selection Examples** 

| SCP1:<br>SCP0 | Prescaler<br>divisor (PD) | SCR2:<br>SCR1:<br>SCR0 | Baud rate<br>divisor (BD) | Baud rate<br>(CGMXCLK ÷ 2 = 0.8192 MHz) |
|---------------|---------------------------|------------------------|---------------------------|-----------------------------------------|
| 00            | 1                         | 000                    | 1                         | 12,800                                  |
| 00            | 1                         | 001                    | 2                         | 6400                                    |
| 00            | 1                         | 010                    | 4                         | 3200                                    |
| 00            | 1                         | 011                    | 8                         | 1600                                    |
| 00            | 1                         | 100                    | 16                        | 800                                     |
| 00            | 1                         | 101                    | 32                        | 400                                     |
| 00            | 1                         | 110                    | 64                        | 200                                     |
| 00            | 1                         | 111                    | 128                       | 100                                     |
| 01            | 3                         | 000                    | 1                         | 4267                                    |
| 01            | 3                         | 001                    | 2                         | 2133                                    |
| 01            | 3                         | 010                    | 4                         | 1067                                    |
| 01            | 3                         | 011                    | 8                         | 533                                     |
| 01            | 3                         | 100                    | 16                        | 267                                     |
| 01            | 3                         | 101                    | 32                        | 133                                     |
| 01            | 3                         | 110                    | 64                        | 67                                      |
| 01            | 3                         | 111                    | 128                       | 33                                      |
| 10            | 4                         | 000                    | 1                         | 3200                                    |
| 10            | 4                         | 001                    | 2                         | 1600                                    |
| 10            | 4                         | 010                    | 4                         | 800                                     |
| 10            | 4                         | 011                    | 8                         | 400                                     |
| 10            | 4                         | 100                    | 16                        | 200                                     |
| 10            | 4                         | 101                    | 32                        | 100                                     |
| 10            | 4                         | 110                    | 64                        | 50                                      |
| 10            | 4                         | 111                    | 128                       | 25                                      |
| 11            | 13                        | 000                    | 1                         | 984                                     |
| 11            | 13                        | 001                    | 2                         | 492                                     |
| 11            | 13                        | 010                    | 4                         | 246                                     |
| 11            | 13                        | 011                    | 8                         | 123                                     |
| 11            | 13                        | 100                    | 16                        | 62                                      |
| 11            | 13                        | 101                    | 32                        | 31                                      |
| 11            | 13                        | 110                    | 64                        | 15                                      |
| 11            | 13                        | 111                    | 128                       | 8                                       |
|               |                           |                        |                           |                                         |

MC68HC(9)08LJ60 - Rev. 1.0

**Advance Information** 

Serial Communications Interface Module (SCI)

## Advance Information — MC68HC(9)08LJ60

# Section 13. Serial Peripheral Interface Module (SPI)

#### 13.1 Contents

| 13.2 Introduction                          | 14 |
|--------------------------------------------|----|
| 13.3 Features                              | 14 |
| 13.4 Functional Description                | 15 |
| 13.4.1 Master Mode                         | 17 |
| 13.5 Slave Mode2                           | 18 |
| 13.6 Transmission Formats2                 | 19 |
| 13.6.1 Clock Phase and Polarity Controls   |    |
| 13.6.2 Transmission Format When CPHA = 022 | 20 |
| 13.6.3 Transmission Format When CPHA = 122 | 22 |
| 13.6.4 Transmission Initiation Latency     | 23 |
| 13.7 Queuing Transmission Data             | 25 |
| 13.8 Error Conditions                      | 26 |
| 13.8.1 Overflow Error                      | 26 |
| 13.8.2 Mode Fault Error                    | 29 |
| 13.9 Interrupts                            | 31 |
| 13.10 Resetting the SPI                    | 33 |
| 13.11 Wait Mode23                          | 34 |
| 13.12 SPI During Break Interrupts          | 34 |
| 13.13 I/O Signals                          | 35 |
| 13.13.1 Master In/Slave Out (MISO)         | 35 |
| 13.13.2 Master Out/Slave In (MOSI)         | 36 |
| 13.13.3 Serial Clock (SPSCK)               | 36 |
| 13.13.4 Slave Select (SS)                  | 36 |
| 13.13.5 Clock Ground (EV <sub>SS</sub> )   | 38 |
| 13.14 I/O Registers23                      | 38 |
| 13.14.1 SPI Control Register               | 38 |
| 13.14.2 SPI Status and Control Register    | 41 |
| 13.14.3 SPI Data Register                  | 44 |
|                                            |    |

MC68HC(9)08LJ60 - Rev. 1.0

**Advance Information** 

### Serial Peripheral Interface Module (SPI)

### 13.2 Introduction

This section describes the serial peripheral interface (SPI) module which allows full-duplex, synchronous, serial communications with peripheral devices.

#### NOTE:

References to DMA and associated functions are only valid if the MCU has a DMA module. This MCU does not have the DMA function. Any DMA-related register bits should be left in their reset state for normal MCU operation.

#### 13.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
- Clock ground for reduced radio frequency (RF) interference
- Serial clock with programmable polarity and phase
- Two separately enabled interrupts:
  - 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

Serial Peripheral Interface Module (SPI) Functional Description

## 13.4 Functional Description

**Figure 13-1** shows the locations and contents of the SPI input/output (I/O) registers and **Figure 13-2** shows the structure of the SPI module.



Figure 13-1. SPI I/O Register Summary

The SPI module allows full-duplex, synchronous, serial communication among the MCU and peripheral devices, including other MCUs. Software can poll the SPI status flags or SPI operation can be interrupt-driven.

The following paragraphs describe the operation of the SPI module.

## Serial Peripheral Interface Module (SPI)



Figure 13-2. SPI Module Block Diagram

Serial Peripheral Interface Module (SPI)

Functional Description

#### 13.4.1 Master Mode

The SPI operates in master mode when the SPI master bit, SPMSTR, is set.

#### **NOTE:**

Configure the SPI modules as master or slave before enabling them. Enable the master SPI before enabling the slave SPI. Disable the slave SPI before disabling the master SPI. (See 13.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 transmit data register. If the shift register is empty, the byte immediately transfers to the shift register, setting the SPI transmitter empty bit, SPTE. The byte begins shifting out on the MOSI pin under the control of the serial clock. (See **Figure 13-3**.)

The SPR1 and SPR0 bits control the baud rate generator and determine the speed of the shift register. (See 13.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.

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, 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 with SPRF set and then reading the SPI data register. Writing to the SPI data register clears the SPTE bit.

# Serial Peripheral Interface Module (SPI)



Figure 13-3. Full-Duplex Master-Slave Connections

#### 13.5 Slave Mode

The SPI operates in slave mode when the SPMSTR bit 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 SPI must be at logic 0.  $\overline{SS}$  must remain low until the transmission is complete. (See 13.8.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 transfers to the receive data register, and the SPRF bit is set. To prevent an overflow condition, slave software then must read the receive data register before another full 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

Advance Information

MC68HC(9)08LJ60 — Rev. 1.0

Serial Peripheral Interface Module (SPI)

Transmission Formats

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 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 **13.6 Transmission Formats**.)

**NOTE:** 

SPSCK must be in the proper idle state before the slave is enabled to prevent SPSCK from appearing as a clock edge.

#### 13.6 Transmission Formats

During an SPI transmission, data is simultaneously transmitted (shifted out serially) and received (shifted in serially). A serial clock synchronizes shifting and sampling on the two serial data lines. A slave select line allows selection of an individual 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 optionally used to indicate multiple-master bus contention.

#### 13.6.1 Clock Phase and Polarity Controls

Software can select any of four combinations of serial clock (SPSCK) 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 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.

MC68HC(9)08LJ60 — Rev. 1.0

**Advance Information** 

# Serial Peripheral Interface Module (SPI)

**NOTE:** Before writing to the CPOL bit or the CPHA bit, disable the SPI by clearing the SPI enable bit (SPE).

#### 13.6.2 Transmission Format When CPHA = 0

Figure 13-4 shows an SPI transmission in which CPHA is logic 0. The figure should not be used as a replacement for data sheet parametric information. Two waveforms are shown for SPSCK: 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 (SPSCK), 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 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 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 13.8.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 SS pin is used to start the slave data transmission. The slave's SS pin must be toggled back to high and then low again between each byte transmitted as shown in Figure 13-5.

**NOTE:** The  $\overline{SS}$  pin on this device cannot be configured as a general-purpose I/O.

Serial Peripheral Interface Module (SPI)

Transmission Formats



Figure 13-4. Transmission Format (CPHA = 0)



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

# Serial Peripheral Interface Module (SPI)

#### 13.6.3 Transmission Format When CPHA = 1

Figure 13-6 shows an SPI transmission in which CPHA is logic 1. The figure should not be used as a replacement for data sheet parametric information. Two waveforms are shown for SPSCK; 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 (SPSCK), 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 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 SS pin of the master is not shown but is assumed to be inactive. The SS pin of the master must be high or must be reconfigured as general-purpose I/O not affecting the SPI. (See 13.8.2 Mode Fault Error.) When CPHA = 1, the master begins driving its MOSI pin on the first SPSCK edge. Therefore, the slave uses the first SPSCK edge as a start transmission signal. The 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.

**NOTE:** The  $\overline{SS}$  pin on this device cannot be configured as a general-purpose I/O.



Figure 13-6. Transmission Format (CPHA = 1)

Advance Information

MC68HC(9)08LJ60 - Rev. 1.0

Serial Peripheral Interface Module (SPI)

Transmission Formats

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.

#### 13.6.4 Transmission Initiation Latency

When the SPI is configured as a master (SPMSTR = 1), writing to the SPDR starts a transmission. CPHA has no effect on the delay to the start of the transmission, but it does affect the initial state of the SPSCK signal. When CPHA = 0, the SPSCK signal remains inactive for the first half of the first SPSCK cycle. When CPHA = 1, the first SPSCK cycle begins with an edge on the SPSCK 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 13-7.) The internal SPI clock in the master is a free-running derivative of the internal MCU clock. To conserve power, it is enabled only when both the SPE and SPMSTR bits are set. SPSCK 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 occurs relative to the slower SPSCK. This uncertainty causes the variation in the initiation delay shown in Figure 13-7. This delay is no longer than a single SPI bit time. That is, the maximum delay 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.



Figure 13-7. Transmission Start Delay (Master)

Serial Peripheral Interface Module (SPI)

Queuing Transmission Data

# 13.7 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) indicates when the transmit data buffer is ready to accept new data. Write to the transmit data register only when the SPTE bit is high. **Figure 13-8** shows the timing associated with doing back-to-back transmissions with the SPI (SPSCK has CPHA: CPOL = 1:0).



Figure 13-8. SPRF/SPTE CPU Interrupt Timing

MC68HC(9)08LJ60 — Rev. 1.0

Advance Information

# Serial Peripheral Interface Module (SPI)

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.

### 13.8 Error Conditions

These flags signal SPI error conditions:

- Overflow (OVRF) Failing to read the SPI data register before
  the next full 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. OVRF is in the SPI status and control
  register.
- Mode fault error (MODF) The MODF bit indicates that the voltage on the slave select pin (SS) is inconsistent with the mode of the SPI. MODF is in the SPI status and control register.

#### 13.8.1 Overflow Error

The overflow flag (OVRF) becomes set if the receive data register still has unread data from a previous transmission when the capture strobe of bit 1 of the next transmission occurs. The bit 1 capture strobe occurs in the middle of SPSCK cycle 7. (See Figure 13-4 and Figure 13-6.) If an overflow occurs, all data received after the overflow and before the OVRF bit is cleared does not transfer to the receive data register and does not set the SPI receiver full bit (SPRF). The unread data that transferred to the receive data register before the overflow occurred can

Advance Information

MC68HC(9)08LJ60 — Rev. 1.0

Serial Peripheral Interface Module (SPI) Error Conditions

still be read. Therefore, an overflow error always indicates the loss of data. Clear the overflow flag by reading the SPI status and control register and then reading the SPI data register.

OVRF generates a receiver/error CPU interrupt request if the error interrupt enable bit (ERRIE) is also set. The SPRF, MODF, and OVRF interrupts share the same CPU interrupt vector. It is not possible to enable MODF or OVRF individually to generate a receiver/error CPU interrupt request. However, leaving MODFEN low prevents MODF from being set.

If the CPU SPRF interrupt is enabled and the OVRF interrupt is not, watch for an overflow condition. **Figure 13-9** shows how it is possible to miss an overflow. The first part of **Figure 13-9** shows how it is possible to read the SPSCR and SPDR to clear the SPRF without problems. However, as illustrated by the second transmission example, the OVRF bit can be set in between the time that SPSCR and SPDR are read.



Figure 13-9. Missed Read of Overflow Condition

In this case, an overflow can easily be missed. Since no more SPRF interrupts can be generated until this OVRF is serviced, it is not 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 following the read of the SPDR. This ensures that the OVRF was not set before the SPRF was cleared and that future transmissions can set the SPRF bit. Figure 13-10 illustrates this process. Generally, to avoid this second SPSCR read, enable the OVRF to the CPU by setting the ERRIE bit.



Freescale Semiconductor, Inc.

Figure 13-10. Clearing SPRF When OVRF Interrupt Is Not Enabled

Serial Peripheral Interface Module (SPI)

Error Conditions

#### 13.8.2 Mode Fault Error

Setting the SPMSTR bit selects master mode and configures the SPSCK and MOSI pins as outputs and the MISO pin as an input. Clearing SPMSTR selects slave mode and configures the SPSCK and MOSI pins as inputs and the MISO pin as an output. The mode fault bit, MODF, becomes set any time the state of the slave select pin,  $\overline{SS}$ , is inconsistent with the mode selected by SPMSTR. To prevent SPI pin contention and damage to the MCU, a mode fault error occurs if:

- The SS pin of a slave SPI goes high during a transmission
- The SS pin of a master SPI goes low at any time

For the MODF flag to be set, the mode fault error enable bit (MODFEN) 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) is also set. The SPRF, MODF, and OVRF interrupts share the same CPU interrupt vector. It is not possible to enable MODF or OVRF individually 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 the following 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.

# Serial Peripheral Interface Module (SPI)

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 goes back to its idle level following 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 following the shift of the last data bit. (See **13.6 Transmission Formats**.)

**NOTE:** 

Setting the MODF flag does not clear the SPMSTR bit. The SPMSTR bit has no function when SPE = 0. Reading SPMSTR when MODF = 1 shows the difference between a MODF occurring when the SPI is a master and when it is a slave.

NOTE:

When CPHA = 0, a MODF occurs if a slave is selected (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 clearing the SPE bit of the slave.

**NOTE:** 

A logic 1 voltage on the  $\overline{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 it was already in the middle of a transmission.

To clear the MODF flag, read the SPSCR with the MODF bit set and then write to the SPCR register. This entire clearing mechanism must occur with no MODF condition existing or else the flag is not cleared.

Advance Information

MC68HC(9)08LJ60 — Rev. 1.0

Serial Peripheral Interface Module (SPI)
Interrupts

# 13.9 Interrupts

The four SPI status flags that can be enabled to generate CPU interrupt requests are discussed in **Table 13-1**.

Table 13-1. SPI Interrupts

| Flag                      | Request                                                             |
|---------------------------|---------------------------------------------------------------------|
| SPTE<br>Transmitter empty | SPI transmitter CPU interrupt request (DMAS = 0, SPTIE = 1,SPE = 1) |
| SPRF<br>Receiver full     | SPI receiver CPU interrupt request (DMAS = 0, SPRIE = 1)            |
| OVRF<br>Overflow          | SPI receiver/error interrupt request (ERRIE = 1)                    |
| MODF<br>Mode fault        | SPI receiver/error interrupt request (ERRIE = 1)                    |

Reading the SPI status and control register with SPRF set and then reading the receive data register clears SPRF. The clearing mechanism for the SPTE flag is always just a write to the transmit data register.

The SPI transmitter interrupt enable bit (SPTIE) enables the SPTE flag to generate transmitter interrupt requests provided that the SPI is enabled (SPE = 1).

The SPI receiver interrupt enable bit (SPRIE) enables the SPRF bit to generate receiver interrupt requests regardless of the state of the SPE bit. (See **Figure 13-11**.)

The error interrupt enable bit (ERRIE) enables both the MODF and OVRF bits 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 bit is enabled by the ERRIE bit to generate receiver/error CPU interrupt requests.

# Serial Peripheral Interface Module (SPI)



Figure 13-11. SPI Interrupt Request Generation

These sources in the SPI status and control register can generate 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 generates 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 generates an SPTE CPU interrupt request or an SPTE DMA service request.

Serial Peripheral Interface Module (SPI)

Resetting the SPI

# 13.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, the following occurs:

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

These 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 set all control bits again when SPE is set back 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 can also be disabled by a mode fault occurring in an SPI that was configured as a master with the MODFEN bit set.

# Serial Peripheral Interface Module (SPI)

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

# 13.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) enables software to clear status bits during the break state. (See 6.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 transmit data register in break mode does not initiate a transmission nor is this data transferred into the shift register. Therefore, a write to the SPDR in break mode with the BCFE bit cleared has no effect.

Advance Information

MC68HC(9)08LJ60 — Rev. 1.0

Serial Peripheral Interface Module (SPI)

I/O Signals

# 13.13 I/O Signals

The SPI module has five dedicated I/O pins.

- MISO Data received
- MOSI Data transmitted
- SPSCK Serial clock
- SS Slave select
- EV<sub>SS</sub> Clock ground

The SPI has limited inter-integrated circuit ( $I^2C$ ) capability (requiring software support) as a master in a single-master environment. To communicate with  $I^2C$  peripherals, MOSI becomes an open-drain output when the SPWOM bit in the SPI control register is set. In  $I^2C$  communication, the MOSI and MISO pins are connected to a bidirectional pin from the  $I^2C$  peripheral and through a pullup resistor to  $V_{DD}$ .

#### 13.13.1 Master In/Slave Out (MISO)

MISO is one of the two SPI module pins that transmits 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.

**NOTE:** The MISO pin on this device is not shared with an I/O port.

MC68HC(9)08LJ60 - Rev. 1.0

Advance Information

# Serial Peripheral Interface Module (SPI)

#### 13.13.2 Master Out/Slave In (MOSI)

MOSI is one of the two SPI module pins that transmits 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.

**NOTE:** The MOSI pin on this device is not shared with an I/O port.

#### 13.13.3 Serial Clock (SPSCK)

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.

NOTE: The SPSCK pin on this device is not shared with an I/O port.

# 13.13.4 Slave Select (SS)

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 13.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 between transmissions for the CPHA = 1 format. See Figure 13-12.

Advance Information

MC68HC(9)08LJ60 — Rev. 1.0

Serial Peripheral Interface Module (SPI)
I/O Signals



Figure 13-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 13.14.2 SPI Status and Control Register.)

**NOTE:** A logic 1 voltage on the  $\overline{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 it was already in the middle of a transmission.

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

**NOTE:** The  $\overline{SS}$  pin on this device cannot be used as a general-purpose I/O.

# Serial Peripheral Interface Module (SPI)

The CPU can always read the state of the  $\overline{SS}$  pin by configuring the appropriate pin as an input and reading the port data register. (See Table 13-2.)

Table 13-2. SPI Configuration

| SPE | SPMSTR           | MODFEN | SPI configuration   | State of SS logic                      |
|-----|------------------|--------|---------------------|----------------------------------------|
| 0   | X <sup>(1)</sup> | Х      | Not Enabled         | General-purpose I/O; SS ignored by SPI |
| 1   | 0                | Х      | Slave               | Input-only to SPI                      |
| 1   | 1                | 0      | Master without MODF | General-purpose I/O; SS ignored by SPI |
| 1   | 1                | 1      | Master with MODF    | Input-only to SPI                      |

<sup>1.</sup> X = Don't Care

#### 13.13.5 Clock Ground (EV<sub>SS</sub>)

EV<sub>SS</sub> is the ground return for the serial clock pin, SPSCK, and the ground for the port output buffers.

# 13.14 I/O Registers

Three registers control and monitor SPI operation:

- SPI control register (SPCR)
- SPI status and control register (SPSCR)
- SPI data register (SPDR)

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

Advance Information

MC68HC(9)08LJ60 — Rev. 1.0

Serial Peripheral Interface Module (SPI)
I/O Registers

- Configures the SPSCK, MOSI, and MISO pins as open-drain outputs
- Enables the SPI module



Figure 13-13. SPI Control Register (SPCR)

#### SPRIE — SPI receiver interrupt enable bit

This read/write bit enables 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.

- 1 = SPRF CPU interrupt requests or SPRF DMA service requests enabled
- 0 = SPRF CPU interrupt requests or SPRF DMA service requests disabled

#### DMAS —DMA select bit

This read/write bit has no effect on this version of the SPI. This bit always read as 0.

0 = SPRE DMA and SPTE DMA service requests disabled

#### SPMSTR — SPI master bit

This read/write bit selects master mode operation or slave mode operation.

- 1 = Master mode
- 0 = Slave mode

# Serial Peripheral Interface Module (SPI)

#### CPOL — Clock polarity bit

This read/write bit determines the logic state of the SPSCK pin between transmissions. (See **Figure 13-4** and **Figure 13-6**.) To transmit data between SPI modules, the SPI modules must have identical CPOL values.

#### CPHA — Clock phase bit

This read/write bit controls the timing relationship between the serial clock and SPI data. (See Figure 13-4 and Figure 13-6.) To transmit data between SPI modules, the SPI modules must have identical CPHA values. When CPHA = 0, the  $\overline{SS}$  pin of the slave SPI module must be set to logic 1 between bytes. (See Figure 13-12.)

#### SPWOM — SPI wired-OR mode bit

This read/write bit disables the pullup devices on pins SPSCK, MOSI, and MISO pins 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

This read/write bit enables the SPI module. Clearing SPE causes a partial reset of the SPI. (See 13.10 Resetting the SPI.)

- 1 = SPI module enabled
- 0 = SPI module disabled

#### SPTIE— SPI transmit interrupt enable

This read/write bit enables interrupt requests generated by the SPTE bit. SPTE is set when a byte transfers from the transmit data register to the shift register.

- 1 = SPTE interrupt requests enabled
- 0 = SPTE interrupt requests disabled

Serial Peripheral Interface Module (SPI)
I/O Registers

#### 13.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 \$\overline{SS}\$ 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



Figure 13-14. SPI Status and Control Register (SPSCR)

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 an interrupt request if the SPRIE bit in the SPI control register is set also.

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

MC68HC(9)08LJ60 — Rev. 1.0

Advance Information

# Serial Peripheral Interface Module (SPI)

#### ERRIE — Error interrupt enable bit

This read/write bit enables the MODF and OVRF bits 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 full 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 receive data register.

- 1 = Overflow
- 0 = No overflow

#### MODF — Mode fault bit

This clearable, read-only flag is set in a slave SPI if the  $\overline{SS}$  pin goes high during a transmission with the MODFEN bit set. In a master SPI, the MODF flag is set if the  $\overline{SS}$  pin goes low at any time with the MODFEN bit set. Clear the MODF bit by reading the SPI status and control register (SPSCR) with MODF set and then writing to the SPI control register (SPCR).

- $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 interrupt request if the SPTIE bit in the SPI control register is set also.

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

**NOTE:** Do not write to the SPI data register unless the SPTE bit is high.

Serial Peripheral Interface Module (SPI)
I/O Registers

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 MODFEN bit is low, the level of the  $\overline{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 13.8.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 13-3**. SPR1 and SPR0 have no effect in slave mode. Reset clears SPR1 and SPR0.

Use this formula to calculate the SPI baud rate:

Baud rate = 
$$\frac{CGMOUT}{2 \times BD}$$

CGMOUT = base clock output of the clock generator module (CGM) BD = baud rate divisor

Table 13-3. SPI Master Baud Rate Selection

| SPR1 and SPR0 | Baud rate divisor (BD) |
|---------------|------------------------|
| 00            | 2                      |
| 01            | 8                      |
| 10            | 32                     |
| 11            | 128                    |

# Serial Peripheral Interface Module (SPI)

Reset:

### 13.14.3 SPI Data Register

The SPI data register consists of the read-only receive data register and the write-only 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 registers that can contain different values. (See Figure 13-2.)

| Address: | \$000F |    |    |    |    |    |    |       |
|----------|--------|----|----|----|----|----|----|-------|
|          | Bit 7  | 6  | 5  | 4  | 3  | 2  | 1  | Bit 0 |
| Read:    | R7     | R6 | R5 | R4 | R3 | R2 | R1 | R0    |
| Write:   | T7     | T6 | T5 | T4 | T3 | T2 | T1 | T0    |

Indeterminate after reset

Figure 13-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 register read is not the same as the register written.

# Advance Information — MC68HC(9)08LJ60

# Section 14. Alert Output Generator (ALR)

#### 14.1 Contents

| 14.2   | Introduction                 | 245 |
|--------|------------------------------|-----|
| 14.3   | Features                     | 245 |
| 14.4   | Functional Description       | 245 |
| 14.4.1 | Alert Control Register       | 247 |
| 14.4.2 | Sound Pressure Level Circuit | 247 |
| 14.4.3 | Alert Data Register          | 248 |

#### 14.2 Introduction

This section describes the alert output generaor (ALR), which provides 14 software selectable square wave output frequencies.

#### 14.3 Features

Features of the ALR module include:

- 14 software selectable audio alert tone outputs
- 4-bit software selectable sound pressure level control

# 14.4 Functional Description

This system will be used to generate alert tones as the output signal ALERT. The audio alert tone generator is controlled by the four control bits as shown in **Table 14-1**. This allows 14 possible frequencies to drive the alert output. The zero state acts as an off mode and places the output in a high-impedance mode and an on mode places the output in ground state.

MC68HC(9)08LJ60 - Rev. 1.0

Advance Information

# **Alert Output Generator (ALR)**

**NOTE:** 

The alert module is enabled only when the on-chip phase locked loop (PLL) is engaged. During wait mode, the ALCR register should be programmed with value \$00 to ensure a three-state output and eliminate any residual output from the audio frequency generator.

**Table 14-1. Audio Alert Tone Generator Divider Ratios** 

| A12 A10 | Audio alert generator frequencies at given fosc |                 |                 |                 |  |  |
|---------|-------------------------------------------------|-----------------|-----------------|-----------------|--|--|
| AL3-AL0 | fosc                                            | 32.768 kHz      | 32.000 kHz      | 38.4 kHz        |  |  |
| 0000    | OFF                                             | Hi-Z            | Hi-Z            | Hi-Z            |  |  |
| 0001    | f <sub>OSC</sub> ÷ 32                           | 1024            | 10001           | 1200            |  |  |
| 0010    | f <sub>OSC</sub> ÷ 8                            | 4096            | 4000            | 4800            |  |  |
| 0011    | f <sub>OSC</sub> ÷ 16                           | 2048            | 2000            | 2400            |  |  |
| 0100    | f <sub>OSC</sub> ÷ 6                            | 5461            | 5333            | 6400            |  |  |
| 0101    | f <sub>OSC</sub> ÷ 12                           | 2730            | 2666            | 3200            |  |  |
| 0110    | f <sub>OSC</sub> ÷ 24                           | 1365            | 1333            | 1600            |  |  |
| 0111    | f <sub>OSC</sub> ÷ 48                           | 683             | 667             | 800             |  |  |
| 1000    | f <sub>OSC</sub> ÷ 10                           | 3276            | 3200            | 3840            |  |  |
| 1001    | f <sub>OSC</sub> ÷ 20                           | 1638            | 1600            | 1920            |  |  |
| 1010    | f <sub>OSC</sub> ÷ 40                           | 819             | 800             | 960             |  |  |
| 1011    | f <sub>OSC</sub> ÷ 80                           | 410             | 400             | 480             |  |  |
| 1100    | f <sub>OSC</sub> ÷ 14                           | 2341            | 2285            | 2743            |  |  |
| 1101    | f <sub>OSC</sub> ÷ 28                           | 1170            | 1143            | 1371            |  |  |
| 1110    | f <sub>OSC</sub> ÷ 56                           | 585             | 571             | 686             |  |  |
| 1111    | OFF                                             | V <sub>SS</sub> | V <sub>SS</sub> | V <sub>SS</sub> |  |  |

Alert Output Generator (ALR)
Functional Description

#### 14.4.1 Alert Control Register

The alert control register (ALCR) bits are in Figure 14-1.



Figure 14-1. Alert Control Register (ALCR)

#### AL3-AL0 — Alert frequency select

The value of these bits determines the frequency of the alert output (see Table 14-1). If these bits are set to all 0s, the ALERT output will be high impedance (OFF). If set to all 1s, the ALERT output will be at  $V_{SS}$  (logic 0).

Reset clears these bits, turning this output off to the high-impedance state.

#### 14.4.2 Sound Pressure Level Circuit

The sound pressure level (SPL) control register is used to control the volume of the alert transducer. A high-frequency clock signal is used to modulate the normal alert output frequency. This modulation reduces the amplitude of the frequency components in the audible range while adding new frequencies outside the audible range.

This feature causes a significant reduction in the SPL of the transducer. A broad range of volume control is obtained by altering the duty cycle of the high frequency modulation signal. The SPL control register is software programmable to allow users to select different frequencies with different duty cycles.

# **Alert Output Generator (ALR)**

#### 14.4.3 Alert Data Register

The alert data register (ALDR) bits are:



Figure 14-2. Alert Data Register (ALDR)

#### SPL7

This bit selects between 16-phase duty cycle modulation if bit SPL7 = 0 and 8-phase duty cycle modulation if bit SPL7 = 1.

#### SPL6

This bit selects between the output (DCMOD) of the duty cycle modulator when SPL6 = 0 and the clock FMODHI when SPL6 = 1 to send to the output SPLCLK to modulate the alert output. (See Figure 14-3.)

#### SPL5 and SPL4

These bits are used to control the frequency divider selections (divided by 1, 2, and 4) and, along with bit SPL6 in one case where both SPL4 and SPL5 are high, to select between a CPU clock divided by 8 and the crystal clock. (See **Table 14-2**.)

Table 14-2. Clock Divider and Modulator Selections

| SPL6 | SPL5 | SPL4 | FMODHI | SPLCLK |
|------|------|------|--------|--------|
| 0    | 0    | 0    | IT12/1 | DCMOD  |
| 0    | 0    | 01   | IT12/2 | DCMOD  |
| 0    | 1    | 0    | IT12/4 | DCMOD  |
| 0    | 1    | 1    | IT12/8 | DCMOD  |
| 1    | 0    | 0    | IT12/1 | FMODHI |

Advance Information

MC68HC(9)08LJ60 — Rev. 1.0

Alert Output Generator (ALR)
Functional Description

**Table 14-2. Clock Divider and Modulator Selections (Continued)** 

| SPL6 | SPL5 | SPL4 | FMODHI  | SPLCLK |
|------|------|------|---------|--------|
| 1    | 0    | 1    | IT12/2  | FMODHI |
| 1    | 1    | 0    | IT12/4  | FMODHI |
| 1    | 1    | 1    | CGMXCLK | FMODHI |

#### SPL3-SPL0

These bits control the duty cycle of the modulation signal, as shown in **Table 14-3**.

**Table 14-3. Duty Cycle Selection** 

| SPL3 | SPL2 | SPL1 | SPL0 | Duty cycle<br>8-phase count<br>(SPL7 = 1) | Duty cycle<br>16-phase count<br>(SPL7 = 0) |
|------|------|------|------|-------------------------------------------|--------------------------------------------|
| 0    | 0    | 0    | 0    | SPL disabled                              | SPL disabled                               |
| 0    | 0    | 0    | 1    | 1/8 high 7/8 low                          | 1/16 high 15/16 low                        |
| 0    | 0    | 1    | 0    | 2/8 high 6/8 low                          | 2/16 high 14/16 low                        |
| 0    | 0    | 1    | 1    | 3/8 high 5/8 low                          | 3/16 high 13/16 low                        |
| 0    | 1    | 0    | 0    | 4/8 high 4.8 low                          | 4/16 high 12/16 low                        |
| 0    | 1    | 0    | 1    | 5/8 high 3/8 low                          | 5/16 high 11/16 low                        |
| 0    | 1    | 1    | 0    | 6/8 high 2/8 low                          | 6/16 high 10/16 low                        |
| 0    | 1    | 1    | 1    | 7/8 high 1/8 low                          | 7/16 high 9/16 low                         |
| 1    | 0    | 0    | 0    | spl disabled                              | 8/16 high 8/16 low                         |
| 1    | 0    | 0    | 1    | 1/8 high 7/8 low                          | 9/16 high 7/16 low                         |
| 1    | 0    | 1    | 0    | 2/8 high 6/8 low                          | 10/16 high 6/16 low                        |
| 1    | 0    | 1    | 1    | 3/8 high 5/8 low                          | 11/16 high 5/16 low                        |
| 1    | 1    | 0    | 0    | 4/8 high 4.8 low                          | 12/16 high 4/16 low                        |
| 1    | 1    | 0    | 1    | 5/8 high 3/8 low                          | 13/16 high 3/16 low                        |
| 1    | 1    | 1    | 0    | 6/8 high 2/8 low                          | 14/16 high 2/16 low                        |
| 1    | 1    | 1    | 1    | 7/8 high 1/8 low                          | 15/16 high 1/16 low                        |

MC68HC(9)08LJ60 — Rev. 1.0

**Advance Information** 

# Alert Output Generator (ALR)



Figure 14-3. Block Diagram of SPL Reduction Circuit

# Advance Information — MC68HC(9)08LJ60

# Section 15. Liquid Crystal Display Module (LCD)

#### 15.1 Contents

| 15.2   | Introduction                                                                 | 25′ |
|--------|------------------------------------------------------------------------------|-----|
| 15.3   | Features                                                                     | 251 |
| 15.4   | Functional Description                                                       | 252 |
| 15.5   | LCD Registers                                                                | 253 |
| 15.5.1 | LCD Control Register                                                         | 253 |
| 15.5.2 | LCD Address Register                                                         | 254 |
| 15.5.3 | LCD Data Register                                                            | 256 |
| 15.6   | Anti-Ghosting                                                                | 260 |
| 15.7   | Software Examples                                                            | 261 |
| 15.8   | Power Supply Pins (V <sub>LL</sub> , V <sub>LL12</sub> , V <sub>LL32</sub> , |     |
|        | and V <sub>CP1</sub> –V <sub>CP4</sub> )                                     | 262 |

#### 15.2 Introduction

The liquid crystal display (LCD) module provides software control for eight backplanes and either 10 or 85 frontplanes.

#### 15.3 Features

Features of the LCD module include:

- Built-in voltage generator charge pump
- Software selectable three, five, or eight backplanes
- Software selectable 10 or 85 frontplanes
- Anti-ghosting capability

MC68HC(9)08LJ60 — Rev. 1.0

**Advance Information** 

# Liquid Crystal Display Module (LCD)

# 15.4 Functional Description

This LCD driver circuit has a maximum of eight backplanes (BP) and 85 frontplanes (FP). The output waveform has a maximum output level of  $3/2 \text{ V}_{LL}$  and is configured with 1/3 bias. The output voltage levels are  $\text{V}_{SS}$ ,  $1/2 \text{ V}_{LL}$ ,  $\text{V}_{LL}$ , and  $3/2 \text{ V}_{LL}$  ( $\text{V}_{LL}$  – LCD power supply). The bias voltage levels are generated internally from the external inputs  $\text{V}_{LL}$ ,  $\text{V}_{CP1}$ – $\text{V}_{CP4}$ ,  $\text{V}_{LL12}$ , and  $\text{V}_{LL32}$ . For more information on using the LCD voltage converter, see the functional pin description in 15.8 Power Supply Pins (VLL, VLL12, VLL32, and VCP1–VCP4).



Figure 15-1. LCD Driver Block Diagram

Liquid Crystal Display Module (LCD)
LCD Registers

# 15.5 LCD Registers

The LCD driver outputs are manipulated through software control of the LCD control register, the LCD address register, and the LCD data register. Data is written to each of the 85 frontplanes by writing the FP number to the LCD address register and then writing the data to the LCD data register.

#### 15.5.1 LCD Control Register

The LCD control register (LCDCR) is a read/write register containing the control bits to configure the LCD drivers.



Figure 15-2. LCD Control Register (LCDCR)

#### DUTY1 and DUTY0 — Duty cycle select bits

These bits enable all FP outputs and select the duty of the LCD driver, enabling the specified number of BP outputs. Reset clears these bits, disabling LCD waveforms at the outputs. When disabled, an LCD output will be held at  $V_{SS}$ . Table 15-1 shows the duty cycle selected and the corresponding number of backplanes, as well as the frame rate for the chosen duty cycle.

**Table 15-1. Duty Cycle Select** 

| DUTY1-<br>DUTY0 | DUTY | Number of backplanes | Frame rate f <sub>OSC</sub> = 32.000 kHz | Frame rate f <sub>OSC</sub> = 38.4 kHz |  |
|-----------------|------|----------------------|------------------------------------------|----------------------------------------|--|
| 00              | OFF  | OFF                  | OFF                                      | OFF                                    |  |
| 01              | 1/3  | 3                    | 27.8 Hz                                  | 33.3 Hz                                |  |
| 10              | 1/5  | 5                    | 25.0 Hz                                  | 30.0 Hz                                |  |
| 11              | 1/8  | 8                    | 31.25 Hz                                 | 37.5 Hz                                |  |

MC68HC(9)08LJ60 — Rev. 1.0

# Liquid Crystal Display Module (LCD)

AGON — Anti-ghost on bit

This bit is used to turn the anti-ghosting feature on or off. When AGON = 1, the anti-ghosting feature is enabled. When AGON = 0, anti-ghosting is turned off. For additional information, see **15.6 Anti-Ghosting**. This bit is cleared by reset.

DSMIN — Display minimum bit

This bit is used to force the data of the lower 75 FP (FP0–FP74) to be 0. This mode is used to enable only part of the display to be on (for example, clock display) without having to rewrite the data on the rest of the display to 0.

MOTMD — Motorola (multiplex) mode

This bit can be used to convert the LCD outputs to accommodate multiplexed LCD driver ICs (integrated circuits) from Motorola (MC145000 and MC145001).

- 1 = Motorola (multiplex) mode enabled
- 0 = Standard (lower current consumption) mode enabled

#### 15.5.2 LCD Address Register

The LCD address register (LCDAR) is a read/write register used to access the data for each FP register.



Figure 15-3. LCD Address Register (LCDAR)

To access the FP registers, the LCD address is the frontplane pin number converted to hexadecimal. For this implementation of 85 frontplanes, bit 7 is always set to 0. (see **Table 15-2**.)

Advance Information

MC68HC(9)08LJ60 — Rev. 1.0

Liquid Crystal Display Module (LCD) LCD Registers

**Table 15-2. Frontplane Address Assignments** 

| Pin name | Address | Pin name | Address |
|----------|---------|----------|---------|
| FP0      | \$01    | FP45     | \$2E    |
| FP1      | \$02    | FP46     | \$2F    |
| FP2      | \$03    | FP47     | \$30    |
| FP3      | \$04    | FP48     | \$31    |
| FP4      | \$05    | FP49     | \$32    |
| FP5      | \$06    | FP50     | \$33    |
| FP6      | \$07    | FP51     | \$34    |
| FP7      | \$08    | FP52     | \$35    |
| FP8      | \$09    | FP53     | \$36    |
| FP9      | \$0A    | FP54     | \$37    |
| FP10     | \$0B    | FP55     | \$38    |
| FP11     | \$0C    | FP56     | \$39    |
| FP12     | \$0D    | FP57     | \$3A    |
| FP13     | \$0E    | FP58     | \$3B    |
| FP14     | \$0F    | FP59     | \$3C    |
| FP15     | \$10    | FP60     | \$3D    |
| FP16     | \$11    | FP61     | \$3E    |
| FP17     | \$12    | FP62     | \$3F    |
| FP18     | \$13    | FP63     | \$40    |
| FP19     | \$14    | FP64     | \$41    |
| FP20     | \$15    | FP65     | \$42    |
| FP22     | \$16    | FP66     | \$43    |
| FP23     | \$17    | FP67     | \$44    |
| FP24     | \$18    | FP68     | \$45    |
| FP25     | \$19    | FP69     | \$46    |
| FP25     | \$1A    | FP70     | \$47    |
| FP26     | \$1B    | FP71     | \$48    |
| FP27     | \$1C    | FP72     | \$49    |
| FP28     | \$1D    | FP73     | \$4A    |
| FP29     | \$1E    | FP74     | \$4B    |
| FP30     | \$1F    | FP75     | \$4C    |
| FP31     | \$20    | FP76     | \$4D    |
| FP32     | \$21    | FP77     | \$4E    |
| FP33     | \$22    | FP78     | \$4F    |
| FP34     | \$23    | FP79     | \$50    |
| FP35     | \$24    | FP80     | \$51    |
| FP36     | \$25    | FP81     | \$52    |
| FP37     | \$26    | FP82     | \$53    |
| FP38     | \$27    | FP83     | \$54    |
| FP39     | \$28    | FP84     | \$55    |
| FP40     | \$29    |          |         |
| FP41     | \$2A    |          |         |
| FP42     | \$2B    |          |         |
| FP43     | \$2C    |          |         |
| FP44     | \$2D    |          |         |

MC68HC(9)08LJ60 - Rev. 1.0

# Liquid Crystal Display Module (LCD)

#### 15.5.3 LCD Data Register

Each bit in the read/write LCD data register (LCDDR) is the data to be written out on to the FP pin, as specified in the LCD address register, in the appropriate BP time frame. The correct address must be written into the LCD address register before reading from or writing to the LCD data register. The data in this register is for all the segments controlled by the FP driver.

If the user has selected less than eight backplanes, the upper bits of this register will be unknown.



Figure 15-4. LCD Data Register (LCDDR)

**BPx** 

1 = FP output ON during BPx time frame

0 = FP output OFF during BPx time frame

For example, if the segment controlled by FP1 and BP4 is to be on, follow this sequence:

- 1. Write \$02 to the LCD address register
- 2. Write 1 to bit 4 of the LCD data register

Liquid Crystal Display Module (LCD) LCD Registers



Figure 15-5. LCD Backplane Waveforms — 3 BP

# **Liquid Crystal Display Module (LCD)**



Figure 15-6. LCD Backplane Waveforms — 5 BP

Liquid Crystal Display Module (LCD) LCD Registers



Figure 15-7. LCD Backplane Waveforms — 8 BP

MC68HC(9)08LJ60 - Rev. 1.0

# Liquid Crystal Display Module (LCD)

# 15.6 Anti-Ghosting

The purpose of the anti-ghosting feature is to provide the user with the option to improve the LCD viewing angle at the expense of display contrast and increased power consumption. The level of improvement to the viewing angle as well as the amount of reduction in contrast depends entirely on the display used. The anti-ghosting is performed by taking all frontplane and backplane pins to  $V_{SS}$  potential for a short time (~16  $\mu$ s), while the internal muxing circuitry is transitioning. See **Figure 15-8** for waveforms detailing the anti-ghosting pulses.

**NOTE:** The anti-ghosting pulses are not shown in the previous figures. Operating  $I_{DD}$  current approximately doubles with the use of the anti-ghosting function.



Figure 15-8. LCD Backplane Waveforms with Anti-Ghosting — 3 BP

Advance Information

MC68HC(9)08LJ60 — Rev. 1.0

Liquid Crystal Display Module (LCD) Software Examples

# 15.7 Software Examples

This example shows a routine which loads the LCD data register with information for each frontplane.

```
LCD Register Definitions
lcdcr
                $1a
                             LCD Control Register
       equ
lcdar
       equ
                $1b
                            LCD Address Register
lcddr
       equ
                $1c
                            LCD Data Register
                $8000
       org
       Load data into correct data registers
       ldx
                #45
                             load correct number of data registers
datald stx
                lcdar
                             point to the desired data register
       lda
                             fetch data
                data-1,x
                lcddr
                             store data
       sta
       decx
                             point to next register
       bne
                datald
                             continue until all data registers full
       Turn on display
       ldx
                #$c0
       stx
                lcdcr
                             configure w/ 8 BPs
                             loop here; hold display
       bra
*Message Table - Displays " DISPLAY " in nine 5x7 dot matrix characters
*(0 = off, 1 = on)
     FFFFF
                FFFFF
                           F F F F F
                                     FFFFF
                                                FFFFF FFFF
     PPPPP PPPP
                           PPPP
                                     PPPP
                                                PPPP
                                                           PPPP
                6 7 8 9 1
                                                 2 2 2 2 2
      1 2 3 4 5
                           1 1 1 1 1
                                      1 1 1 1 2
                                                           2 2 2 2 3
                           1 2 3 4 5
                                     6 7 8 9 0
                                                1 2 3 4 5
                                                           6 7 8 9 0
                1 1 1 0 0
                           0 1 1 1 0
 BP0 0 0 0 0 0
                                      0 1 1 1 1
                                                1 1 1 1 0
                                                           1 0 0 0 0
                                      1 0 0 0 0
* BP1 0 0 0 0 0
                1 0 0 1 0
                           0 0 1 0 0
                                                1 0 0 0 1
                                                           1 0 0 0 0
 BP2 0 0 0 0 0 1 0 0 0 1
                           0 0 1 0 0
                                     1 0 0 0 0
                                                1 0 0 0 1
                                                           1 0 0 0 0
* BP3 0 0 0 0 0 1 0 0 0 1
                           0 0 1 0 0
                                      0 1 1 1 0
                                                1 1 1 1 0
                                                           1 0 0 0 0
* BP4 0 0 0 0 0 1 0 0 0 1
                           0 0 1 0 0
                                      0 0 0 0 1
                                                1 0 0 0 0
                                                           1 0 0 0 0
* BP5 0 0 0 0 0 1 0 0 1 0
                           0 0 1 0 0
                                      0 0 0 0 1
                                                1 0 0 0 0
                                                           1 0 0 0 0
                                                1 0 0 0 0
* BP6 0 0 0 0 0 1 1 1 0 0 0 1 1 1 0
                                     1 1 1 1 0
                                                           1 1 1 1 1
```

MC68HC(9)08LJ60 — Rev. 1.0

# Liquid Crystal Display Module (LCD)

| data<br>** ** | equ | *                        |
|---------------|-----|--------------------------|
| **D**         | fcb | \$00,\$00,\$00,\$00,\$00 |
| _             | fcb | \$7f,\$41,\$41,\$22,\$1c |
| **I**         | fcb | \$00,\$41,\$7f,\$41,\$00 |
| **S**         | fcb | \$46,\$49,\$49,\$49,\$31 |
| **P**         | fcb | \$7f,\$09,\$09,\$09,\$06 |
| **L**         | fcb | \$7f,\$40,\$40,\$40,\$40 |
| **A**         |     |                          |
| **Y**         | fcb | \$7e,\$11,\$11,\$11,\$7e |
| ** **         | fcb | \$07,\$08,\$70,\$08,\$07 |
|               | fcb | \$00,\$00,\$00,\$00,\$00 |

# 15.8 Power Supply Pins (V<sub>LL</sub>, V<sub>LL12</sub>, V<sub>LL32</sub>, and V<sub>CP1</sub>–V<sub>CP4</sub>)

These are power supply pins for the LCD voltage converter. When using the internal LCD voltage converter, the pins should be connected as shown in **Figure 15-9**.



Figure 15-9. LCD Voltage Converter Connections

If an external voltage supply is used to power the LCD module, the appropriate voltages should be applied to the V<sub>LL</sub>, V<sub>LL12</sub> ( $^{1}$ /<sub>2</sub> V<sub>LL</sub>) and V<sub>LL32</sub> ( $^{3}$ /<sub>2</sub> V<sub>LL</sub>) pins. V<sub>CP1</sub>–V<sub>CP4</sub> should be left floating.

Advance Information

MC68HC(9)08LJ60 — Rev. 1.0

# Advance Information — MC68HC(9)08LJ60

# Section 16. Timer Interface Module (TIM)

# 16.1 Contents

| 16.2 Introduction                                 | 264 |
|---------------------------------------------------|-----|
| 16.3 Features                                     | 264 |
| 16.4 Functional Description                       | 268 |
| 16.4.1 Timer Counter Prescaler                    |     |
| 16.4.2 Input Capture                              | 268 |
| 16.4.3 Output Compare                             |     |
| 16.4.3.1 Unbuffered Output Compare                |     |
| 16.4.3.2 Buffered Output Compare                  |     |
| 16.4.4 Pulse Width Modulation (PWM)               |     |
| 16.4.4.1 Unbuffered PWM Signal Generation         |     |
| 16.4.4.2 Buffered PWM Signal Generation           |     |
| 16.4.4.3 PWM Initialization                       | 274 |
| 16.5 Interrupts                                   | 275 |
| 16.6 Low-Power Modes                              | 276 |
| 16.6.1 Wait Mode                                  | 276 |
| 16.6.2 Stop Mode                                  | 276 |
| 16.7 TIM During Break Interrupts                  | 276 |
| 16.8 I/O Signals                                  | 277 |
| 16.8.1 TIM Clock Pin (TCLK)                       | 277 |
| 16.8.2 Timer Channel I/O Pins (TCH0–TCH3)         | 277 |
| 16.9 I/O Registers                                | 278 |
| 16.9.1 Timer Status and Control Register          | 278 |
| 16.9.2 Timer Counter Registers                    | 281 |
| 16.9.3 Timer Modulo Registers                     |     |
| 16.9.4 Timer Channel Status and Control Registers | 283 |
| 16.9.5 Timer Channel Registers                    | 288 |
|                                                   |     |

MC68HC(9)08LJ60 - Rev. 1.0

#### 16.2 Introduction

This section describes the timer interface module (TIM). The TIM is a 4-channel timer that provides a timing reference with input capture, output compare, and pulse-width-modulation functions. **Figure 16-1** is a block diagram of the TIM.

#### **NOTE:**

References to DMA and associated functions are only valid if the MCU has a DMA module. This MCU does not have the DMA function. Any DMA-related register bits should be left in their reset state for normal MCU operation.

#### 16.3 Features

Features of the TIM include:

- Modular architecture
- Four input capture/output compare channels:

Freescale Semiconductor, Inc.

- 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 TIM clock input
  - Seven-frequency internal bus clock prescaler selection
  - External TIM clock input (4-MHz maximum frequency)
- Free-running or modulo up-count operation
- Toggle any channel pin on overflow
- Timer counter stop and reset bit

#### **NOTE:**

Because there are no input or output pins available for the timer module, the input capture functions are disabled. However, for the output compare function, when the counter reaches the value in the selected channel register, the timer can generate an interrupt to CPU. But it can't set, clear, or toggle the timer compare pin. Ignore all references to TCHx pins. See 16.5 Interrupts for more information.

#### **NOTE:**

The shaded boxes in **Figure 16-1** are not implemented in this module. All references to these blocks should be ignored. TCLK is a floating pin. Do not set the PS2–PS0 bits in the TIM status and control register to select TCLK input.

Advance Information

MC68HC(9)08LJ60 — Rev. 1.0

Semiconductor, Inc.

# Freescale Semiconductor, Inc.

Timer Interface Module (TIM) Features



Figure 16-1. TIM Block Diagram

MC68HC(9)08LJ60 - Rev. 1.0

# Timer Interface Module (TIM)

| Addr                               | Register Name                                       |          | Bit 7  | 6        | 5             | 4      | 3      | 2      | 1      | Bit 0  |
|------------------------------------|-----------------------------------------------------|----------|--------|----------|---------------|--------|--------|--------|--------|--------|
|                                    |                                                     | Read: To | TOF    | TOIE     | TSTOP         | 0      | 0      | PS2    | PS1    | PS0    |
| \$0020 TIM Status and Control Regi |                                                     | Write:   | 0      | 0        |               | TRST   |        | P32    | P31    | P30    |
|                                    | ,                                                   | Reset:   | 0      | 0        | 0             | 0      | 0      | 0      | 0      | 0      |
| \$0021                             | Unimplemented                                       |          |        |          |               |        |        |        |        |        |
|                                    |                                                     | ا ۔      | D!: 45 | Bu 44    | B!! 40        | B!! 40 | D!: 44 | DII 40 | DII 0  | Du o   |
|                                    | TIM Counter Register High                           | Read:    | Bit 15 | Bit 14   | Bit 13        | Bit 12 | Bit 11 | Bit 10 | Bit 9  | Bit 8  |
| \$0022                             | (TCNTH)                                             | Write:   |        |          |               |        |        |        |        |        |
|                                    |                                                     | Reset:   | 0      | 0        | 0             | 0      | 0      | 0      | 0      | 0      |
|                                    | TIM 0                                               | Read:    | Bit 7  | Bit 6    | Bit 5         | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  |
| \$0023                             | TIM Counter Register Low<br>(TCNTL)                 | Write:   |        |          |               |        |        |        |        |        |
|                                    | , , ,                                               | Reset:   | 0      | 0        | 0             | 0      | 0      | 0      | 0      | 0      |
|                                    |                                                     | Read:    | Duar   | Diad     | Bit 13        | Bit 12 | Bit 11 | Bit 10 | Bit 9  | D# 0   |
| \$0024 TIM Counter Mod             | TIM Counter Modulo Register High (TMODH)            | Write:   | Bit 15 | Bit 14   |               |        |        |        |        | Bit 8  |
|                                    | (TWODIT)                                            | Reset:   | 0      | 0        | 0             | 0      | 0      | 0      | 0      | 0      |
|                                    |                                                     | Read:    |        |          |               |        |        |        |        |        |
| \$0025                             | TIM Counter Modulo Register Low (TMODL)             | Write:   | Bit 7  | Bit 6    | Bit 5         | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  |
|                                    | , ,                                                 | Reset:   | 0      | 0        | 0             | 0      | 0      | 0      | 0      | 0      |
|                                    |                                                     | Read:    | CH0F   | CHOIF    | MS0B          | MS0A   | ELS0B  | EL COA | TO) (0 | CHOMAN |
| \$0026                             | TIM Channel 0 Status and Control<br>Register (TSC0) | Write:   | 0      | CH0IE    |               |        |        | ELS0A  | TOV0   | CH0MAX |
|                                    | • , ,                                               | Reset:   | 0      | 0        | 0             | 0      | 0      | 0      | 0      | 0      |
|                                    |                                                     | Read:    | DI: 45 | DI 44    | DII 40        | DI: 40 | DI: 44 | DI: 40 | DU 0   | Bit 8  |
| \$0027                             | TIM Channel 0 Register High<br>(TCH0H)              | Write:   | Bit 15 | Bit 14   | Bit 13        | Bit 12 | Bit 11 | Bit 10 | Bit 9  |        |
|                                    |                                                     | Reset:   | 0      | 0        | 0             | 0      | 0      | 0      | 0      | 0      |
|                                    |                                                     | Read:    | D# 7   |          | <b>-</b> 10 - |        |        | Date   | D:: 4  | Dit 0  |
| \$0028                             | TIM Channel 0 Register Low (TCH0L)                  | Write:   | Bit 7  | Bit 6    | Bit 5         | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  |
|                                    |                                                     | Reset:   | 0      | 0        | 0             | 0      | 0      | 0      | 0      | 0      |
|                                    |                                                     |          |        | = Unimpl | emented       |        |        |        |        |        |

Figure 16-2. TIM I/O Register Summary

**Advance Information** 

MC68HC(9)08LJ60 — Rev. 1.0

Timer Interface Module (TIM) Features

| Addr    | Register Name                                       |        | Bit 7  | 6        | 5       | 4      | 3      | 2       | 1     | Bit 0  |
|---------|-----------------------------------------------------|--------|--------|----------|---------|--------|--------|---------|-------|--------|
|         |                                                     | Read:  | CH1F   | CUITE    | 0       | MC1A   | EL CAD | E1 04 A | TOV4  | CHAMAN |
| \$0029  | TIM Channel 1 Status and Control<br>Register (TSC1) | Write: | 0      | CH1IE    |         | MS1A   | ELS1B  | ELS1A   | TOV1  | CH1MAX |
|         | regisier (1301)                                     |        | 0      | 0        | 0       | 0      | 0      | 0       | 0     | 0      |
|         |                                                     | Read:  | D# 15  | D# 14    | D# 10   | D'I 10 | DI: 44 | B!! 40  | D'I O | D# 0   |
| \$002A  | TIM Channel 1 Register High<br>(TCH1H)              | Write: | Bit 15 | Bit 14   | Bit 13  | Bit 12 | Bit 11 | Bit 10  | Bit 9 | Bit 8  |
|         |                                                     | Reset: | 0      | 0        | 0       | 0      | 0      | 0       | 0     | 0      |
|         |                                                     | Read:  | D# 7   | Bit 6    | Bit 5   | Bit 4  | D# 2   | D# 2    | Bit 1 | Bit 0  |
| \$002B  | TIM Channel 1 Register Low<br>(TCH1L)               | Write: | Bit 7  |          |         |        | Bit 3  | Bit 2   |       |        |
|         | ,                                                   | Reset: | 0      | 0        | 0       | 0      | 0      | 0       | 0     | 0      |
|         |                                                     | Read:  | CH2F   | CH2IE    | MS2B    | MS2A   | ELS2B  | ELS2A   | TOV2  | CH2MAX |
| \$002C  | TIM Channel 2 Status and Control<br>Register (TSC2) | Write: | 0      |          |         |        |        |         |       |        |
|         | <b>,</b>                                            | Reset: | 0      | 0        | 0       | 0      | 0      | 0       | 0     | 0      |
|         |                                                     | Read:  | Bit 15 | Bit 14   | Bit 13  | Bit 12 | Bit 11 | Bit 10  | Bit 9 | Bit 8  |
|         | TIM Channel 2 Register High<br>(TCH2H)              | Write: | DIL 13 | DIC 14   | Dit 10  | DIC 12 | Dit 11 | Dit 10  | Dit 7 | Dit 0  |
|         | ,                                                   | Reset: | 0      | 0        | 0       | 0      | 0      | 0       | 0     | 0      |
|         |                                                     | Read:  | Bit 7  | Bit 6    | Bit 5   | Bit 4  | Bit 3  | Bit 2   | Bit 1 | Bit 0  |
| \$002E  | TIM Channel 2 Register Low<br>(TCH2L)               | Write: | DIL 7  | DIL 0    | טונ ט   | DIL 4  | DIL 3  | Dit 2   | DILI  | Dit 0  |
|         |                                                     | Reset: | 0      | 0        | 0       | 0      | 0      | 0       | 0     | 0      |
|         |                                                     | Read:  | CH3F   | CH3IE    | 0       | MS3A   | ELS3B  | ELS3A   | TOV3  | CH3MAX |
| \$002F  | TIM Channel 3 Status and Control<br>Register (TSC3) | Write: | 0      | CIBIL    |         | IVISSA | LLJJD  | LLJJA   | 1003  | CHOWAX |
|         | •                                                   | Reset: | 0      | 0        | 0       | 0      | 0      | 0       | 0     | 0      |
|         | TW 01 10 D 11 111 1                                 | Read:  | Bit 15 | Bit 14   | Bit 13  | Bit 12 | Bit 11 | Bit 10  | Bit 9 | Bit 8  |
| \$0030  | TIM Channel 3 Register High<br>(TCH3H)              | Write: | DIC 13 | DIC 14   | Dit 13  | Dit 12 | Dit 11 | Dit 10  | Dit 7 | Dit 0  |
| ·       |                                                     | Reset: | 0      | 0        | 0       | 0      | 0      | 0       | 0     | 0      |
| TIL . 0 | TIM Channel 2 Decistor I                            | Read:  | Bit 7  | Bit 6    | Bit 5   | Bit 4  | Bit 3  | Bit 2   | Bit 1 | Bit 0  |
| \$0031  | TIM Channel 3 Register Low (TCH3L)                  | Write: | Dit 1  | 50       | 5.0     | J.( )  | 5.0    | Dit 2   | D.( ) | 5 0    |
|         |                                                     | Reset: | 0      | 0        | 0       | 0      | 0      | 0       | 0     | 0      |
|         |                                                     |        |        | = Unimpl | emented |        |        |         |       |        |

Figure 16-2. TIM I/O Register Summary (Continued)

MC68HC(9)08LJ60 - Rev. 1.0

# Timer Interface Module (TIM)

# 16.4 Functional Description

Figure 16-1 shows the structure of the TIM. The central component of the TIM is the 16-bit timer counter that can operate as a free-running counter or a modulo up-counter. The timer counter provides the timing reference for the input capture and output compare functions. The timer counter modulo registers, TMODH and TMODL, control the modulo value of the timer counter. Software can read the timer counter value at any time without affecting the counting sequence.

The four TIM channels are programmable independently as input capture or output compare channels.

#### 16.4.1 Timer Counter Prescaler

The TIM clock source can be one of the seven prescaler outputs or the TIM clock pin, TCLK. The prescaler generates seven clock rates from the internal bus clock. The prescaler select bits, PS2–PS0, in the timer status and control register select the TIM clock source.

**NOTE:** This device does not have a TCLK pin.

#### 16.4.2 Input Capture

With the input capture function, the TIM can capture the time at which an external event occurs. When an active edge occurs on the pin of an input capture channel, the TIM latches the contents of the timer counter into the timer channel registers, TCHxH and TCHxL. The polarity of the active edge is programmable. Input capture latency can be up to three bus clock cycles. Input captures can generate TIM CPU interrupt requests.

**NOTE:** This device does not have input capture functionality.

Timer Interface Module (TIM)
Functional Description

#### 16.4.3 Output Compare

With the output compare function, the TIM 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 TIM can set, clear, or toggle the channel pin. Output compares can generate TIM CPU interrupt requests or TIM DMA service requests.

**NOTE:** This device does not have output compare pins.

#### 16.4.3.1 Unbuffered Output Compare

Any output compare channel can generate unbuffered output compare pulses as described in **16.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 timer channel registers.

An unsynchronized write to the timer 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 timer overflow interrupt routine to write a new, smaller output compare value may cause the compare to be missed. The timer 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 timer overflow interrupts and write the new value in the timer
  overflow interrupt routine. The timer overflow interrupt occurs at
  the end of the current counter overflow period. Writing a larger

MC68HC(9)08LJ60 — Rev. 1.0

# Timer Interface Module (TIM)

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.

#### 16.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 TCH0 pin. The timer channel registers of the linked pair alternately control the output.

Setting the MS0B bit in timer channel 0 status and control register (TSC0) links channel 0 and channel 1. The output compare value in the timer channel 0 registers initially controls the output on the TCH0 pin. Writing to the timer channel 1 registers enables the timer channel 1 registers to synchronously control the output after the timer overflows. At each subsequent overflow, the timer 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 timer channel 1 status and control register (TSC1) is unused. While the MS0B bit is set, the channel 1 pin, TCH1, is available as a general-purpose I/O pin.

Channels 2 and 3 can be linked to form a buffered output compare channel whose output appears on the TCH2 pin. The timer channel registers of the linked pair alternately control the output.

Setting the MS2B bit in timer channel 2 status and control register (TSC2) links channel 2 and channel 3. The output compare value in the timer channel 2 registers initially controls the output on the TCH2 pin. Writing to the timer channel 3 registers enables the timer channel 3 registers to synchronously control the output after the timer overflows. At each subsequent overflow, the timer channel registers (2 or 3) that control the output are the ones written to last. TSC2 controls and monitors the buffered output compare function, and timer channel 3 status and control register (TSC3) is unused. 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.

Timer Interface Module (TIM)
Functional Description

#### 16.4.4 Pulse Width Modulation (PWM)

By using the toggle-on-overflow feature with an output compare channel, the TIM can generate a PWM signal. The value in the timer counter modulo registers determines the period of the PWM signal. The channel pin toggles when the counter reaches the value in the timer counter modulo registers. The time between overflows is the period of the PWM signal.

As **Figure 16-3** shows, the output compare value in the timer channel registers determines the pulse width of the PWM signal. The time between overflow and output compare is the pulse width. Program the TIM to clear the channel pin on output compare if the state of the PWM pulse is logic 1. Program the TIM to set the pin if the state of the PWM pulse is logic 0.



Figure 16-3. PWM Period and Pulse Width

The value in the timer counter modulo registers and the selected prescaler output determine the frequency of the PWM output. The frequency of an 8-bit PWM signal is variable in 256 increments. Writing \$00FF (255) to the timer counter modulo registers produces a PWM period of 256 times the internal bus clock period.

# The value in the timer 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 timer channel registers produces a duty cycle of 128/256 or 50%.

**NOTE:** This device does not have channel pins for PWM.

Freescale Semiconductor, Inc.

# 16.4.4.1 Unbuffered PWM Signal Generation

Any output compare channel can generate unbuffered PWM pulses as described in **16.4.4 Pulse Width Modulation (PWM)**. The pulses are unbuffered because changing the pulse width requires writing the new pulse width value over the old value currently in the timer channel registers.

An unsynchronized write to the timer 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 timer overflow interrupt routine to write a new, smaller pulse width value may cause the compare to be missed. The timer may pass the new value before it is written.

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 timer overflow interrupts and write the new value in the timer overflow interrupt routine. The timer 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.

272

Timer Interface Module (TIM) **Functional Description** 

NOTE:

In PWM signal generation, do not program the PWM channel to toggle on output compare. Toggling on output compare prevents reliable 0% duty cycle generation and removes the ability of the channel to selfcorrect 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.

#### 16.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 TCH0 pin. The timer channel registers of the linked pair alternately control the pulse width of the output.

Setting the MS0B bit in timer channel 0 status and control register (TSC0) links channel 0 and channel 1. The timer channel 0 registers initially control the pulse width on the TCH0 pin. Writing to the timer channel 1 registers enables the timer channel 1 registers to synchronously control the pulse width at the beginning of the next PWM period. At each subsequent overflow, the timer 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 timer channel 1 status and control register (TSC1) is unused. While the MS0B bit is set, the channel 1 pin, TCH1, is available as a general-purpose I/O pin if the timer pad is shared with I/O pad.

Channels 2 and 3 can be linked to form a buffered PWM channel whose output appears on the TCH2 pin. The timer channel registers of the linked pair alternately control the pulse width of the output.

Setting the MS2B bit in timer channel 2 status and control register (TSC2) links channel 2 and channel 3. The timer channel 2 registers initially control the pulse width on the TCH2 pin. Writing to the timer channel 3 registers enables the timer channel 3 registers to synchronously control the pulse width at the beginning of the next PWM period. At each subsequent overflow, the timer channel registers (2 or 3) that control the pulse width are the ones written to last. TSC2 controls and monitors the buffered PWM function, and timer channel 3 status and control register (TSC3) is unused.

MC68HC(9)08LJ60 — Rev. 1.0

# Timer Interface Module (TIM)

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

#### 16.4.4.3 PWM Initialization

To ensure correct operation when generating unbuffered or buffered PWM signals, use this initialization procedure:

- 1. In the timer status and control register (TSC):
  - a. Stop the timer counter by setting the timer stop bit, TSTOP.
  - b. Reset the timer counter by setting the timer reset bit, TRST.
- 2. In the timer counter modulo registers (TMODH and TMODL), write the value for the required PWM period.
- 3. In the timer channel x registers (TCHxH and TCHxL), write the value for the required pulse width.
- 4. In timer channel x status and control register (TSCx):
  - 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 16-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 and ELSxA. The output action on compare must force the output to the complement of the pulse width level. (See Table 16-2.)

NOTE:

In PWM signal generation, do not program the PWM channel to toggle on output compare. Toggling on output compare prevents reliable 0% 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 timer status control register (TSC), clear the timer stop bit, TSTOP.

Advance Information

MC68HC(9)08LJ60 — Rev. 1.0

Timer Interface Module (TIM)
Interrupts

Setting MS0B links channels 0 and 1 and configures them for buffered PWM operation. The timer channel 0 registers (TCH0H and TCH0L) initially control the buffered PWM output. Timer status control register 0 (TSCR0) controls and monitors the PWM signal from the linked channels. MS0B takes priority over MS0A.

Setting MS2B links channels 2 and 3 and configures them for buffered PWM operation. The timer channel 2 registers (TCH2H and TCH2L) initially control the PWM output. Timer status control register 2 (TSCR2) controls and monitors the PWM signal from the linked channels. MS2B takes priority over MS2A.

Clearing the toggle on overflow bit, TOVx, inhibits output toggles on timer 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% duty cycle output.

Setting the CHxMAX bit generates a 100% duty cycle output. (See 16.9.4 Timer Channel Status and Control Registers.)

# 16.5 Interrupts

The TIM sources can generate these interrupt requests:

- TIM overflow flag (TOF) TOF is set when the TIM counter value matches the value in the TIM counter modulo registers. The TIM overflow interrupt enable bit, TOIE, enables the TOF flag to generate TIM overflow CPU interrupt requests. TOF and TOIE are in the TIM status and control register
- TIM channel flags (CH3F–CH0F) CHxF is set when an input capture or output compare occurs on channel x. The channel x interrupt enable bit, CHxIE, enables the CHxF flag to generate TIM channel x CPU interrupt requests. CHxF and CHxIE are in the TIM channel x status and control register

# Timer Interface Module (TIM)

#### 16.6 Low-Power Modes

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

#### 16.6.1 Wait Mode

The TIM remains active after the execution of a WAIT instruction. Any enabled CPU interrupt request from the TIM can bring the MCU out of wait mode. If the TIM is not required to bring the MCU out of wait mode, reduce power consumption by stopping the TIM before executing the WAIT instruction.

#### 16.6.2 Stop Mode

The TIM is inactive after the execution of a STOP instruction. The STOP instruction does not affect register conditions or the state of the timer counter. Timer operation resumes when the MCU exits stop mode after an external interrupt.

**NOTE:** This device does not function in stop mode.

# 16.7 TIM During Break Interrupts

A break interrupt stops the timer 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 9.5.1 Break Status and 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.

Advance Information

MC68HC(9)08LJ60 — Rev. 1.0

Timer Interface Module (TIM)
I/O Signals

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.

# 16.8 I/O Signals

TCLK is an external clock input to the timer prescaler. The four timer channel I/O pins are TCH0, TCH1, TCH2, and TCH3.

**NOTE:** This device does not have external timer pins.

#### 16.8.1 TIM Clock Pin (TCLK)

TCLK is an external clock input that can be the clock source for the timer counter instead of the prescaled internal bus clock. Select the TCLK input by writing logic 1s to the three prescaler select bits, PS2–PS0. (See 16.9.1 Timer Status and Control Register.) The minimum TCLK pulse width, TCLK<sub>LMIN</sub> or TCLK<sub>HMIN</sub>, is:

The maximum TCLK frequency is:

bus frequency ÷ 2

#### 16.8.2 Timer Channel I/O Pins (TCH0-TCH3)

Each channel I/O pin is programmable independently as an input capture pin or an output compare pin. TCH0 and TCH2 can be configured as buffered output compare or buffered PWM pins.

# Timer Interface Module (TIM)

# 16.9 I/O Registers

These I/O registers control and monitor operation of the TIM:

- Timer status and control register (TSC)
- Timer DMA select register (TDMA)
- Timer control registers (TCNTH and TCNTL)
- Timer counter modulo registers (TMODH and TMODL)
- Timer channel status and control registers (TSC0, TSC1, TSC2, and TSC3)
- Timer channel registers (TCH0H, TCH0L, TCH1H, TCH1L, TCH2H, TCH2L, TCH3H, and TCH3L)

#### 16.9.1 Timer Status and Control Register

The timer status and control register (TSC):

- Enables timer overflow interrupts
- Flags timer overflows
- Stops the timer counter
- Resets the timer counter and prescaler
- Prescales the timer counter clock



Figure 16-4. Timer Status and Control Register (TSC)

Timer Interface Module (TIM)
I/O Registers

#### TOF — Timer overflow flag bit

This read/write flag is set when the timer counter reaches the modulo value programmed in the timer counter modulo registers. Clear TOF by reading the timer status and control register when TOF is set and then writing a logic 0 to TOF. If another timer 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 = Timer counter has reached modulo value.
- 0 = Timer counter has not reached modulo value.

#### TOIE — Timer overflow interrupt enable bit

This read/write bit enables timer overflow interrupts when the TOF bit becomes set. Reset clears the TOIE bit.

- 1 = Timer overflow interrupts enabled
- 0 = Timer overflow interrupts disabled

#### TSTOP — Timer stop bit

This read/write bit stops the timer counter. Counting resumes when TSTOP is cleared. Reset sets the TSTOP bit, stopping the timer counter until software clears the TSTOP bit.

- 1 = Timer counter stopped
- 0 = Timer counter active

# **NOTE:** Do not set the TSTOP bit before entering wait mode if the TIM is required to exit wait mode.

#### TRST — Timer reset bit

Setting this write-only bit resets the timer counter and the timer prescaler. Setting TRST has no effect on any other registers. Counting resumes from \$0000. TRST is cleared automatically after the timer counter is reset and always reads as logic 0. Reset clears the TRST bit.

- 1 = Prescaler and timer counter cleared
- 0 = No effect

# **NOTE:** Setting the TSTOP and TRST bits simultaneously stops the timer counter at a value of \$0000.

MC68HC(9)08LJ60 — Rev. 1.0

# Timer Interface Module (TIM)

PS[2:0] — Prescaler select bits

These read/write bits select either the PTE3/TCLK pin or one of the seven prescaler outputs as the input to the timer counter as **Table 16-1** shows. Reset clears the PS2–PS0 bits.

**Table 16-1. Prescaler Selection** 

| PS2-PS0 | TIM clock source        |  |  |  |  |
|---------|-------------------------|--|--|--|--|
| 000     | Internal bus clock      |  |  |  |  |
| 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     | PTE3/TCLK               |  |  |  |  |

**NOTE:** TCLK is a floating input pin. Do not select PS2–PS0 = 111.

Timer Interface Module (TIM)
I/O Registers

#### 16.9.2 Timer Counter Registers

The two read-only timer counter registers contain the high and low bytes of the value in the timer counter. Reading the high byte (TCNTH) latches the contents of the low byte (TCNTL). Subsequent reads of TCNTH do not affect the latched TCNTL value until TCNTL is read. Reset clears the timer counter registers.

Setting the timer reset bit (TRST) also clears the timer counter registers.



Figure 16-5. Timer Counter Register High (TCNTH)



Figure 16-6. Timer Counter Register Low (TCNTL)

# Timer Interface Module (TIM)

#### 16.9.3 Timer Modulo Registers

The read/write timer modulo registers contain the modulo value for the timer counter. When the timer counter reaches the modulo value, the overflow flag (TOF) becomes set, and the timer counter resumes counting from \$0000 at the next clock. The TOF bit and overflow interrupts are inhibited after a write to the high byte (TMODH) until the low byte (TMODL) is written. Reset sets the timer modulo registers.



Figure 16-7. Timer Modulo Register High (TMODH)



Figure 16-8. Timer Modulo Register Low (TMODL)

**NOTE:** Reset the timer counter before writing to the timer modulo registers.

reescale

# Freescale Semiconductor, Inc.

Timer Interface Module (TIM)
I/O Registers

# 16.9.4 Timer Channel Status and Control Registers

Each of the timer 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 timer overflow
- Selects 100% PWM duty cycle



Figure 16-9. Timer Channel 0 Status and Control Register (TSC0)



Figure 16-10. Timer Channel 1 Status and Control Register (TSC1)

# Timer Interface Module (TIM)



Figure 16-11. Timer Channel 2 Status and Control Register (TSC2)



Figure 16-12. Timer Channel 3 Status and Control Register (TSC3)

#### 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 timer counter registers matches the value in the timer channel x registers.

When TIM CPU interrupt requests are enabled

(CHxIE:DMAxS = 1:0), clear CHxF by reading timer 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.

When TIM DMA service requests are enabled (CHxIE:DMAxS = 1:1), clear CHxF by reading or writing to the low byte of the timer channel x registers (TCHxL).

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

Advance Information

MC68HC(9)08LJ60 - Rev. 1.0

Timer Interface Module (TIM)
I/O Registers

CHxIE — Channel x interrupt enable bit

This read/write bit enables TIM CPU interrupts service requests on channel x. The DMAxS bit in the timer DMA select register selects channel x TIM DMA service requests or TIM CPU interrupt requests.

**NOTE:** 

TIM DMA service requests cannot be used in buffered PWM mode. In buffered PWM mode, disable TIM DMA service requests by clearing the DMAxS bit in the timer DMA select register.

Reset clears the CHxE bit.

- 1 = Channel x CPU interrupt requests and DMA service requests enabled
- 0 = Channel x CPU interrupt requests and DMA service requests disabled

**NOTE:** 

Reading the high byte of the timer channel x registers (TCHxH) inhibits the CHxF flag until the low byte (TCHxL) is read.

MSxB — Mode select bit B

This read/write bit selects buffered output compare/PWM operation. MSxB exists only in the timer channel 0 and timer channel 2 status and control registers. Setting MS0B disables the channel 1 status and control register. Setting MS2B disables the channel 3 status and control register.

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 ≠ 00, this read/write bit selects either input capture operation or unbuffered output compare/PWM operation.

(See Table 16-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 16-2**.). Reset clears the MSxA bit.

- 1 = Initial output level low
- 0 = Initial output level high

MC68HC(9)08LJ60 — Rev. 1.0

**NOTE:** Before changing a channel function by writing to the MSxB or MSxA bit, set the TSTOP and TRST bits in the timer status and control register (TSC).

ELSxB and ELSxA — Edge/level select bits

Freescale Semiconductor, Inc.

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 TCHx is available as a general-purpose I/O pin. Table 16-2 shows how ELSxB and ELSxA work. Reset clears the ELSxB and ELSxA bits.

Table 16-2. Mode, Edge, and Level Selection

| MSxB:MSxA | ELSxB:ELSxA | Mode                         | Configuration                                   |  |  |  |
|-----------|-------------|------------------------------|-------------------------------------------------|--|--|--|
| X0        | 00          | Output procet                | Set initial output level high                   |  |  |  |
| X1        | 00          | Output preset                | Set initial output level low                    |  |  |  |
| XX        | 00          | _                            | TCHx pin under port control                     |  |  |  |
| 00        | 01          | 01 Capture on rising edge or |                                                 |  |  |  |
| 00        | 10          | Input capture                | Capture on falling edge only                    |  |  |  |
| 00        | 11          | 1                            | Capture on rising or falling edge               |  |  |  |
| xx        | 00          | _                            | TCHx pin under port control; initial output low |  |  |  |
| 01        | 01          |                              | Toggle output on compare                        |  |  |  |
| 01        | 10          | Output compare or PWM        | Clear output on compare                         |  |  |  |
| 01        | 11          |                              | Set output on compare                           |  |  |  |
| XX        | 00          | _                            | TCHx pin under port control <sup>(1)</sup>      |  |  |  |
| 1X        | 01          | Buffered output              | Toggle output on compare                        |  |  |  |
| 1X        | 10          | compare or                   | Clear output on compare                         |  |  |  |
| 1X        | 11          | buffered PWM                 | Set output on compare                           |  |  |  |

<sup>1.</sup> Initial output high if MSxA = 0. Initial output low if MSxA = 1.

Timer Interface Module (TIM)
I/O Registers

**NOTE:** Before enabling a timer channel register for input capture operation, make sure that the TCHx 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 timer 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 timer counter overflow.
- 0 = Channel x pin does not toggle on timer counter overflow.

**NOTE:** When TOVx is set, a timer counter overflow takes precedence over a channel x output compare if both occur at the same time.

Reading the high byte of the timer channel x registers prevents the channel x pin from toggling until the low byte is read.

CHxMAX — Channel x maximum (100%) PWM duty cycle bit

This read/write bit forces the duty cycle of buffered and unbuffered PWM signals to 100%. As **Figure 16-13** shows, the CHxMAX bit takes effect in the cycle after it is set or cleared. The output stays at the 100% duty cycle level until the cycle after CHxMAX is cleared.



Figure 16-13. CHxMAX Latency

# Timer Interface Module (TIM)

# 16.9.5 Timer Channel Registers

The timer channel registers (TCH0H/L–TCH3H/L) are read/write registers containing the captured timer counter value of the input capture function or the output compare value of the output compare function. The state of the timer channel registers after reset is unknown.

In input capture mode (MSxB:MSxA = 0:0), reading the high byte of the timer channel x registers (TCHxH) inhibits input captures until the low byte (TCHxL) is read.

In output compare mode (MSxB:MSxA  $\neq$  0:0), writing to the high byte of the timer channel x registers (TCHxH) inhibits output compares until the low byte (TCHxL) is written.



Figure 16-14. Timer Channel 0 Register High (TCH0H)



Figure 16-15. Timer Channel 0 Register Low (TCH0L)

Timer Interface Module (TIM)
I/O Registers



Figure 16-16. Timer Channel 1 Register High (TCH1H)



Figure 16-17. Timer Channel 1 Register Low (TCH1L)



Figure 16-18. Timer Channel 2 Register High (TCH2H)



Figure 16-19. Timer Channel 2 Register Low (TCH2L)

# **Timer Interface Module (TIM)**



Figure 16-20. Timer Channel 3 Register High (TCH3H)



Figure 16-21. Timer Channel 3 Register Low (TCH3L)

# Advance Information — MC68HC(9)08LJ60

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

#### 17.1 Contents

| 17.2 In | troduction                | 291 |
|---------|---------------------------|-----|
| 17.3 P  | ort A                     | 293 |
| 17.3.1  | Port A Data Register      | 293 |
| 17.3.2  | Data Direction Register A | 294 |
| 17.4 P  | ort B                     | 296 |
| 17.4.1  | Port B Data Register      | 296 |
| 17.4.2  | Data Direction Register B | 297 |
| 17.5 P  | ort C                     | 299 |
| 17.5.1  | Port C Data Register      | 299 |
| 17.5.2  | Data Direction Register C | 300 |

### 17.2 Introduction

Twenty-four bidirectional input-output (I/O) pins form three 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.

# Input/Output (I/O) Ports

| Addr   | Register Name                    |                 | Bit 7               | 6     | 5     | 4         | 3          | 2     | 1     | Bit 0 |
|--------|----------------------------------|-----------------|---------------------|-------|-------|-----------|------------|-------|-------|-------|
| \$0000 | Port A Data Register (PTA)       | Read:<br>Write: | PTA7                | PTA6  | PTA5  | PTA4      | PTA3       | PTA2  | PTA1  | РТА0  |
|        |                                  | Reset:          |                     |       |       | Unaffecte | d by reset |       |       |       |
| \$0001 | Port B Data Register (PTB)       | Read:<br>Write: | PTB7                | PTB6  | PTB5  | PTB4      | PTB3       | PTB2  | PTB1  | РТВ0  |
|        |                                  | Reset:          |                     |       |       | Unaffecte | d by reset |       |       |       |
| \$0002 | Port C Data Register (PTC)       | Read:<br>Write: | PTC7                | PTC6  | PTC5  | PTC4      | PTC3       | PTC2  | PTC1  | PTC0  |
|        |                                  | Reset:          | Unaffected by reset |       |       |           |            |       |       |       |
| \$0004 | Data Direction Register A (DDRA) | Read:<br>Write: | DDRA7               | DDRA6 | DDRA5 | DDRA4     | DDRA3      | DDRA2 | DDRA1 | DDRA0 |
|        |                                  | Reset:          | 0                   | 0     | 0     | 0         | 0          | 0     | 0     | 0     |
| \$0005 | Data Direction Register B (DDRB) | Read:<br>Write: | DDRB7               | DDRB6 | DDRB5 | DDRB4     | DDRB3      | DDRB2 | DDRB1 | DDRB0 |
|        |                                  | Reset:          | 0                   | 0     | 0     | 0         | 0          | 0     | 0     | 0     |
| \$0006 | Data Direction Register C (DDRC) | Read:<br>Write: | DDRC7               | DDRC6 | DDRC5 | DDRC4     | DDRC3      | DDRC2 | DDRC1 | DDRC0 |
|        |                                  | Reset:          | 0                   | 0     | 0     | 0         | 0          | 0     | 0     | 0     |

Figure 17-1. I/O Port Register Summary

Input/Output (I/O) Ports Port A

#### 17.3 Port A

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

#### 17.3.1 Port A Data Register

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



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

#### PTA7-PTA0 — 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.

## Input/Output (I/O) Ports

### 17.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 17-3. Data Direction Register A (DDRA)

DDRA7–DDRA0 — Data direction register a bits

These read/write bits control port A data direction. Reset clears DDRA7–DDRA0, 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 17-4 shows the port A I/O logic.



Figure 17-4. Port A I/O Circuit

Advance Information

MC68HC(9)08LJ60 — Rev. 1.0

Input/Output (I/O) Ports Port A

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 17-1** summarizes the operation of the port A pins.

**Table 17-1. Port A Pin Functions** 

| DDR. | A PTA            | I/O pin<br>mode               | Accesses<br>to DDRA | Accesse   | s to PTA                 |
|------|------------------|-------------------------------|---------------------|-----------|--------------------------|
|      | bit bit liloue   |                               | Read/Write          | Read      | Write                    |
| 0    | X <sup>(1)</sup> | Input,<br>Hi-Z <sup>(2)</sup> | DDRA7-DDRA0         | Pin       | PTA7-PTA0 <sup>(3)</sup> |
| 1    | Х                | Output                        | DDRA7-DDRA0         | PTA7-PTA0 | PTA7-PTA0                |

- 1. X = don't care
- 2. Hi-Z = high impedance
- 3. Writing affects data register, but does not affect input.

# Input/Output (I/O) Ports

#### 17.4 Port B

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

#### 17.4.1 Port B Data Register

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



Figure 17-5. Port B Data Register (PTB)

#### PTB7-PTB0 — 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.

The port B interrupt enable bits, PTB7IE–PTB0IE, in the port B interrupt control register (PTBICR) enable the port B pins as external interrupt pins. See **Section 11. External Interrupt Module (IRQ)**.

Input/Output (I/O) Ports Port B

### 17.4.2 Data Direction Register B

Data direction register B (DDRB) 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.



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

DDRB7-DDRB0 — Data direction register B bits

These read/write bits control port B data direction. Reset clears DDRB7–DDRB0, 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 17-7 shows the port B I/O logic.



Figure 17-7. Port B I/O Circuit

MC68HC(9)08LJ60 - Rev. 1.0

**Advance Information** 

# Input/Output (I/O) Ports

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. The data latch can always be written, regardless of the state of its data direction bit. **Table 17-2** summarizes the operation of the port B pins.

**Table 17-2. Port B Pin Functions** 

| DDRB<br>bit | PTB<br>bit       |                               | I/O pin<br>mode | Accesses<br>to DDRB | Access                   | es to PTB |
|-------------|------------------|-------------------------------|-----------------|---------------------|--------------------------|-----------|
|             | bit bit mode     |                               | Read/Write      | Read                | Write                    |           |
| 0           | X <sup>(1)</sup> | Input,<br>Hi-Z <sup>(2)</sup> | DDRB7-DDRB0     | Pin                 | PTB7-PTB0 <sup>(3)</sup> |           |
| 1           | Х                | Output                        | DDRB7-DDRB0     | PTB7-PTB0           | PTB7-PTB0                |           |

- 1. X = don't care
- 2. Hi-Z = high impedance
- 3. Writing affects data register, but does not affect input.

### 17.5 Port C

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

#### 17.5.1 Port C Data Register

The port C data register (PTC) contains a data latch for each of the eight port C pins.



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

#### PTC7-PTC0 — 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.

# Input/Output (I/O) Ports

### 17.5.2 Data Direction Register C

Data direction register C (DDRC) 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.



Figure 17-9. Data Direction Register C (DDRC)

DDRC7–DDRC0 — Data direction register C bits

These read/write bits control port C data direction. Reset clears DDRC7–DDRC0, 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 17-10 shows the port C I/O logic.



Figure 17-10. Port C I/O Circuit

Advance Information

MC68HC(9)08LJ60 — Rev. 1.0

Input/Output (I/O) Ports Port C

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 17-3** summarizes the operation of the port C pins.

**Table 17-3. Port C Pin Functions** 

| DDRC<br>bit | PTC<br>bit       |                               | I/O pin<br>mode | Accesses<br>to DDRC | Accesse                  | es to PTC |
|-------------|------------------|-------------------------------|-----------------|---------------------|--------------------------|-----------|
| ) bit       | bit bit mode     |                               | Read/Write      | Read                | Write                    |           |
| 0           | X <sup>(1)</sup> | Input,<br>Hi-Z <sup>(2)</sup> | DDRC7-DDRC0     | Pin                 | PTC7-PTC0 <sup>(3)</sup> |           |
| 1           | Х                | Output                        | DDRC7-DDRC0     | PTC7-PTC0           | PTC7-PTC0                |           |

- 1. X = don't care
- 2. Hi-Z = high impedance
- 3. Writing affects data register, but does not affect input.

Input/Output (I/O) Ports

### Advance Information — MC68HC(9)08LJ60

# Section 18. Monitor ROM (MON)

#### 18.1 Contents

| 18.2   | Introduction              |
|--------|---------------------------|
| 18.3   | Features                  |
| 18.4   | Functional Description304 |
| 18.4.1 | Entering Monitor Mode     |
| 18.4.2 | Data Format               |
| 18.4.3 | Echoing                   |
| 18.4.4 | Break Signal              |
| 18.4.5 | Baud Rate                 |

### 18.2 Introduction

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

#### 18.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 to 28.8-Kbaud communication with host computer
- Execution of code in RAM or ROM

MC68HC(9)08LJ60 — Rev. 1.0

**Advance Information** 

# **Monitor ROM (MON)**

## 18.4 Functional Description

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

Simple monitor commands can access any memory address. In monitor mode, the MCU can execute host-computer code in RAM while all MCU pins 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.

Monitor ROM (MON) Functional Description



Figure 18-1. Monitor Mode Circuit

MC68HC(9)08LJ60 - Rev. 1.0

Advance Information

### **Monitor ROM (MON)**

### 18.4.1 Entering Monitor Mode

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

Table 18-1. Mode Selection

| IRQ1 pin                          | PTC0 pin | PTC1 pin | PTA0 pin | PTC3 pin | Mode    | CGMOUT                                                   | Bus<br>frequency |
|-----------------------------------|----------|----------|----------|----------|---------|----------------------------------------------------------|------------------|
| V <sub>DD</sub> + V <sub>HI</sub> | 1        | 0        | 1        | 1        | Monitor | $\frac{\text{CGMXCLK}}{2}$ or $\frac{\text{CGMVCLK}}{2}$ | CGMOUT 2         |
| V <sub>DD</sub> + V <sub>HI</sub> | 1        | 0        | 1        | 0        | Monitor | CGMXCLK                                                  | CGMOUT 2         |

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}$  is applied to either the  $\overline{IRQ1}$  pin or the  $\overline{RST}$  pin. See Section 6. 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% duty cycle at maximum bus frequency.

Advance Information

MC68HC(9)08LJ60 — Rev. 1.0

Monitor ROM (MON) Functional Description

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

**Table 18-2. Mode Differences** 

|                        |                         |                         | Fu                     | ınctions                |                        |                       |                      |
|------------------------|-------------------------|-------------------------|------------------------|-------------------------|------------------------|-----------------------|----------------------|
| 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 <sup>(1)</sup> | Disabled <sup>(2)</sup> | \$FEFE                  | \$FEFF                 | \$FEFC                  | \$FEFD                 | \$FEFC                | \$FEFD               |

- 1. If PTA0 is low out of reset, the CPU performs a jump to RAM for burn-in.
- 2. If the high voltage ( $V_{DD} + V_{HI}$ ) is removed from the  $\overline{IRQ1}$  pin or the  $\overline{RST}$  pin, the SIM asserts its COP enable output.

#### 18.4.2 Data Format

Communication with the monitor ROM is in standard non-return-to-zero (NRZ) mark/space data format. (See Figure 18-2 and Figure 18-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 18-2. Monitor Data Format



Figure 18-3. Sample Monitor Waveforms

MC68HC(9)08LJ60 — Rev. 1.0

**Advance Information** 

# **Monitor ROM (MON)**

### **18.4.3 Echoing**

As shown in **Figure 18-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 18-4. Read Transaction

### 18.4.4 Break Signal

A start bit followed by nine low bits is a break signal. (See **Figure 18-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 18-5. Break Transaction

Monitor ROM (MON) Functional Description

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

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



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

| Description                                  | Write byte to memory                                                                 |  |  |  |  |  |
|----------------------------------------------|--------------------------------------------------------------------------------------|--|--|--|--|--|
| Operand                                      | Specifies 2-byte address in high byte:low byte order; low byte followed by data byte |  |  |  |  |  |
| Data returned                                | None                                                                                 |  |  |  |  |  |
| Opcode                                       | \$49                                                                                 |  |  |  |  |  |
| Command sequer  SENT TO MONITOR  WRITE  ECHO | WRITE ADDR. HIGH ADDR. LOW ADDR. LOW DATA DATA                                       |  |  |  |  |  |

MC68HC(9)08LJ60 — Rev. 1.0

Advance Information

### Table 18-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 sequer  | Command sequence                                       |  |  |  |  |  |
| SENT TO MONITOR | IREAD / DATA / DATA / RESULT                           |  |  |  |  |  |

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



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

Table 18-7. READSP (Read Stack Pointer) Command



Table 18-8. RUN (Run User Program) Command

| Description    | Executes RTI instruction |  |  |  |  |  |
|----------------|--------------------------|--|--|--|--|--|
| Operand        | None                     |  |  |  |  |  |
| Data returned  | None                     |  |  |  |  |  |
| Opcode         | \$28                     |  |  |  |  |  |
| Command sequer | Command sequence         |  |  |  |  |  |
|                | SENT TO MONITOR RUN RUN  |  |  |  |  |  |
|                | ЕСНО —                   |  |  |  |  |  |

# **Monitor ROM (MON)**

#### 18.4.5 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 MUL11–MUL0 bits in the PLL multiplier registers. See Section 7. Clock Generator Module (CGMB).

Table 18-9. Monitor Baud Rate Selection

|                   | VCO frequency multiplier (N) |      |        |        |        |        |  |  |
|-------------------|------------------------------|------|--------|--------|--------|--------|--|--|
|                   | 1                            | 2    | 3      | 4      | 5      | 6      |  |  |
| Monitor baud rate | 4800                         | 9600 | 14,400 | 19,200 | 24,000 | 28,800 |  |  |

# Advance Information — MC68HC(9)08LJ60

# Section 19. Keyboard Interrupt (KBI) Module

### 19.1 Contents

| 19.2   | Introduction                       |
|--------|------------------------------------|
| 19.3   | Features                           |
| 19.4   | Functional Description             |
| 19.5   | Initialization                     |
| 19.6   | Wait Mode                          |
| 19.7   | I/O Registers                      |
| 19.7.1 | IRQ Status and Control Register317 |
| 19.7.2 | Keyboard Interrupt Enable Register |

### 19.2 Introduction

The keyboard interrupt (KBI) module provides eight independently maskable external interrupt pins.

### 19.3 Features

### Features include:

- Eight keyboard interrupt pins with separate keyboard interrupt enable bits and one keyboard interrupt mask
- The keyboard interrupt module shares the 8-bit bidirectional I/O port with port B.

# Keyboard Interrupt (KBI) Module



Figure 19-1. Block Diagram

Keyboard Interrupt (KBI) Module Functional Description

# 19.4 Functional Description

Writing to the KBIE7–KBIE0 bits in the keyboard interrupt enable register independently enables or disables each port B pin as a keyboard interrupt pin. Enabling a keyboard interrupt pin also enables its internal pullup device. A logic 0 applied to an enabled keyboard interrupt pin latches a keyboard interrupt request.

A keyboard interrupt request is latched when one or more keyboard pins goes low after all were high.

#### Vector fetch or software clear

A vector fetch generates an interrupt acknowledge signal to clear the interrupt request. Software can generate the interrupt acknowledge signal by writing a logic 1 to the ACK2, IRQ2 interrupt request acknowledge bit in the IRQ status and control register (ISCR). The ACK2 bit is useful in applications that poll the keyboard interrupt pins and require software to clear the keyboard interrupt request. Writing to the ACK2 bit in an interrupt service routine can also prevent spurious interrupts due to noise. Setting ACK2 does not affect subsequent transitions on the keyboard interrupt pins. A falling edge that occurs after writing to the ACK2 bit latches another interrupt request. If the keyboard interrupt mask bit, IMASK2, is clear, the CPU loads the program counter with the vector address at locations \$FFD2 and \$FFD3. See 19.7.1 IRQ Status and Control Register.

#### Return of all enabled keyboard interrupt pins to logic 1

As long as any enabled keyboard interrupt pin is at logic 0, the keyboard interrupt request remains set.

The vector fetch or software clear and the return of all enabled keyboard interrupt pins to logic 1 may occur in any order.

Reset clears the keyboard interrupt request.

The PIN2 bit in the ISCR can be used to see if a pending interrupt exists. The PIN2 bit is not affected by the keyboard interrupt mask bit IMASK2. See 19.7.1 IRQ Status and Control Register.

MC68HC(9)08LJ60 — Rev. 1.0

Advance Information

## Keyboard Interrupt (KBI) Module

To determine the logic level on a keyboard interrupt pin, use the data direction register to configure the pin as an input and read the data register.

#### **NOTE:**

Setting a keyboard interrupt enable bit (KBIEx) forces the corresponding keyboard interrupt pin to be an input, overriding the data direction register. However, the data direction register bit must be a logic 0 for software to read the pin.

#### 19.5 Initialization

When a keyboard interrupt pin is enabled, it takes time for the internal pullup to reach a logic 1. Therefore, a false interrupt can occur as soon as the pin is enabled.

To prevent a false interrupt on keyboard initialization:

- Mask keyboard interrupts by setting the IMASK2 bit in the ISCR. See 19.7.1 IRQ Status and Control Register.
- 2. Enable the KBI pins by setting the appropriate KBIEx bits in the keyboard interrupt enable register.
- Write to the ACK2 bit in the ISCR to clear any false interrupts.See 19.7.1 IRQ Status and Control Register.
- 4. Clear the IMASK2 bit.

An interrupt signal on an edge-triggered pin can be acknowledged immediately after enabling the pin.

Another way to avoid a false interrupt:

- 1. Configure the keyboard pins as outputs by setting the appropriate DDRB bits in data direction register B.
- 2. Write logic 1s to the appropriate port B data register bits.
- 3. Enable the KBI pins by setting the appropriate KBIEx bits in the keyboard interrupt enable register.

Advance Information

MC68HC(9)08LJ60 — Rev. 1.0

Keyboard Interrupt (KBI) Module Wait Mode

#### 19.6 Wait Mode

The keyboard interrupt module remains active in wait mode. Clearing the IASK2 bit in the ISCR enables keyboard interrupt requests to bring the MCU out of wait mode.

### 19.7 I/O Registers

These registers control and monitor operation of the keyboard interrupt module:

- IRQ status and control register (ISCR)
- Keyboard interrupt enable register (KBIER)

### 19.7.1 IRQ Status and Control Register

See 11.6 IRQ Status and Control Register.

### 19.7.2 Keyboard Interrupt Enable Register

The keyboard interrupt enable register enables or disables each port B pin to operate as a keyboard interrupt pin.



Figure 19-2. Keyboard Interrupt Enable Register (KBIER)

KBIE7-KBIE0 — Keyboard interrupt enable bits

Each of these read/write bits enables the corresponding keyboard interrupt pin to latch interrupt requests. Reset clears the keyboard interrupt enable register.

- 1 = PBx pin enabled as keyboard interrupt pin
- 0 = PBx pin not enabled as keyboard interrupt pin

MC68HC(9)08LJ60 — Rev. 1.0

Advance Information

Keyboard Interrupt (KBI) Module

### Advance Information — MC68HC(9)08LJ60

# Section 20. Preliminary Electrical Specifications

### 20.1 Contents

| 20.2 | ! Introduction                                                    |
|------|-------------------------------------------------------------------|
| 20.3 | Absolute Maximum Ratings                                          |
| 20.4 | Functional Operating Range321                                     |
| 20.5 | Thermal Characteristics                                           |
| 20.6 | 3.0 Volt ± 10% DC Electrical Characteristics                      |
| 20.7 | 2.0 Volt ± 10% DC Electrical Characteristics                      |
| 20.8 | 3.0 Volt ± 10% Control Timing                                     |
| 20.9 | 2.0 Volt ± 10% Control Timing                                     |
| 20.1 | 0 3.0 Volt $\pm$ 10% Serial Peripheral Interface (SPI) Timing 325 |
| 20.1 | 1 2.0 Volt $\pm$ 10% Serial Peripheral Interface (SPI) Timing 326 |
| 20.1 | 2 PLL2P12M Electrical Specifications                              |
| 20.1 | 3 Bus Clock PLL Acquisition/Lock Time Specifications330           |
| 20.1 | 4 PLL2P12M Component Specifications                               |
| 20.1 | 5 RAM Characteristics                                             |
| 20.1 | 6 FLASH Memory Electrical Characteristics                         |

### 20.2 Introduction

This section contains electrical and timing specifications. These values are design targets and have not yet been tested.

## **Preliminary Electrical Specifications**

## 20.3 Absolute Maximum Ratings

Maximum ratings are the extreme limits to which the MCU can be exposed without permanently damaging it.

The MCU contains circuitry to protect the inputs against damage from high static voltages; however, do not apply voltages higher than those shown in this table. Keep  $V_{In}$  and  $V_{Out}$  within the range  $V_{SS} \leq (V_{In} \text{ or } V_{Out}) \leq V_{DD}$ . Connect unused inputs to the appropriate voltage level, either  $V_{SS}$  or  $V_{DD}$ .

| Rating                                                                | Symbol            | Value                                                        | Unit |
|-----------------------------------------------------------------------|-------------------|--------------------------------------------------------------|------|
| Supply voltage                                                        | V <sub>DD</sub>   | V <sub>DD</sub> -0.3 to +3.6                                 |      |
| Input voltage                                                         | V <sub>IN</sub>   | V <sub>IN</sub> V <sub>SS</sub> -0.3 to V <sub>DD</sub> +0.3 |      |
| Maximum current per pin 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 <sub>SS</sub>                                | I <sub>MVSS</sub> | 100                                                          | mA   |
| Maximum current into V <sub>DD</sub>                                  | I <sub>MVDD</sub> | 100                                                          | mA   |

NOTE: Voltages are referenced to V<sub>SS</sub>.

#### **NOTE:**

This device is not guaranteed to operate properly at the maximum ratings. Refer to 20.6 3.0 Volt ± 10% DC Electrical Characteristics and 20.7 2.0 Volt ± 10% DC Electrical Characteristics for guaranteed operating conditions.

| Rating                                 | Symbol          | Value                  | Unit |
|----------------------------------------|-----------------|------------------------|------|
| Operating temperature range            | T <sub>A</sub>  | –20 to +65             | °C   |
| Operating voltage range <sup>(1)</sup> | V <sub>DD</sub> | 2.0 ± 10%<br>3.0 ± 10% | V    |

<sup>1.</sup> LCD charge pump optimized for given ranges

### 20.5 Thermal Characteristics

| Characteristic                                         | Symbol           | Value                                                              | Unit |
|--------------------------------------------------------|------------------|--------------------------------------------------------------------|------|
| Thermal resistance, 160 BGA MC68HC08LJ60 MC68HC908LJ60 | $\theta_{JA}$    | 61<br>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_D \times (T_A + 273 ^{\circ}C) + (P_D^2 \times \theta_{JA})$    | W/°C |
| Average junction temperature                           | T <sub>J</sub>   | $T_A = P_D \times \theta_{JA}$                                     | °C   |
| Maximum junction temperature                           | T <sub>JM</sub>  | 100                                                                | °C   |

<sup>1.</sup> Power dissipation is a function of temperature

<sup>2.</sup> 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$ .

## **Preliminary Electrical Specifications**

#### 20.6 3.0 Volt ± 10% DC Electrical Characteristics

| Characteristic <sup>(1)</sup>                                               | Symbol                              | Min                   | Тур <sup>(2)</sup> | Max                   | Unit     |
|-----------------------------------------------------------------------------|-------------------------------------|-----------------------|--------------------|-----------------------|----------|
| Output high voltage (I <sub>Load</sub> = -0.4 mA) all pins                  | V <sub>OH</sub>                     | 0.7 x V <sub>DD</sub> | _                  | _                     | V        |
| Output low voltage (I <sub>Load</sub> = 0.8 mA) all pins                    | V <sub>OL</sub>                     |                       | _                  | 0.3 x V <sub>DD</sub> | V        |
| Input high voltage All ports, IRQs, RESET, OSC1                             | V <sub>IH</sub>                     | 0.7 x V <sub>DD</sub> | _                  | V <sub>DD</sub>       | V        |
| Input low voltage All ports, IRQs, RESET, OSC1                              | V <sub>IL</sub>                     | $V_{SS}$              | _                  | 0.3 x V <sub>DD</sub> | V        |
| Monitor mode entry voltage                                                  | V <sub>HI</sub>                     |                       | _                  | $V_{DD}$              | V        |
| V <sub>DD</sub> supply current<br>Run <sup>(3)</sup><br>Wait <sup>(4)</sup> | I <sub>DD</sub>                     | 1-1                   | _                  | 4<br>30               | mA<br>μA |
| I/O ports high-impedance leakage current                                    | I <sub>IL</sub>                     | _                     | _                  | ± 10                  | μΑ       |
| Input current                                                               | I <sub>In</sub>                     |                       | _                  | 1                     | μΑ       |
| Capacitance Ports (as input or output)                                      | C <sub>Out</sub><br>C <sub>In</sub> |                       |                    | 12<br>8               | pF       |
| POR rearm voltage <sup>(5)</sup>                                            | V <sub>POR</sub>                    | 0                     | _                  | 200                   | mV       |
| POR reset voltage <sup>(6)</sup>                                            | V <sub>PORRST</sub>                 | 0                     | 700                | 800                   | mV       |
| POR rise time ramp rate <sup>(7)</sup>                                      | R <sub>POR</sub>                    | 0.02                  | _                  | _                     | V/ms     |

- 1.  $V_{DD}$  = 3.0 Vdc  $\pm$  10%,  $V_{SS}$  = 0 Vdc,  $T_A$  = -20 °C to +65 °C, unless otherwise noted.
- 2. Typical values reflect average measurements at midpoint of voltage range, 25  $^{\circ}\text{C}$  only.
- 3. Run (operating)  $I_{DD}$  measured using external square wave clock source ( $f_{op}$  = 4.1 MHz). All inputs 0.2 V from rail. No dc loads. Less than 100 pF on all outputs.  $C_L$  = 20 pF on OSC2. All ports configured as inputs. OSC2 capacitance linearly affects run  $I_{DD}$ . Measured with all modules enabled.
- 4. Wait  $I_{DD}$  measured using external square wave clock source ( $f_{op}$  = 9.6 kHz). All inputs 0.2V from rail. No dc loads. Less than 100 pF on all outputs.  $C_L$  = 20 pF on OSC2. All ports configured as inputs. OSC2 capacitance linearly affects wait  $I_{DD}$ . Measured with PLL and LCD.
- 5. Maximum is highest voltage that POR is guaranteed.
- 6. Maximum is highest voltage that POR is possible.
- 7. If minimum V<sub>DD</sub> is not reached before the internal POR reset is released, RSTB must be driven low externally until minimum V<sub>DD</sub> is reached.

Preliminary Electrical Specifications 2.0 Volt ± 10% DC Electrical Characteristics

#### 20.7 2.0 Volt ± 10% DC Electrical Characteristics

| Characteristic <sup>(1)</sup>                                               | Symbol                              | Min                   | Тур <sup>(2)</sup> | Max                   | Unit     |
|-----------------------------------------------------------------------------|-------------------------------------|-----------------------|--------------------|-----------------------|----------|
| Output high voltage<br>(I <sub>Load</sub> = -0.4 mA) all pins               | V <sub>OH</sub>                     | 0.7 x V <sub>DD</sub> | _                  | _                     | V        |
| Output low voltage<br>(I <sub>Load</sub> = 0.8 mA) all pins                 | V <sub>OL</sub>                     | _                     | _                  | 0.3 x V <sub>DD</sub> | V        |
| Input high voltage All ports, IRQs, RESET, OSC1                             | V <sub>IH</sub>                     | 0.7 x V <sub>DD</sub> | _                  | V <sub>DD</sub>       | V        |
| Input low voltage All ports, IRQs, RESET, OSC1                              | V <sub>IL</sub>                     | V <sub>SS</sub>       | _                  | 0.3 x V <sub>DD</sub> | V        |
| Monitor mode entry voltage                                                  | V <sub>HI</sub>                     | _                     | _                  | V <sub>DD</sub>       | V        |
| V <sub>DD</sub> supply current<br>Run <sup>(3)</sup><br>Wait <sup>(4)</sup> | I <sub>DD</sub>                     |                       | _                  | 2<br>20               | mA<br>μA |
| I/O ports high-impedance leakage current                                    | I <sub>IL</sub>                     | _                     | _                  | ± 10                  | μΑ       |
| Input current                                                               | I <sub>In</sub>                     | _                     | _                  | 1                     | μΑ       |
| Capacitance Ports (as input or output)                                      | C <sub>Out</sub><br>C <sub>In</sub> | _                     | _                  | 12<br>8               | pF       |
| POR rearm voltage <sup>(5)</sup>                                            | V <sub>POR</sub>                    | 0                     | _                  | 200                   | mV       |
| POR reset voltage <sup>(6)</sup>                                            | V <sub>PORRST</sub>                 | 0                     | 700                | 800                   | mV       |
| POR rise time ramp rate <sup>(7)</sup>                                      | R <sub>POR</sub>                    | 0.02                  | _                  | _                     | V/ms     |

- 1.  $V_{DD}$  = 2.0 Vdc  $\pm$  10%,  $V_{SS}$  = 0 Vdc,  $T_A$  = -20 °C to +65 °C, unless otherwise noted.
- 2. Typical values reflect average measurements at midpoint of voltage range, 25 °C only.
- 3. Run (operating)  $I_{DD}$  measured using external square wave clock source ( $f_{op}$  = 2 MHz). All inputs 0.2 V from rail. No dc loads. Less than 100 pF on all outputs.  $C_L$  = 20 pF on OSC2. All ports configured as inputs. OSC2 capacitance linearly affects run  $I_{DD}$ . Measured with all modules enabled.
- 4. Wait  $I_{DD}$  measured using external square wave clock source ( $f_{op}$  = 9.6 kHz). All inputs 0.2 V from rail. No dc loads. Less than 100 pF on all outputs.  $C_L$  = 20 pF on OSC2. All ports configured as inputs. OSC2 capacitance linearly affects wait  $I_{DD}$ . Measured with PLL, LCD, LVI, and TBM enabled.
- 5. Maximum is highest voltage that POR is guaranteed.
- 6. Maximum is highest voltage that POR is possible.
- If minimum V<sub>DD</sub> is not reached before the internal POR reset is released, RSTB must be driven low externally until minimum V<sub>DD</sub> is reached.

# **Preliminary Electrical Specifications**

# 20.8 3.0 Volt $\pm$ 10% Control Timing

| Characteristic <sup>(1)</sup>                                | Symbol            | Min | Max | Unit |
|--------------------------------------------------------------|-------------------|-----|-----|------|
| Frequency of operation, (2) crystal option                   | fosc              | 32  | 100 | kHz  |
| Internal operating frequency                                 | f <sub>OP</sub>   | _   | 4.0 | MHz  |
| Internal bus cycle time                                      | t <sub>cyc</sub>  | _   | 250 | ns   |
| RESET input pulse width low (3)                              | t <sub>IRL</sub>  | 125 | _   | ns   |
| IRQ interrupt pulse width low, <sup>(4)</sup> edge-triggered | t <sub>ILIH</sub> | 125 | _   | ns   |

<sup>1.</sup>  $V_{DD}$  = 3.0 Vdc  $\pm$  10%,  $V_{SS}$  = 0 Vdc; timing shown with respect to 20%  $V_{DD}$  and 70%  $V_{SS}$  unless otherwise noted

- 2. See 20.12 PLL2P12M Electrical Specifications for more information.
- Minimum pulse width reset is guaranteed to be recognized; it is possible for a smaller pulse width to cause a reset.
- Minimum pulse width is for guaranteed interrupt; it is possible for a smaller pulse width to be recognized.

### 20.9 2.0 Volt $\pm$ 10% Control Timing

| Characteristic <sup>(1)</sup>                                | Symbol            | Min | Max | Unit |
|--------------------------------------------------------------|-------------------|-----|-----|------|
| Frequency of operation, (2) crystal option                   | fosc              | 32  | 100 | kHz  |
| Internal operating frequency                                 | f <sub>OP</sub>   | _   | 2.0 | MHz  |
| Internal bus cycle time                                      | t <sub>cyc</sub>  | _   | 500 | ns   |
| RESET input pulse width low (3)                              | t <sub>IRL</sub>  | 125 | _   | ns   |
| IRQ interrupt pulse width low, <sup>(4)</sup> edge-triggered | t <sub>ILIH</sub> | 125 | _   | ns   |

<sup>1.</sup>  $V_{DD}$  = 2.0 Vdc  $\pm$  10%,  $V_{SS}$  = 0 Vdc; timing shown with respect to 20%  $V_{DD}$  and 70%  $V_{SS}$  unless otherwise noted

<sup>2.</sup> See 20.12 PLL2P12M Electrical Specifications for more information.

<sup>3.</sup> Minimum pulse width reset is guaranteed to be recognized; it is possible for a smaller pulse width to cause a reset.

Minimum pulse width is for guaranteed interrupt; it is possible for a smaller pulse width to be recognized.

**Preliminary Electrical Specifications** 3.0 Volt ± 10% Serial Peripheral Interface (SPI) Timing

### 20.10 3.0 Volt ± 10% Serial Peripheral Interface (SPI) Timing

| Num <sup>(1)</sup> | Characteristic <sup>(2)</sup>                                        | Symbol                                      | Min                        | Max                                   | Unit             |
|--------------------|----------------------------------------------------------------------|---------------------------------------------|----------------------------|---------------------------------------|------------------|
|                    | Operating frequency Master Slave                                     | f <sub>OP(M)</sub><br>f <sub>OP(S)</sub>    | f <sub>OP</sub> /128<br>dc | f <sub>OP</sub> /2<br>f <sub>OP</sub> | MHz              |
| 1                  | Cycle time<br>Master<br>Slave                                        | t <sub>cyc(M)</sub> t <sub>cyc(s)</sub>     | 2<br>1                     | 128<br>—                              | t <sub>cyc</sub> |
| 2                  | Enable lead time                                                     | t <sub>Lead</sub>                           | 30                         | _                                     | ns               |
| 3                  | Enable lag time                                                      | t <sub>LAG</sub>                            | 30                         | _                                     | ns               |
| 4                  | Clock (SCK) high time<br>Master<br>Slave                             | t <sub>w(sckh)m</sub> t <sub>w(sckh)s</sub> | 200<br>100                 |                                       | ns               |
| 5                  | Clock (SCK) low time<br>Master<br>Slave                              | tw(sckl)m                                   | 200<br>100                 | _                                     | ns               |
| 6                  | Data setup time, inputs<br>Master<br>Slave                           | t <sub>SU(M)</sub> t <sub>SU(S)</sub>       | 90<br>10                   | _                                     | ns               |
| 7                  | Data hold time, inputs<br>Master<br>Slave                            | t <sub>H(M)</sub> t <sub>H(S)</sub>         | 0<br>30                    | _                                     | ns               |
| 8                  | Access time, slave <sup>(3)</sup> CPHA = 0 CPHA = 1                  | t <sub>A(CP0)</sub><br>t <sub>A(CP1)</sub>  | 0<br>0                     | 80<br>40                              | ns               |
| 9                  | Slave disable time, hold time to high-impedance state <sup>(4)</sup> | t <sub>DIS</sub>                            | _                          | 50                                    | ns               |
| 10                 | Data valid time after enable edge <sup>(5)</sup> Master Slave        | t <sub>V(M)</sub> t <sub>V(S)</sub>         | _                          | 20<br>80                              | 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>10                    | _                                     | ns               |

<sup>1.</sup> Item numbers refer to dimensions in Figure 20-1 and Figure 20-2. 
2. All timing is shown with respect to 20%  $V_{DD}$  and 70%  $V_{DD}$ , unless otherwise noted; assumes 100 pF load on all SPI pins.

<sup>3.</sup> Time to data active from high-impedance state

<sup>4.</sup> Hold time to high-impedance state

<sup>5.</sup> With 100 pF on all SPI pins

### **Preliminary Electrical Specifications**

#### 20.11 2.0 Volt ± 10% Serial Peripheral Interface (SPI) Timing

| Num <sup>(1)</sup> | Characteristic <sup>(2)</sup>                                        | Symbol                                         | Min                        | Max                                   | Unit             |
|--------------------|----------------------------------------------------------------------|------------------------------------------------|----------------------------|---------------------------------------|------------------|
|                    | Operating frequency Master Slave                                     | f <sub>OP(M)</sub><br>f <sub>OP(S)</sub>       | f <sub>OP</sub> /128<br>dc | f <sub>OP</sub> /2<br>f <sub>OP</sub> | MHz              |
| 1                  | Cycle time<br>Master<br>Slave                                        | t <sub>cyc(M)</sub> t <sub>cyc(s)</sub>        | 2<br>1                     | 128<br>—                              | t <sub>cyc</sub> |
| 2                  | Enable lead time                                                     | t <sub>Lead</sub>                              | 60                         | _                                     | ns               |
| 3                  | Enable lag time                                                      | t <sub>LAG</sub>                               | 60                         | _                                     | ns               |
| 4                  | Clock (SCK) high time<br>Master<br>Slave                             | t <sub>W(SCKH)M</sub><br>t <sub>W(SCKH)S</sub> | 400<br>200                 |                                       | ns               |
| 5                  | Clock (SCK) low time<br>Master<br>Slave                              | t <sub>W(SCKL)M</sub>                          | 400<br>200                 |                                       | ns               |
| 6                  | Data setup time, inputs<br>Master<br>Slave                           | t <sub>SU(M)</sub> t <sub>SU(S)</sub>          | 180<br>20                  |                                       | ns               |
| 7                  | Data hold time, inputs<br>Master<br>Slave                            | t <sub>H(M)</sub> t <sub>H(S)</sub>            | 0<br>60                    | _                                     | ns               |
| 8                  | Access time, slave <sup>(3)</sup> CPHA = 0 CPHA = 1                  | t <sub>A(CP0)</sub>                            | 0<br>0                     | 160<br>80                             | ns               |
| 9                  | Slave disable time, hold time to high-impedance state <sup>(4)</sup> | t <sub>DIS</sub>                               | _                          | 100                                   | ns               |
| 10                 | Data valid time after enable edge <sup>(5)</sup> Master Slave        | t <sub>∨(M)</sub><br>t <sub>∨(S)</sub>         |                            | 40<br>160                             | 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>2                     | _                                     | ns               |

<sup>1.</sup> Item numbers refer to dimensions in Figure 20-1 and Figure 20-2. 
2. All timing is shown with respect to 20%  $V_{DD}$  and 70%  $V_{DD}$ , unless otherwise noted; assumes 100 pF load on all SPI pins.

<sup>3.</sup> Time to data active from high-impedance state

<sup>4.</sup> Hold time to high-impedance state

<sup>5.</sup> With 100 pF on all SPI pins

Preliminary Electrical Specifications 2.0 Volt  $\pm$  10% Serial Peripheral Interface (SPI) Timing



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 20-1. SPI Master Timing

MC68HC(9)08LJ60 - Rev. 1.0

**Advance Information** 

### **Preliminary Electrical Specifications**



NOTE: Not defined but normally MSB of character just received.

#### a) SPI Slave Timing (CPHA = 0)



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

b) SPI Slave Timing (CPHA = 1)

Figure 20-2. SPI Slave Timing

Preliminary Electrical Specifications PLL2P12M Electrical Specifications

## 20.12 PLL2P12M Electrical Specifications

| Description                        | Symbol            | Min                 | Тур         | Max                 | Notes                                                            |
|------------------------------------|-------------------|---------------------|-------------|---------------------|------------------------------------------------------------------|
| CGMXCLK reference frequency        | f <sub>RCLK</sub> | _                   | 38.4 kHz    | _                   |                                                                  |
| Range nominal multiplier (Hz)      | f <sub>NOM</sub>  | _                   | 38.4 k      | _                   |                                                                  |
| VCO center-of-range frequency (Hz) | f <sub>VRS</sub>  | 38.4 k<br>38.4 k    | _           | 20.0 M<br>10.0 M    | 2.7–3.3 V V <sub>DD</sub> only<br>1.8–2.7 V V <sub>DD</sub>      |
| VCO range linear range multiplier  | L                 | 1<br>E = 0          | 64<br>E = 0 | 255<br>E = 3        |                                                                  |
| VCO power-of-two range multiplier  | 2 <sup>E</sup>    | 1                   | 1           | 8                   |                                                                  |
| VCO multiply factor                | N                 | 1                   | 64          | 4095                |                                                                  |
| VCO prescale multiplier            | 2 <sup>P</sup>    | 1<br>P = 0          | 1<br>P = 0  | 8<br>P = 3          |                                                                  |
| Reference divider factor           | R                 | 1                   | 1           | 15                  |                                                                  |
| VCO operating frequency            | f <sub>VCLK</sub> | f <sub>VRSMIN</sub> | _           | f <sub>VRSMAX</sub> |                                                                  |
| Bus operating frequency (Hz)       | f <sub>BUS</sub>  |                     |             | 4M<br>2M            | 2.7–3.3 V V <sub>DD</sub> only<br>1.8–2.7 V V <sub>DD</sub> only |

## **Preliminary Electrical Specifications**

### 20.13 Bus Clock PLL Acquisition/Lock Time Specifications

This section provides specifications for the entry and exit of acquisition and tracking modes, as well as required manual mode delay times.

| Description                                       | Symbol            | Min                                | Тур                                | Max    | Notes                              |
|---------------------------------------------------|-------------------|------------------------------------|------------------------------------|--------|------------------------------------|
| Filter capacitor multiply factor                  | C <sub>Fact</sub> | _                                  | 0.0145                             | _      | F/sV                               |
| Acquisition mode time factor                      | K <sub>ACQ</sub>  | _                                  | 0.117                              | _      | V                                  |
| Tracking mode time factor                         | K <sub>TRK</sub>  | _                                  | 0.021                              | _      | V                                  |
| Manual mode time to stable                        | t <sub>ACQ</sub>  | _                                  | 10 ms                              | _      | If C <sub>F</sub> chosen correctly |
| Manual stable to lock time                        | t <sub>AL</sub>   | _                                  | 20 ms                              | _      | If C <sub>F</sub> chosen correctly |
| Manual acquisition time                           | t <sub>Lock</sub> | _                                  | t <sub>ACQ</sub> + t <sub>AL</sub> | _      |                                    |
| Tracking mode entry frequency tolerance           | $\Delta_{TRK}$    | 0                                  | _                                  | ± 3.6% |                                    |
| Acquisition mode entry frequency tolerance        | $\Delta_{ACQ}$    | ± 6.3%                             | _                                  | ± 7.2% |                                    |
| LOCK entry frequency tolerance                    | $\Delta_{Lock}$   | 0                                  | _                                  | ± 0.9% |                                    |
| LOCK exit frequency tolerance                     | $\Delta_{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 mode time to stable                     | t <sub>ACQ</sub>  | n <sub>ACQ</sub> /f <sub>RDV</sub> | 10 ms                              | _      | If C <sub>F</sub> chosen correctly |
| Automatic stable to lock time                     | t <sub>AL</sub>   | n <sub>TRK</sub> /f <sub>RDV</sub> | 15 ms                              | _      | If C <sub>F</sub> chosen correctly |
| Automatic lock time                               | t <sub>Lock</sub> | _                                  | t <sub>ACQ</sub> + t <sub>AL</sub> |        |                                    |

Preliminary Electrical Specifications PLL2P12M Component Specifications

## 20.14 PLL2P12M Component Specifications

| Characteristic             | Symbol           | Min | Тур                                                         | Max  | Notes                                                                                                                                                |
|----------------------------|------------------|-----|-------------------------------------------------------------|------|------------------------------------------------------------------------------------------------------------------------------------------------------|
| Crystal load capacitance   | C <sub>L</sub>   | _   | _                                                           | _    | Consult crystal manufacturer's data                                                                                                                  |
| Crystal fixed capacitance  | C <sub>1</sub>   |     | 2 x C <sub>L</sub>                                          |      | Consult crystal manufacturer's data                                                                                                                  |
| Crystal tuning capacitance | C <sub>2</sub>   | _   | 2 x C <sub>L</sub>                                          | _    | Consult crystal manufacturer's data                                                                                                                  |
| Feedback bias resistor     | R <sub>B</sub>   | _   | 22 MΩ                                                       | _    |                                                                                                                                                      |
| Series resistor            | R <sub>S</sub>   | 0   | 330 kΩ                                                      | 1 ΜΩ | Not required                                                                                                                                         |
| Filter capacitor           | C <sub>F</sub>   | I   | C <sub>FACT</sub><br>(V <sub>DDA</sub> /f <sub>XCLK</sub> ) | 1    |                                                                                                                                                      |
| Bypass capacitor           | C <sub>BYP</sub> | _   | 0.1 μF                                                      | _    | C <sub>BYP</sub> must provide low AC impedance from f = f <sub>XCLK</sub> /100 to 100 x f <sub>VCLK</sub> , so series resistance must be considered. |

## **Preliminary Electrical Specifications**

## 20.15 RAM Characteristics

| Characteristic             | Symbol           | Min | Тур | Max | Unit |
|----------------------------|------------------|-----|-----|-----|------|
| RAM data retention voltage | V <sub>RDR</sub> | 0.7 | _   | _   | V    |

### 20.16 FLASH Memory Electrical Characteristics

| Parameter               | Description                              | Min | Тур | Max | Units  |
|-------------------------|------------------------------------------|-----|-----|-----|--------|
| t <sub>Erase</sub>      | Erase time                               | 40  | 80  | 110 | ms     |
| t <sub>kill</sub>       | High voltage kill time                   | 200 | 200 | _   | μs     |
| t <sub>HVD</sub>        | Return to read mode time                 | 50  | 50  | _   | μs     |
| t <sub>Step</sub>       | Program step size                        | 0.8 | 1.0 | 1.2 | ms     |
| Pulses                  | Number of program pulses/page            | 1   | 8   | 10  | pulses |
| t <sub>HVTV</sub>       | HVEN low to VERF high time               | 50  | _   | _   | μs     |
| t <sub>VTP</sub>        | VERF high to PGM low time                | 150 | _   | _   | μs     |
| Endurance               | Erase/program cycles                     | _   | _   | 100 | cycles |
| Pump Clock<br>Frequency | Charge pump frequency for the 10 K array | 1.8 | _   | 2.5 | MHz    |

#### Advance Information — MC68HC(9)08LJ60

# Section 21. Mechanical Data

#### 21.1 Contents

| 21.2 | Introduction                     | 3 |
|------|----------------------------------|---|
| 21.3 | 160 Input/Output, BGA, Thin Map, |   |
|      | 15 x 15 Package (Case #1268)     | 4 |

#### 21.2 Introduction

This section describes the dimensions of the 100-pin quad flat pack.

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 Fax Back System (Mfax™)
  - Phone 1-602-244-6609
  - EMAIL RMFAX0@email.sps.mot.com; http://sps.motorola.com/mfax/
- Worldwide Web (wwweb) home page at http://www.mot-sps.com/cgi-bin/cases

Follow Mfax or wwweb on-line instructions to retrieve the current mechanical specifications.

## 21.3 160 Input/Output, BGA, Thin Map, 15 x 15 Package (Case #1268)



#### Advance Information — MC68HC(9)08LJ60

# Section 22. Ordering Information

#### 22.1 Contents

| 22.2 | Introduction     |     |
|------|------------------|-----|
| 22.3 | MC Order Numbers | 335 |

#### 22.2 Introduction

This section contains instructions for ordering the MC68HC908LJ60.

#### 22.3 MC Order Numbers

**Table 22-1. MC Order Numbers** 

| MC Order Number | Operating<br>Temperature Range |
|-----------------|--------------------------------|
| MC68HC08LJ60VF  | −20 to +65°C                   |
| MC68HC908LJ60VF | −20 to +65°C                   |

**Ordering Information** 

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

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

MC68HC08LJ60/D

