# 68HC908RC24 Advance Information This document contains information on a new product. Specifications and information herein are subject to change without notice. ### **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 MC68HC908RC24/D 2 MOTOROLA # **List of Sections** | Section 1. General Description23 | |-----------------------------------------------------| | Section 2. Memory Map31 | | Section 3. Random-Access Memory (RAM) | | Section 4. FLASH Memory | | Section 5. Central Processor Unit (CPU)51 | | Section 6. Resets and Interrupts | | Section 7. Low-Power Modes83 | | Section 8. Low-Voltage Inhibit (LVI)95 | | <b>Section 9. Oscillator</b> | | Section 10. Configuration Register (CONFIG) 105 | | Section 11. Input/Output Ports (I/O)109 | | Section 12. Carrier Modulator Transmitter (CMT) 119 | | Section 13. Modulo Timer (TIM0I)143 | | Section 14. External Interrupt (IRQ)153 | | Section 15. Keyboard Interrupt Module (KBI)159 | | Section 16. Computer Operating Properly (COP)167 | | Section 17. Monitor ROM (MON) | MC68HC908RC24 — Rev. 1.0 ## **List of Sections** | Section 18. Break Module (BRK) | 185 | |---------------------------------------------------|-----| | Section 19. Preliminary Electrical Specifications | 193 | | Section 20. Mechanical Specifications | 203 | | Section 21. Ordering Information | 207 | ## **Table of Contents** 5 # **Section 1. General Description** | 1.1 | Contents | |--------------------------------------------------------------------------------------|------------------------------------------------------| | 1.2 | Features | | 1.3 | MCU Block Diagram | | 1.4 | Pin Assignments | | 1.5<br>1.5.1<br>1.5.2<br>1.5.3<br>1.5.4<br>1.5.5<br>1.5.6<br>1.5.7<br>1.5.8<br>1.5.9 | $\begin{array}{cccccccccccccccccccccccccccccccccccc$ | | | Section 2. Memory Map | | 2.1 | Contents | | 2.2 | Introduction | | 2.3 | I/O Section | | 2.4 | Monitor ROM (MON) | | | Section 3. Random-Access Memory (RAM) | | 3.1 | Contents | | 3.2 | Introduction | | 3.3 | Functional Description | | 1.0 | Advance Information | MC68HC908RC24 — Rev. # **Section 4. FLASH Memory** | 4.1 | Contents | 43 | |----------------|-----------------------------------------|-----| | 4.2 | Introduction | 43 | | 4.3 | Functional Description | 43 | | 4.4 | FLASH Control Register | 44 | | 4.5 | Charge Pump Frequency Control | 46 | | 4.6 | FLASH Erase Operation | 46 | | 4.7 | FLASH Program/Verify Operation | 47 | | 4.8 | Block Protection | 49 | | 4.9 | FLASH Block Protect Register | .49 | | | 0 4' 5 0 4 10 11 '4 (001) | | | | Section 5. Central Processor Unit (CPU) | | | 5.1 | Contents | .51 | | 5.2 | Introduction | .52 | | 5.3 | Features | .52 | | 5.4 | CPU Registers | .52 | | 5.4.1 | Accumulator | | | 5.4.2<br>5.4.3 | Index Register | | | 5.4.4 | Stack Pointer | | | 5.4.5 | Condition Code Register | | | 5.5 | Arithmetic/Logic Unit (ALU) | .57 | | 5.6 | Low-Power Modes | .57 | | 5.6.1 | Wait Mode | .58 | | 5.6.2 | Stop Mode | .58 | | 5.7 | CPU During Break Interrupts | .58 | | 5.8 | Instruction Set Summary | .58 | | 5.9 | Opcode Map | 65 | Advance Information MC68HC908RC24 — Rev. 1.0 ### Section 6. Resets and Interrupts # **Table of Contents** | 7.5 | Low-Power Reset Mode | | |------------------|-------------------------------------------|---| | 7.5.1 | External Circuits | | | 7.5.2<br>7.5.3 | Low-Power Reset Operation | | | | | | | 7.6 | Central Processor Unit (CPU)8 | | | 7.6.1<br>7.6.2 | Wait Mode | | | | Stop Mode | | | 7.7 | Break Module (BRK)8 | | | 7.7.1<br>7.7.2 | Wait Mode | | | | Stop Mode | | | 7.8 | Computer Operating Properly Module (COP)8 | | | 7.8.1<br>7.8.2 | Wait Mode | | | | | | | 7.9 | External Interrupt Module (IRQ) | | | 7.9.1<br>7.9.2 | Wait Mode | | | | Stop Mode | | | 7.10 | Keyboard Interrupt Module (KBI) | | | 7.10.1<br>7.10.2 | Wait Mode | | | | Stop Mode | | | 7.11 | Low-Voltage Inhibit Module (LVI) | | | 7.11.1 | Wait Mode | | | 7.11.2 | Stop Mode | | | 7.12 | Carrier Modulator Transmitter (CMT) | | | 7.12.1 | Wait Mode | | | 7.12.2 | Stop Mode | | | 7.13 | Timer Interface Module (TIMOI) | | | 7.13.1 | Wait Mode | | | 7.13.2 | <b>'</b> | | | 7.14 | Exiting Wait Mode9 | 2 | | 7.15 | Exiting Stop Mode9 | 3 | Advance Information 8 MC68HC908RC24 — Rev. 1.0 ## Section 8. Low-Voltage Inhibit (LVI) | 8.1 | Contents | |------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 8.2 | Introduction | | 8.3 | Features | | 8.4<br>8.4.1<br>8.4.2 | Functional Description | | 8.5 | LVI Status Register98 | | 8.6 | LVI Interrupts | | 8.7<br>8.7.1<br>8.7.2 | Low-Power Modes | | | Section 9. Oscillator | | 9.1 | Contents | | 9.2 | Introduction | | | | | 9.3 | Oscillator External Connections | | 9.3<br>9.4<br>9.4.1<br>9.4.2<br>9.4.3<br>9.4.4<br>9.4.5<br>9.4.6 | Oscillator External Connections | | 9.4<br>9.4.1<br>9.4.2<br>9.4.3<br>9.4.4<br>9.4.5 | I/O Signals103Crystal Amplifier Input Pin (OSC1)103Crystal Amplifier Output Pin (OSC2)103Oscillator Enable Signal (SIMOSCEN)103External Clock Source (CGMXCLK)103Oscillator Out (CGMOUT)103 | | Section 10. Configuration Register (CONFIG) | |-------------------------------------------------| | 10.1 Contents | | 10.2 Introduction | | 10.3 Functional Description | | Section 11. Input/Output Ports (I/O) | | 11.1 Contents | | 11.2 Introduction | | 11.3 Port A | | 11.4 Port B | | 11.5 Port C | | Section 12. Carrier Modulator Transmitter (CMT) | | 12.1 Contents | | 12.2 Introduction | | 12.3 Clock Generation | | 12.4 Overview | | 12.5 Carrier Generator | | 12.6 Modulator | | 12.6.2 Baseband Mode | | 12.6.3 FSK Mode130 | | 12.6.4.1 EXSPC Operation in Time Mode | |-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 12.7 Transmitter | | 12.8 IRO Latch | | 12.9 Flags and Interrupts | | 12.10 I/O Registers | | 12.10.2 CMT Modulator Control and Status Register | | 12.11 Wait Mode Operation | | | | 12.12 Stop Mode Operation | | Section 12 Module Timer (TIMOI) | | Section 13. Modulo Timer (TIM0I) | | 13.1 Contents | | ` , | | 13.1 Contents | | 13.1 Contents | | 13.1 Contents .143 13.2 Introduction .143 13.3 Features .144 13.4 Functional Description .144 | | 13.1 Contents .143 13.2 Introduction .143 13.3 Features .144 13.4 Functional Description .144 13.4.1 TIM0I Counter Prescaler .145 | | 13.1 Contents .143 13.2 Introduction .143 13.3 Features .144 13.4 Functional Description .144 13.4.1 TIM0I Counter Prescaler .145 13.5 Interrupts .146 13.6 Low-Power Modes .146 13.6.1 Wait Mode .146 | | 13.1 Contents 143 13.2 Introduction 143 13.3 Features 144 13.4 Functional Description 144 13.4.1 TIM0I Counter Prescaler 145 13.5 Interrupts 146 13.6 Low-Power Modes 146 13.6.1 Wait Mode 146 13.6.2 Stop Mode 146 | 11 | 14.1 | Contents | |----------------------------|-----------------------------------------------| | 14.2 | Introduction | | 14.3 | Features | | 14.4 | Functional Description | | 14.5 | IRQ1 Pin 155 | | 14.6 | IRQ Module During Break Interrupts156 | | 14.7 | IRQ Status and Control Register | | | Section 15. Keyboard Interrupt Module (KBI) | | 15.1 | Contents | | 15.2 | Introduction | | 15.3 | Features | | 15.4 | Functional Description | | 15.5 | Keyboard Initialization | | 15.6<br>15.6.1<br>15.6.2 | | | 15.7 | Keyboard Module During Break Interrupts | | 15.8<br>15.8.1<br>15.8.2 | • | | | Section 16. Computer Operating Properly (COP) | | 16.1 | Contents | | 16.2 | Introduction | | 16.3 | Functional Description | | 16.4.1<br>16.4.2<br>16.4.3 | STOP Instruction | | | MC68HC908RC24 — Rev. 1.0 | Advance Information MOTOROLA | 16.4.4 Power-On Reset .170 16.4.5 Internal Reset .170 16.4.6 Reset Vector Fetch .170 16.4.7 COPD (COP Disable) .170 16.4.8 COPRS (COP Rate Select) .170 | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 16.5 COP Control Register170 | | 16.6 Interrupts | | 16.7 Monitor Mode | | 16.8 Low-Power Modes .171 16.8.1 Wait Mode .171 16.8.2 Stop Mode .171 | | 16.9 COP Module During Break Mode | | Section 17. Monitor ROM (MON) | | 17.1 Contents | | 17.2 Introduction | | 17.3 Features | | 17.4 Functional Description .174 17.4.1 Entering Monitor Mode .176 17.4.2 Data Format .177 17.4.3 Break Signal .178 17.4.4 Baud Rate .178 17.4.5 Commands .179 | | 17.5 Security | | Section 18. Break Module (BRK) | | 18.1 Contents | | 18.2 Introduction | | 18.3 Features | | 18.4 Functional Description | ## **Table of Contents** | 18.4.3<br>18.4.4 | | |----------------------------------------------|---------------------------------------------------| | 18.5<br>18.5.1<br>18.5.2 | Low-Power Modes | | 18.6<br>18.6.1<br>18.6.2<br>18.6.3<br>18.6.4 | Break Status Register191 | | 9 | Section 19. Preliminary Electrical Specifications | | 19.1 | Contents | | 19.2 | Introduction | | 19.3 | Absolute Maximum Ratings | | 19.4 | Functional Operating Range195 | | 19.5 | Thermal Characteristics | | 19.6 | 3.3-Volt DC Electrical Characteristics196 | | 19.7 | 2.0-Volt DC Electrical Characteristics197 | | 19.8 | Control Timing | | 19.9 | Oscillator Characteristics | | 19.10 | LVI Characteristics | | 19.11 | Battery Detection Characteristics200 | | 19.12 | Battery Circuit Component Specifications | | 19.13 | Memory Characteristics201 | | | Section 20. Mechanical Specifications | | 20.1 | Contents | | 20.2 | Introduction | | | | Advance Information MC68HC908RC24 — Rev. 1.0 | 20.3 | Available Packages | 204 | |--------|--------------------------------------------------|-----| | 20.3.1 | 1 28-Pin Plastic Dual In-Line Package (Case 710) | 204 | | 20.3.2 | 2 28-Pin Small Outline Package (Case 751F) | 205 | | | | | | | Section 21. Ordering Information | | | 21.1 | Contents | 207 | | 21.2 | Introduction | 207 | | 21.3 | YC Order Numbers | 207 | # **Table of Contents** # **List of Figures** | Figur | e Title | Page | |-------|-----------------------------------------|------| | 1-1 | MCU Block Diagram for the MC68HC908RC24 | 26 | | 1-2 | DIP and SOIC Pin Assignments | 27 | | 1-3 | Power Supply Bypassing | 28 | | 2-1 | Memory Map | 32 | | 2-2 | Control, Status, and Data Registers | 34 | | 4-1 | FLASH Control Register (FLCR) | 44 | | 4-2 | FLASH Block Protect Register (FLBPR) | 49 | | 5-1 | CPU Registers | 53 | | 5-2 | Accumulator (A) | 53 | | 5-3 | Index Register (H:X) | 54 | | 5-4 | Stack Pointer (SP) | 54 | | 5-5 | Program Counter (PC) | 55 | | 5-6 | Condition Code Register (CCR) | 55 | | 6-1 | Reset Block Diagram | 68 | | 6-2 | External Reset Recovery Timing | 71 | | 6-3 | Active Reset Recovery Timing | 71 | | 6-4 | Power-on Reset (POR) Recovery | 72 | | 6-5 | Reset Status Register (RSR) | 73 | | 6-6 | Interrupt Stacking Order | 76 | | 6-7 | Interrupt Recognition Example | | | 6-8 | Interrupt Processing | | | 6-9 | Interrupt Status Register 1 (INT1) | | | 6-10 | Interrupt Status Register 2 (INT2) | 82 | MC68HC908RC24 — Rev. 1.0 | 7-1 External Low-Power Circuit 85 7-2 Internal Low-Battery Detection Block Diagram 86 8-1 LVI Module Block Diagram 97 8-2 LVI Status Register (LVISR) 98 9-1 Oscillator External Connections 102 10-1 Configuration Register (CONFIG) 106 11-1 I/O Port Register Summary 110 11-2 Port A Data Register (PTA) 111 11-3 Data Direction Register A (DDRA) 111 11-4 Port A I/O Circuit 112 11-5 Port B Data Register (PTB) 113 11-6 Data Direction Register B (DDRB) 114 11-7 Port B I/O Circuit 114 11-8 Port C Data Register (PTC) 116 11-9 Data Direction Register C (DDRC) 117 11-10 Port C I/O Circuit 117 11-10 Port C I/O Circuit 118 12-1 CMT Clock Generation 121 12-2 Carrier Modulator Transmitter Module Block Diagram 125 12-4 Modulator Block Diagram 127 | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 8-1 LVI Module Block Diagram .97 8-2 LVI Status Register (LVISR) .98 9-1 Oscillator External Connections .102 10-1 Configuration Register (CONFIG) .106 11-1 I/O Port Register Summary .110 11-2 Port A Data Register (PTA) .111 11-3 Data Direction Register A (DDRA) .111 11-4 Port A I/O Circuit .112 11-5 Port B Data Register (PTB) .113 11-6 Data Direction Register B (DDRB) .114 11-7 Port B I/O Circuit .114 11-8 Port C Data Register (PTC) .116 11-9 Data Direction Register (PTC) .116 11-9 Data Direction Register C (DDRC) .117 11-10 Port C I/O Circuit .118 12-1 CMT Clock Generation .121 12-2 Carrier Modulator Transmitter Module Block Diagram .125 12-4 Modulator Block Diagram .127 | | 8-2 LVI Status Register (LVISR). .98 9-1 Oscillator External Connections. .102 10-1 Configuration Register (CONFIG). .106 11-1 I/O Port Register Summary. .110 11-2 Port A Data Register (PTA) .111 11-3 Data Direction Register A (DDRA) .111 11-4 Port A I/O Circuit. .112 11-5 Port B Data Register (PTB) .113 11-6 Data Direction Register B (DDRB) .114 11-7 Port B I/O Circuit. .114 11-8 Port C Data Register (PTC) .116 11-9 Data Direction Register C (DDRC) .117 11-10 Port C I/O Circuit. .118 12-1 CMT Clock Generation .121 12-2 Carrier Modulator Transmitter Module Block Diagram .122 12-3 Carrier Generator Block Diagram .125 12-4 Modulator Block Diagram .127 | | 9-1 Oscillator External Connections | | 10-1 Configuration Register (CONFIG). .106 11-1 I/O Port Register Summary. .110 11-2 Port A Data Register (PTA) .111 11-3 Data Direction Register A (DDRA) .111 11-4 Port A I/O Circuit. .112 11-5 Port B Data Register (PTB) .113 11-6 Data Direction Register B (DDRB) .114 11-7 Port B I/O Circuit. .114 11-8 Port C Data Register (PTC) .116 11-9 Data Direction Register C (DDRC) .117 11-10 Port C I/O Circuit. .118 12-1 CMT Clock Generation .121 12-2 Carrier Modulator Transmitter Module Block Diagram .125 12-4 Modulator Block Diagram .127 | | 11-1 I/O Port Register Summary. .110 11-2 Port A Data Register (PTA) .111 11-3 Data Direction Register A (DDRA) .111 11-4 Port A I/O Circuit. .112 11-5 Port B Data Register (PTB) .113 11-6 Data Direction Register B (DDRB) .114 11-7 Port B I/O Circuit. .114 11-8 Port C Data Register (PTC) .116 11-9 Data Direction Register C (DDRC) .117 11-10 Port C I/O Circuit. .118 12-1 CMT Clock Generation .121 12-2 Carrier Modulator Transmitter Module Block Diagram .122 12-3 Carrier Generator Block Diagram .125 12-4 Modulator Block Diagram .127 | | 11-2 Port A Data Register (PTA) .111 11-3 Data Direction Register A (DDRA) .111 11-4 Port A I/O Circuit .112 11-5 Port B Data Register (PTB) .113 11-6 Data Direction Register B (DDRB) .114 11-7 Port B I/O Circuit .114 11-8 Port C Data Register (PTC) .116 11-9 Data Direction Register C (DDRC) .117 11-10 Port C I/O Circuit .118 12-1 CMT Clock Generation .121 12-2 Carrier Modulator Transmitter Module Block Diagram .122 12-3 Carrier Generator Block Diagram .125 12-4 Modulator Block Diagram .127 | | 11-3 Data Direction Register A (DDRA) .111 11-4 Port A I/O Circuit .112 11-5 Port B Data Register (PTB) .113 11-6 Data Direction Register B (DDRB) .114 11-7 Port B I/O Circuit .114 11-8 Port C Data Register (PTC) .116 11-9 Data Direction Register C (DDRC) .117 11-10 Port C I/O Circuit .118 12-1 CMT Clock Generation .121 12-2 Carrier Modulator Transmitter Module Block Diagram .122 12-3 Carrier Generator Block Diagram .125 12-4 Modulator Block Diagram .127 | | 11-4 Port A I/O Circuit. 112 11-5 Port B Data Register (PTB) 113 11-6 Data Direction Register B (DDRB) 114 11-7 Port B I/O Circuit. 114 11-8 Port C Data Register (PTC) 116 11-9 Data Direction Register C (DDRC) 117 11-10 Port C I/O Circuit. 118 12-1 CMT Clock Generation 121 12-2 Carrier Modulator Transmitter Module Block Diagram 122 12-3 Carrier Generator Block Diagram 125 12-4 Modulator Block Diagram 127 | | 11-5 Port B Data Register (PTB) 113 11-6 Data Direction Register B (DDRB) 114 11-7 Port B I/O Circuit 114 11-8 Port C Data Register (PTC) 116 11-9 Data Direction Register C (DDRC) 117 11-10 Port C I/O Circuit 118 12-1 CMT Clock Generation 121 12-2 Carrier Modulator Transmitter Module Block Diagram 122 12-3 Carrier Generator Block Diagram 125 12-4 Modulator Block Diagram 127 | | 11-6 Data Direction Register B (DDRB) | | 11-7 Port B I/O Circuit | | 11-8Port C Data Register (PTC) | | 11-9Data Direction Register C (DDRC) | | 11-10 Port C I/O Circuit | | 12-1 CMT Clock Generation | | 12-2 Carrier Modulator Transmitter Module Block Diagram | | 12-3 Carrier Generator Block Diagram | | 12-4 Modulator Block Diagram | | | | 12-5 CMT Operation in Time Made | | 12-5 CMT Operation in Time Mode | | 12-6 Extended Space Operation131 | | 12-7 CMT Carrier Generator Data Register | | (CCH1, CCL1, CCH2, and CCL2) | | 12-8 CMT Modulator Control and Status Register (CMCS) 138 | | 12-9 CMT Modulator Data Registers | | (CMD1, CMD2, and CMD3)141 | | 13-1 TIM0I Block Diagram | | 13-2 TIM0I Status and Control Register (TSC)148 | | 13-3 TIM0I Counter Registers (TCNTH and TCNTL) | | Advance Information MC68HC908RC24 — Rev. 1.0 | | Figur | e Title | Page | |-------|--------------------------------------------------|------| | 13-4 | TIM0I Counter Modulo Registers (TMODH and TMODL) | 151 | | | | | | 14-1 | IRQ Module Block Diagram | | | 14-2 | IRQ Status and Control Register (ISCR) | 157 | | 15-1 | Keyboard Module Block Diagram | 160 | | 15-2 | Keyboard Module I/O Register Summary | | | 15-3 | Keyboard Status and Control Register (KBSCR) | | | 15-4 | Keyboard Interrupt Enable Register (KBIER) | | | 16-1 | COP Block Diagram | 168 | | 16-2 | COP Control Register (COPCTL) | | | 17-1 | Monitor Mode Circuit | 175 | | 17-2 | Monitor Data Format. | | | 17-3 | Break Transaction. | | | 17-4 | Read Transaction | | | 17-5 | Write Transaction | | | 17-6 | Stack Pointer at Monitor Mode Entry | | | 17-7 | Monitor Mode Entry Timing | | | 18-1 | Break Module Block Diagram | 187 | | 18-2 | Break Module Register Summary | | | 18-3 | Break Status and Control Register (BSCR) | | | 18-4 | Break Address Registers (BRKH and BRKL) | | | 18-5 | Break Status Register (BSR) | | | 18-6 | Break Flag Control Register (BFCR) | | # List of Figures ## **List of Tables** | Table | Title | Page | |----------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------| | 2-1 | Vector Addresses | 39 | | 4-1<br>4-2 | Charge Pump Clock Frequency | | | 5-1<br>5-2 | Instruction Set Summary | | | 6-1<br>6-2 | Interrupt Sources | | | 8-1 | LVI Digital Filter Characteristics | 97 | | 11-1<br>11-2<br>11-3 | Port A Pin Functions | 115 | | 12-1<br>12-2 | System Clock Examples CMT Modes of Operation | | | 13-1<br>13-2 | TIM0I Register Summary | | | 17-1<br>17-2<br>17-3<br>17-4<br>17-5<br>17-6 | Monitor Mode Entry Mode Differences Monitor Baud Rate Selection READ (Read Memory) Command WRITE (Write Memory) Command IREAD (Indexed Read) Command | 177<br>178<br>180<br>180 | MC68HC908RC24 — Rev. 1.0 # List of Tables | Table | Title | Page | |-------|-------------------------------------|------| | 17-7 | IWRITE (Indexed Write) Command | 181 | | 17-8 | READSP (Read Stack Pointer) Command | 182 | | 17-9 | RUN (Run User Program) Command | 182 | | 21-1 | XC Order Numbers | .207 | # **Section 1. General Description** ### 1.1 Contents | 1.2 | Features | |-------|---------------------------------------------------| | 1.3 | MCU Block Diagram | | 1.4 | Pin Assignments27 | | 1.5 | Pin Functions | | 1.5.1 | V <sub>DD</sub> and V <sub>SS</sub> | | 1.5.2 | BATT28 | | 1.5.3 | External Interrupt Pin (IRQ1) | | 1.5.4 | OSC1 and OSC2 | | 1.5.5 | RST | | 1.5.6 | IRO29 | | 1.5.7 | Port A Input/Output Pins (PTA7–PTA0) | | 1.5.8 | Port B Input/Output Pins (PTB7/KBD7-PTB0/KBD0) 30 | | 1.5.9 | Port C Input/Output Pins (PTC7–PTC0)30 | #### 1.2 Features #### Features of the MC68HC908RC24 include: - High performance M68HC08 architecture - Fully upward-compatible object code with M6805, M146805, and M68HC05 Families - 8-MHz maximum oscillator frequency at 2.0-volt supply - 24,064 byes of on-chip FLASH memory - On-chip programming firmware for use with host personal computer - FLASH memory data security<sup>(1)</sup> - 352 bytes of on-chip random-access memory (RAM) - Low-voltage inhibit (LVI) module: - 1.8-V detection forces the microprocessor unit (MCU) into low-power state - 2.0-V detection sets indicator flag - Low-power design, fully static with low-power reset, stop, and wait modes - Battery removal detection circuits - Computer operating properly (COP) watchdog resets - Carrier modulator transmitter (CMT) supporting baseband, pulse length modulator (PLM), and frequency shift keying (FSK) protocols - 16-bit, modulo timer module (TIM0I) Advance Information MC68HC908RC24 — Rev. 1.0 <sup>1.</sup> No security feature is absolutely secure. However, Motorola's strategy is to make reading or copying the FLASH difficult for unauthorized users. - Available packaging: - 28-pin plastic dual in-line package (PDIP) - 28-pin small-outline integrated circuit package (SOIC) - 20 bidirectional input/output (I/O) lines - 8-bit keyboard wakeup port - High-current infrared (IR) drive pin (IRO) - High-current port pins (PC0–PC3) #### Features of the CPU08 include: - Enhanced HC05 programming model - Extensive loop control functions - 16 addressing modes (eight more than the HC05) - 16-bit index register and stack pointer - Memory-to-memory data transfers - Fast 8 × 8 multiply instruction - Fast 16/8 divide instruction - Binary-coded decimal (BCD) instructions - Optimization for controller applications - Third party C language support ### 1.3 MCU Block Diagram Figure 1-1 shows the structure of the MC68HC908RC24. Figure 1-1. MCU Block Diagram for the MC68HC908RC24 ### 1.4 Pin Assignments Figure 1-2 shows the pin assignments for both the DIP and SOIC packages. Figure 1-2. DIP and SOIC Pin Assignments #### 1.5 Pin Functions This section provides a brief description of the pin functions. Where applicable, references are made to other sections for more detailed information. ### 1.5.1 $V_{DD}$ and $V_{SS}$ $V_{DD}$ is the supply node for the MCU. Under normal operation, power is supplied to $V_{DD}$ from the BATT pin through an internal MOSFET device. When the battery is removed, power is temporarily supplied from an external electrolytic capacitor through $V_{DD}$ . $V_{SS}$ is ground. Fast signal transitions on MCU pins place high, short-duration current demands on the power supply. To prevent noise problems, take special care to provide power supply bypassing at the MCU as Figure 1-3 shows. Place the $C_{VBYP}$ and $C_{BATT}$ bypass capacitors as close to the MCU as possible. Use a high-frequency-response ceramic capacitor for $C_{VBYP}$ and $C_{BATT}$ . $C_{VBULK}$ is used for bulk current requirements in applications that require the port pins to source high current levels during normal operation. $C_{VBULK}$ is also used for RAM retention when batteries are removed. Note: Component values shown represent typical applications. Figure 1-3. Power Supply Bypassing #### 1.5.2 BATT The voltage on BATT is passed to V<sub>DD</sub> through an internal P-channel MOSFET transistor and supplies power to the MCU. This pin also detects battery removal and insertion. See **Section 7. Low-Power Modes**. ### 1.5.3 External Interrupt Pin (IRQ1) IRQ1 is an asynchronous external interrupt pin. See Section 14. External Interrupt (IRQ). **NOTE:** The IRQ circuits are powered by the chip $V_{DD}$ . External circuits should drive the pin between $V_{DD}$ and $V_{SS}$ levels. If external circuits use a pullup device on $\overline{IRQ1}$ , the pin must be pulled to $V_{DD}$ and **not** to BATT. #### 1.5.4 OSC1 and OSC2 The OSC1 and OSC2 pins are the connections for the on-chip oscillator circuit. See **Section 8. Low-Voltage Inhibit (LVI)**. #### 1.5.5 **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. Resets and Interrupts**. **NOTE:** The reset circuits are powered by the chip $V_{DD}$ . External circuits should drive the pin through a resistor between $V_{DD}$ and $V_{SS}$ levels. If external circuits use a pullup device on $\overline{RST}$ , the pin must be pulled to $V_{DD}$ and **not** to BATT. #### 1.5.6 IRO The IRO pin is the high-current source and sink output of the carrier modulator transmitter (CMT) subsystem which is suitable for driving infrared (IR) light-emitting diode (LED) biasing logic. See **Section 12. Carrier Modulator Transmitter (CMT)**. ### 1.5.7 Port A Input/Output Pins (PTA7–PTA0) PTA7–PTA0 are general-purpose bidirectional I/O port pins. See **Section 11. Input/Output Ports (I/O)**. MC68HC908RC24 — Rev. 1.0 ### 1.5.8 Port B Input/Output Pins (PTB7/KBD7-PTB0/KBD0) PTB7/KBD7–PTB0/KBD0 are general-purpose bidirectional I/O port pins. Any or all of the port B lines can be programmed to serve as external interrupt pins with internal pullups. See **Section 11**. **Input/Output Ports (I/O)**. ### 1.5.9 Port C Input/Output Pins (PTC7-PTC0) PTC7–PTC0 are general-purpose bidirectional I/O port pins. PTC3–PTC0 have high-current drive capability. The state of any pin is software programmable and all port C lines are configured as input during power-on or reset. See **Section 11. Input/Output Ports (I/O)**. **NOTE:** On 28-pin package parts, PTC7–PTC4 pads are not bonded out. Set these ports to outputs after any reset to avoid floating inputs. Any unused inputs and I/O ports should be tied to an appropriate logic level (either $V_{DD}$ or $V_{SS}$ ). Although the I/O ports of the MC68HC908RC24 do not require termination, termination is recommended to reduce the possibility of static damage. # **Section 2. Memory Map** ### 2.1 Contents | 2.2 | Introduction | .31 | |-----|-------------------|-----| | 2.3 | I/O Section | .33 | | 2.4 | Monitor ROM (MON) | .39 | ### 2.2 Introduction The CPU08 can address 64 Kbytes of memory space. The memory map, shown in **Figure 2-1**, includes: - 24,064 bytes of FLASH memory - 352 bytes of random-access memory (RAM) - 12 bytes of user-defined vectors - 240 bytes of monitor ROM (MON) 31 | \$0000 | I/O REGISTERS | |--------------|------------------------------------------| | \$001F | 32 BYTES | | \$0020 | RAM | | ↓<br>\$017F | 352 BYTES | | \$0180 | UNIMPLEMENTED | | ↓<br>\$9FFF | 40,576 BYTES | | \$A000 | | | , \ | FLASH MEMORY<br>24,064 BYTES | | \$FDFF | · | | \$FE00 | BREAK STATUS REGISTER (BSR) | | \$FE01 | RESET STATUS REGISTER (RSR) | | \$FE02 | RESERVED | | \$FE03 | BREAK FLAG CONTROL REGISTER (BFCR) | | \$FE04 | INTERRUPT STATUS REGISTER 1 (INT1) | | \$FE05<br>↓ | RESERVED | | \$FE08 | 4 BYTES | | \$FE09 | FLASH CONTROL REGISTER (FLCR) | | \$FE0A<br>↓ | RESERVED | | ↓<br>\$FE0B | 2 BYTES | | \$FE0C | BREAK ADDRESS HIGH REGISTER (BRKH) | | \$FE0D | BREAK ADDRESS LOW REGISTER (BRKL) | | \$FE0E | BREAK STATUS AND CONTROL REGISTER (BSCR) | | \$FE0F | RESERVED | | \$FE10 | MONITOR ROM | | ↓<br>\$FEFF | 240 BYTES | | \$FF00 | LINUMPLEMENTED | | $\downarrow$ | UNIMPLEMENTED<br>128 BYTES | | \$FF7F | FLACULDI COM PROTECT DECICTED (FLADD) | | \$FF80 | FLASH BLOCK PROTECT REGISTER (FLBPR) | | \$FF81<br>↓ | UNIMPLEMENTED | | \$FFF3 | 115 BYTES | | \$FFF4 | FLASH VECTORS | | \$FFFE | 12 BYTES | | \$FFFF | COP CONTROL REGISTER (COPCTL) | | | | Figure 2-1. Memory Map Advance Information MC68HC908RC24 — Rev. 1.0 #### 2.3 I/O Section Most of the control, status, and data registers are in the zero page area of \$0000–\$001F. Additional input/output (I/O) registers have these addresses: - \$FE00 Break status register, BSR - \$FE01 Reset status register, RSR - \$FE03 Break flag control register, BFCR - \$FE04 Interrupt status register 1, INT1 - \$FE09 FLASH control register, FLCR - \$FE0C and \$FE0D Break address registers, BRKH and BRKL - \$FE0E Break status and control register, BSCR - \$FF80 FLASH block protection register, FLBPR, in non-volatile FLASH memory - \$FFFF Computer operating properly (COP) control register, COPCTL Note: DDRC7–DDRC4 are not available. Set DDRC7–DDRC4 to 1 on 28-pin packages as described in 11.5 Port C. Figure 2-2. Control, Status, and Data Registers (Sheet 1 of 5) Advance Information MC68HC908RC24 — Rev. 1.0 Figure 2-2. Control, Status, and Data Registers (Sheet 2 of 5) Figure 2-2. Control, Status, and Data Registers (Sheet 3 of 5) Advance Information MC68HC908RC24 — Rev. 1.0 Figure 2-2. Control, Status, and Data Registers (Sheet 4 of 5) MC68HC908RC24 — Rev. 1.0 Figure 2-2. Control, Status, and Data Registers (Sheet 5 of 5) Advance Information MC68HC908RC24 — Rev. 1.0 Table 2-1 is a list of vector locations. **Table 2-1. Vector Addresses** # 2.4 Monitor ROM (MON) The 240 bytes at addresses \$FE10-\$FEFF are reserved ROM addresses that contain the instructions for the monitor functions. # **Memory Map** # Section 3. Random-Access Memory (RAM) #### 3.1 Contents | 3.2 | Introduction4 | 1 | |-----|------------------------|------------| | 3.3 | Functional Description | <b>ļ</b> 1 | #### 3.2 Introduction This section describes the 352 bytes of random-access memory (RAM). # 3.3 Functional Description Addresses \$0020–\$017F 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 correct operation, the stack pointer must point only to RAM locations. Within page zero are 224 bytes of RAM. Because the location of the stack RAM is programmable, all page zero RAM locations can be used for input/output (I/O) control and user data or code. When the stack pointer is moved from its reset location at \$00FF out of page zero, direct addressing mode instructions can efficiently access all page zero RAM locations. Page zero RAM, therefore, provides ideal locations for frequently accessed global variables. Before processing an interrupt, the central processor unit (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. MC68HC908RC24 — 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. # **Section 4. FLASH Memory** #### 4.1 Contents | 4.2 | Introduction | .43 | |-----|--------------------------------|-----| | 4.3 | Functional Description | .43 | | 4.4 | FLASH Control Register | .44 | | 4.5 | Charge Pump Frequency Control | .46 | | 4.6 | FLASH Erase Operation | .46 | | 4.7 | FLASH Program/Verify Operation | .47 | | 4.8 | Block Protection | .49 | | 4.9 | FLASH Block Protect Register | .49 | ### 4.2 Introduction This section describes the operation of the embedded FLASH memory. This memory can be read, programmed, and erased. An internal supply is used for program and erase. # 4.3 Functional Description The FLASH memory is an array of 24,064 bytes with an additional 12 bytes of user vectors and one byte of block protection. 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. MC68HC908RC24 — Rev. 1.0 FLASH locations are in the ranges: - \$A000–\$FDFF User memory - \$FF80 Block protect register, FLBPR - \$FFF4-\$FFF Reserved for user-defined interrupt and reset vectors For availability of programming tools and more information, contact a local Motorola representative. **NOTE:** A security feature prevents viewing of the FLASH contents. (1) ## 4.4 FLASH Control Register The FLASH control register (FLCR) controls FLASH program, erase, and verify operations. Figure 4-1. FLASH Control Register (FLCR) #### FDIV1 — Frequency Divide Control Bit This read/write bit together with FDIV0 selects the factor by which the charge pump clock is divided from the system clock. See **4.5 Charge Pump Frequency Control**. #### FDIVO — Frequency Divide Control Bit This read/write bit together with FDIV1 selects the factor by which the charge pump clock is divided from the system clock. See **4.5 Charge Pump Frequency Control**. Advance Information MC68HC908RC24 — Rev. 1.0 <sup>1.</sup> No security feature is absolutely secure. However, Motorola's strategy is to make reading or copying the FLASH difficult for unauthorized users. #### BLK1— Block Erase Control Bit This read/write bit together with BLK0 allows erasing of blocks of varying size. See **4.6 FLASH Erase Operation** for a description of available block sizes. #### BLK0 — Block Erase Control Bit This read/write bit together with BLK1 allows erasing of blocks of varying size. See **4.6 FLASH Erase Operation** for a description of available block sizes. ## 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 be set only if either PGM or ERASE is high and the sequence for erase or program/verify is followed. - 1 = High voltage enabled to array and charge pump on - 0 = High voltage disabled to array and charge pump off #### VERF — Verify Control Bit This read/write bit configures the memory for verify operation. It cannot be set if the HVEN bit is high, and if it is high when HVEN is set, it will automatically return to 0. - 1 = Verify operation selected - 0 = Verify 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 equal to 1 or 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 ## 4.5 Charge Pump Frequency Control The internal charge pump is designed to operate at greatest efficiency at a frequency of 2 MHz. **Table 4-1** shows how the FDIV bits are used to select a charge pump frequency and the recommended bus frequency ranges for each configuration. Program and erase operations cannot be performed if the pump clock frequency is below 2 MHz. FDIV1 FDIV0 **Pump Clock Frequency** Use When Bus Frequency is 0 0 Bus frequency + 1 2 MHz ± 10% 0 Bus frequency ÷ 2 4 MHz ± 10% 1 0 Bus frequency ÷ 2 $4 \text{ MHz} \pm 10\%$ 1 1 Bus frequency ÷ 4 $8 \text{ MHz} \pm 10\%$ Table 4-1. Charge Pump Clock Frequency ## 4.6 FLASH Erase Operation Use this step-by-step procedure to erase a block of FLASH memory. Values for the time parameters are specified in 19.13 Memory Characteristics. - Set the ERASE bit and the BLK0 and BLK1 bits in the FLASH control register. See Table 4-2 for block sizes. - 2. Read from the block protect register: address \$FF80. - 3. Write to any FLASH address with any data within the block address range desired. - 4. Set the HVEN bit. - 5. Wait for a time, t<sub>Frase</sub>. - Clear the HVEN bit. - 7. Wait for a time, t Kill, for the high voltages to dissipate. - 8. Clear the ERASE bit. - 9. After a time, t<sub>HVD</sub>, the memory can be accessed in read mode again. **NOTE:** While these operations must be performed in the order shown, other unrelated operations may occur between the steps. **Table 4-2** shows the various block sizes which can be erased in one erase operation. BLK1 BLK0 Block Size, Addresses Cared 0 0 Full array: 24 Kbytes 0 1 Half array: 8 or 16 Kbytes (A14) 1 0 Eight rows: 512 bytes (A14–A9) 1 1 Single row: 64 bytes (A14–A6) Table 4-2. Erase Block Sizes In step 3 of the erase operation, the cared addresses are latched and used to determine the location of the block to be erased. For the full array (BLK1 = BLK0 = 0), the only requirement is that the FLASH memory be selected. Writing to any address in the range \$A000 to \$FDFF or the vectors in the address range \$FFF4 to \$FFFF will enable the full array erase. In the half array case (BLK1 = 0, BLK0 = 1), the state of A14 determines whether the range \$A000 to \$FFFF is erased (A14 = 0) or the range from \$C000 to \$FFFF (A14 = 1) is erased. # 4.7 FLASH Program/Verify Operation Programming of the FLASH memory is done on a page basis. A page consists of eight consecutive bytes starting from address \$XXX0 or \$XXX8. The purpose of the verify mode is to ensure that data has been programmed with sufficient margin for long-term data retention. During verify, the control gates of the selected memory bits are held at a slightly negative voltage by an internal charge pump. Reading the data 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. A verify can only follow a program operation. Execute these steps to program and verify the FLASH memory. Values for the time parameters are specified in 19.13 Memory Characteristics. - Set the PGM bit. This configures the memory for program operation and enables the latching of address and data for programming. - 2. Read from the block protect register. - 3. Write data to the eight bytes of the page being programmed. This requires eight separate write operations. - 4. Set the HVEN bit. - 5. Wait for a time, t<sub>Step</sub>. - 6. Clear the HVEN bit. - 7. Wait for a time, t<sub>HVTV</sub>. - 8. Set the VERF bit. - 9. Wait for a time, $t_{VTP}$ . - 10. Clear the PGM bit. - 11. Wait for a time, t<sub>HVD</sub>. - 12. Read back data in verify mode. This is done in eight separate read operations which are each stretched by eight cycles. - 13. Clear the VERF bit. - After a time, t<sub>Recovery</sub>, the memory can be accessed in read mode again. **NOTE:** While these operations must be performed in the order shown, other unrelated operations may occur between the steps. This program/verify sequence is repeated throughout the memory until all data is programmed. For minimum overall programming time and least program disturb effect, the sequence should be part of an intelligent operation which iterates per page (see **4.6 FLASH Erase Operation**). #### 4.8 Block Protection Due to 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 due to system malfunction. This protection is done by reserving a location in the memory for block protect information and requiring that this location be read from to enable setting of the HVEN bit. When the block protect register is read, its contents are latched by the FLASH control logic. 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 erased (all 0s), 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.9 FLASH Block Protect Register**. The presence of a voltage $V_{TST}$ on the $\overline{IRQ1}$ pin will bypass the block protection so that all of the memory, including the block protect register, is open for program and erase operations. # 4.9 FLASH Block Protect Register The block protect register (FLBPR) is implemented as a byte within the FLASH memory. The erased state is logical 0. Each bit, when programmed, protects a range of addresses in the FLASH. Figure 4-2. FLASH Block Protect Register (FLBPR) #### BPR3 — Block Protect Register Bit 3 This bit protects the memory contents in the address range \$C000 to \$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 to \$FFFF. - 1 = Address range protected from erase or program - 0 = Address range open to erase or program #### BPR1 — Block Protect Register Bit 1 In a larger memory this bit would protect the memory contents in the address range \$9000 to \$FFFF. It is redundant in this implementation. Setting this bit locks everything from \$A000 to \$FFFF. - 1 = Address range protected from erase or program - 0 = Address range open to erase or program #### BPR0 — Block Protect Register Bit 0 In a larger memory this bit would protect the memory contents in the address range \$8000 to \$FFFF. It is redundant in this implementation. Setting this bit locks everything from \$A000 to \$FFFF. - 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 bit 3 and bit 2 are set, for instance, the address range \$A000 through \$FFFF is locked. If all bits are erased, then all of the memory is available for erase and program. The presence of a voltage V<sub>TST</sub> on the IRQ1 pin will bypass the block protection so that all of the memory, including the block protect register, is open for program and erase operations. # **Section 5. Central Processor Unit (CPU)** ## 5.1 Contents | 6.2 | Introduction | |------------------------------|------------------------------------------------------------------------------------| | 6.3 | Features | | 6.4<br>6.4.1<br>6.4.2 | CPU Registers | | 6.4.3<br>6.4.4<br>6.4.5 | Stack Pointer | | | | | 6.5 | Arithmetic/Logic Unit (ALU)57 | | 6.5<br>6.6<br>6.6.1<br>6.6.2 | Arithmetic/Logic Unit (ALU) .57 Low-Power Modes .57 Wait Mode .58 Stop Mode .58 | | 6.6<br>6.6.1 | Low-Power Modes | | 6.6<br>6.6.1<br>6.6.2 | Low-Power Modes | ## **Central Processor Unit (CPU)** #### 5.2 Introduction 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. #### 5.3 Features #### Features of the CPU include: - Object code fully upward-compatible with M68HC05 Family - 16-bit stack pointer with stack manipulation instructions - 16-bit index register with X-register manipulation instructions - 8-MHz CPU internal bus frequency - 64-Kbyte program/data memory space - 16 addressing modes - Memory-to-memory data moves without using accumulator - Fast 8-bit by 8-bit multiply and 16-bit by 8-bit divide instructions - Enhanced binary-coded decimal (BCD) data handling - Modular architecture with expandable internal bus definition for extension of addressing range beyond 64 Kbytes - Low-power stop and wait modes ## 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 #### 5.4.1 Accumulator The accumulator 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. MC68HC908RC24 — Rev. 1.0 ## **Central Processor Unit (CPU)** The index register can serve also as a temporary data storage location. Figure 5-3. Index Register (H:X) #### 5.4.3 Stack Pointer The stack pointer 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:** For correct operation, the stack pointer must point only to RAM locations. Advance Information 54 ### 5.4.4 Program Counter The program counter 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) ### 5.4.5 Condition Code Register The 8-bit condition code register 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) MC68HC908RC24 — Rev. 1.0 ## **Central Processor Unit (CPU)** #### 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 add-without-carry (ADD) or add-with-carry (ADC) operation. The half-carry flag is required for binary-coded decimal (BCD) arithmetic operations. The DAA instruction uses the states of the H and C flags to determine the appropriate correction factor. - 1 = Carry between bits 3 and 4 - 0 = No carry between bits 3 and 4 #### I — Interrupt Mask 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 produce a result of \$00. - 1 = Zero result - 0 = Non-zero result ## 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 order number CPU08RM/AD, for a description of the instructions and addressing modes and more detail about the architecture of the CPU. #### 5.6 Low-Power Modes The WAIT and STOP instructions put the MCU in low power-consumption standby modes. ## **Central Processor Unit (CPU)** #### 5.6.1 Wait Mode #### The WAIT instruction: - Clears the interrupt mask (I bit) in the condition code register, enabling interrupts. After exit from wait mode by interrupt, the I bit remains clear. After exit by reset, the I bit is set. - Disables the CPU clock ### 5.6.2 Stop Mode #### The STOP instruction: - Clears the interrupt mask (I bit) in the condition code register, enabling external interrupts. After exit from stop mode by external interrupt, the I bit remains clear. After exit by reset, the I bit is set. - Disables the CPU clock After exiting stop mode, the CPU clock begins running after the oscillator stabilization delay. ## 5.7 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 18. Break Module (BRK)**.) 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. ## 5.8 Instruction Set Summary Table 5-1 provides a summary of the M68HC08 instruction set. Table 5-1. Instruction Set Summary (Sheet 1 of 7) | Source<br>Form | Operation | | | Eff | | | | Address<br>Mode | Opcode | Operand | Cycles | | |----------------------------------------------------------------------------------------------------|------------------------------------------------------|--------------------------------------------------------|----------|----------|---|----------|----------|-----------------|----------------------------------------------------------------------------------------------|--------------------------------------------------|-------------------------------------------------|--------------------------------------| | Form | · | - | ٧ | Н | ı | N | Z | С | Add | obdo | do | S | | ADC #opr<br>ADC opr<br>ADC opr,<br>ADC opr,X<br>ADC opr,X<br>ADC opr,X<br>ADC opr,SP<br>ADC opr,SP | Add with Carry | A ← (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 | 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 | | ADD #opr<br>ADD opr<br>ADD opr,X<br>ADD opr,X<br>ADD opr,X<br>ADD ,X<br>ADD opr,SP<br>ADD opr,SP | Add without Carry | A ← (A) + (M) | <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 ≪ M) | - | - | - | - | - | - | IMM | A7 | ii | 2 | | AIX #opr | Add Immediate Value (Signed) to H:X | H:X ← (H:X) + (16 ≪ M) | - | - | - | - | - | - | IMM | AF | ii | 2 | | AND #opr<br>AND opr<br>AND opr<br>AND opr,X<br>AND opr,X<br>AND ,X<br>AND opr,SP<br>AND opr,SP | Logical AND | A ← (A) & (M) | 0 | _ | _ | <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) | C ← 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<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 | | BGT opr | Branch if Greater Than (Signed Operands) | $PC \leftarrow (PC) + 2 + rel? (Z) (N \oplus V) = 0$ | _ | _ | - | _ | _ | _ | REL | 92 | rr | 3 | MC68HC908RC24 — Rev. 1.0 # **Central Processor Unit (CPU)** Table 5-1. Instruction Set Summary (Sheet 2 of 7) | Source<br>Form | Operation | | | | ec | | | Address<br>Mode | Opcode | Operand | Cycles | | |------------------------------------------------------------------------------------------------|---------------------------------------------------|-------------------------------------------------------|---|---|----|----------|----------|-----------------|----------------------------------------------------------------------------------------------|--------------------------------------------------|----------------------------------------------------------------------|--------------------------------------| | Form | | - | ٧ | Н | ı | N | Z | С | Add | do | odo | ပိ | | 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 (Same as BCC) | PC ← (PC) + 2 + rel ? (C) = 0 | _ | _ | - | - | - | _ | REL | 24 | rr | 3 | | BIH rel | Branch if IRQ Pin High | PC ← (PC) + 2 + rel? <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,<br>BIT opr,X<br>BIT opr,X<br>BIT,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<br>9ED5 | | 2<br>3<br>4<br>4<br>3<br>2<br>4<br>5 | | BLE opr | Branch if Less Than or Equal To (Signed Operands) | $PC \leftarrow (PC) + 2 + 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 ← (PC) + 2 + rel ? (N ⊕ V) =1 | - | - | - | - | - | - | REL | 91 | rr | 3 | | BMC rel | Branch if Interrupt Mask Clear | PC ← (PC) + 2 + rel? (I) = 0 | - | - | - | - | - | - | REL | 2C | rr | 3 | | BMI rel | Branch if Minus | PC ← (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 + rel? (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 n in M Set | PC ← (PC) + 3 + rel? (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 | Table 5-1. Instruction Set Summary (Sheet 3 of 7) | Source<br>Form | Operation | Description | | | | ec | | | Address<br>Mode | Opcode | Operand | les | |-------------------------------------------------------------------------------------------------------|-------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|---|---|-----------|----------|-----------|----------------------------------------------------------------------------------------------|--------------------------------------------------|-------------------------------------------------|--------------------------------------| | FOIII | | | ٧ | Н | I | N | Z | С | Adc | odo | o | Cycles | | BSET n,opr | Set Bit <i>n</i> in M | Mn ← 1 | _ | _ | _ | _ | _ | _ | DIR (b0)<br>DIR (b1)<br>DIR (b2)<br>DIR (b3)<br>DIR (b4)<br>DIR (b5)<br>DIR (b6)<br>DIR (b7) | 10<br>12<br>14<br>16<br>18<br>1A<br>1C | 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<br>4<br>4<br>5<br>4<br>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}{c} 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> | <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>9ED1 | ii<br>dd<br>hh II<br>ee ff<br>ff<br>ee ff | 2<br>3<br>4<br>4<br>3<br>2<br>4<br>5 | | COM opr<br>COMA<br>COMX<br>COM opr,X<br>COM ,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) \\ M \leftarrow (\overline{M}) = \$FF - (M) \\ M \leftarrow (\overline{M}) = \$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> | _ | _ | <b>‡</b> | \$ | <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> | <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>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 | | | l . | l . | | | | | | | | | | | MC68HC908RC24 — Rev. 1.0 # **Central Processor Unit (CPU)** Table 5-1. Instruction Set Summary (Sheet 4 of 7) | Source | Operation | Description | | | | ec | | | 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 + rel? \text{ (result)} \neq 0 \\ PC \leftarrow (PC) + 2 + rel? \text{ (result)} \neq 0 \\ PC \leftarrow (PC) + 2 + rel? \text{ (result)} \neq 0 \\ PC \leftarrow (PC) + 3 + rel? \text{ (result)} \neq 0 \\ PC \leftarrow (PC) + 2 + rel? \text{ (result)} \neq 0 \\ PC \leftarrow (PC) + 2 + rel? \text{ (result)} \neq 0 \\ PC \leftarrow (PC) + 4 + 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>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 | $ \begin{array}{c} PC \leftarrow (PC) + n (n = 1, 2, \mathrm{or} 3) \\ Push (PCL); SP \leftarrow (SP) - 1 \\ Push (PCH); SP \leftarrow (SP) - 1 \\ PC \leftarrow Unconditional Address \end{array} $ | _ | _ | _ | _ | _ | _ | DIR<br>EXT<br>IX2<br>IX1<br>IX | BD<br>CD<br>DD<br>ED<br>FD | dd<br>hh II<br>ee ff<br>ff | 4<br>5<br>6<br>5<br>4 | | LDA #opr<br>LDA opr<br>LDA opr,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) | 0 | _ | _ | <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<br>9ED6 | 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) | 0 | - | - | \$ | <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 ,X<br>LDX opr,SP<br>LDX opr,SP | Load X from M | X ← (M) | 0 | _ | _ | <b>‡</b> | <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 | Advance Information MC68HC908RC24 — Rev. 1.0 Table 5-1. Instruction Set Summary (Sheet 5 of 7) | Source<br>Form | Operation | Description | | | | ec<br>CC | | | Address<br>Mode | Opcode | Operand | les | |-----------------------------------------------------------------------------------------------|-------------------------------------|----------------------------------------------------------------------------------------|----------|---|----------|----------|----------|---------------------------------------|-----------------------------------------------------|--------------------------------------------------|----------------------------|--------------------------------------| | Form | | • | ٧ | Н | I | N | Z | С | Adc | 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 0 b7 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 | | 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}$<br>$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) | $M \leftarrow -(M) = \$00 - (M)$<br>$A \leftarrow -(A) = \$00 - (A)$ | | | | | | | | 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 \leftarrow (A \texttt{[3:0]:A} \texttt{[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 \leftarrow (A) \mid (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 \leftarrow (SP) - 1$ | - | - | - | - | - | - | INH | 89 | | 2 | | PULA | Pull A from Stack | $SP \leftarrow (SP + 1); Pull (A)$ | - | - | - | - | - | - | INH | 86 | | 2 | | PULH | Pull H from Stack | $SP \leftarrow (SP + 1); Pull (H)$ | - | - | _ | - | _ | _ | INH | 8A | | 2 | | PULX | Pull X from Stack | $SP \leftarrow (SP + 1); Pull (X)$ | - | - | _ | _ | _ | _ | INH | 88 | | 2 | | ROL opr<br>ROLA<br>ROLX<br>ROL opr,X<br>ROL ,X<br>ROL opr,SP | Rotate Left through Carry | <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> | 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 | MC68HC908RC24 — Rev. 1.0 # **Central Processor Unit (CPU)** Table 5-1. Instruction Set Summary (Sheet 6 of 7) | RSP | Source<br>Form | Operation | Operation Description | | | | | | | Address<br>Mode | Opcode | Operand | Cycles | |-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------|---------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|----------|----------|----------|----------|----------|---------------------------------------|------------------------------------|----------------------------|--------------------------------------| | RSP | 1 01111 | | | ٧ | Н | I | N | Z | С | Adc | ŏ | ö | င် | | RTI Return from Interrupt | RSP | Reset Stack Pointer | SP ← \$FF | - | - | - | - | - | - | | 9C | | 1 | | SBC #por SBC opr SB | RTI | Return from Interrupt | SP ← (SP) + 1; Pull (A)<br>SP ← (SP) + 1; Pull (X)<br>SP ← (SP) + 1; Pull (PCH) | <b>‡</b> | <b>‡</b> | <b>‡</b> | <b>‡</b> | <b>‡</b> | <b>‡</b> | INH | 80 | | 7 | | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$ | RTS | Return from Subroutine | $SP \leftarrow SP + 1$ ; Pull (PCH)<br>$SP \leftarrow SP + 1$ ; Pull (PCL) | - | - | _ | - | - | - | INH | 81 | | 4 | | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$ | SBC opr<br>SBC opr<br>SBC opr,X<br>SBC opr,X<br>SBC ,X<br>SBC opr,SP | Subtract with Carry | $A \leftarrow (A) - (M) - (C)$ | <b>‡</b> | _ | _ | <b>‡</b> | <b>‡</b> | <b>‡</b> | DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP1 | B2<br>C2<br>D2<br>E2<br>F2<br>9EE2 | dd<br>hh II<br>ee ff<br>ff | 2<br>3<br>4<br>4<br>3<br>2<br>4<br>5 | | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$ | SEC | Set Carry Bit | C ← 1 | - | - | - | - | - | 1 | INH | 99 | | 1 | | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$ | SEI | Set Interrupt Mask | I ← 1 | - | - | 1 | - | - | - | INH | 9B | | 2 | | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$ | STA opr<br>STA opr,X<br>STA opr,X<br>STA ,X<br>STA opr,SP | Store A in M | M ← (A) | 0 | _ | _ | <b>‡</b> | <b>‡</b> | _ | EXT<br>IX2<br>IX1<br>IX<br>SP1 | C7<br>D7<br>E7<br>F7<br>9EE7 | hh II<br>ee ff<br>ff | 3<br>4<br>4<br>3<br>2<br>4<br>5 | | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$ | STHX opr | Store H:X in M | (M:M + 1) ← (H:X) | 0 | - | - | <b>‡</b> | 1 | - | DIR | 35 | dd | 4 | | $\begin{array}{c ccccccccccccccccccccccccccccccccccc$ | STOP | Enable IRQ Pin; Stop Oscillator | I ← 0; Stop Oscillator | - | - | 0 | - | - | - | INH | 8E | | 1 | | $ \begin{array}{c ccccccccccccccccccccccccccccccccccc$ | STX opr<br>STX opr,X<br>STX opr,X<br>STX ,X<br>STX opr,SP | Store X in M | $M \leftarrow (X)$ | 0 | _ | _ | <b>‡</b> | <b>‡</b> | _ | EXT<br>IX2<br>IX1<br>IX<br>SP1 | CF<br>DF<br>EF<br>FF<br>9EEF | hh II<br>ee ff<br>ff | 3<br>4<br>4<br>3<br>2<br>4<br>5 | | | SUB opr<br>SUB opr<br>SUB opr,X<br>SUB opr,X<br>SUB ,X<br>SUB opr,SP | Subtract | $A \leftarrow (A) - (M)$ | <b>‡</b> | _ | _ | \$ | <b>‡</b> | <b>‡</b> | DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP1 | B0<br>C0<br>D0<br>E0<br>F0<br>9EE0 | dd<br>hh II<br>ee ff<br>ff | 2<br>3<br>4<br>4<br>3<br>2<br>4<br>5 | | PCH ← Interrupt Vector High Byte PCL ← Interrupt Vector Low Byte | SWI | Software Interrupt | $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; I \leftarrow 1$ $PCH \leftarrow Interrupt Vector High Byte$ | _ | _ | 1 | _ | _ | _ | INH | 83 | | 9 | | TAP Transfer A to CCR $\qquad$ CCR $\leftarrow$ (A) $\uparrow$ $\uparrow$ $\uparrow$ $\uparrow$ $\uparrow$ $\uparrow$ INH 84 | TAP | Transfer A to CCR | CCR ← (A) | <b>‡</b> | <b>‡</b> | <b>‡</b> | <b>‡</b> | \$ | <b>‡</b> | INH | 84 | | 2 | | TAX Transfer A to X $X \leftarrow (A)$ $ NH $ 97 | TAX | Transfer A to X | - | - | - | - | - | - | INH | 97 | | 1 | | Advance Information MC68HC908RC24 — Rev. 1.0 Table 5-1. Instruction Set Summary (Sheet 7 of 7) | Source<br>Form | Operation | Description | Effect on CCR | | | | | | | | | Cycles | |--------------------------------------------------------------|---------------------------|----------------------------------------|---------------|---|---|----------|----------|----|---------------------------------------|------------------------------------|----------------|----------------------------| | 1 01111 | | | ٧ | Н | I | N | Z | С | Add | Opcode | Operand | Š | | TPA | Transfer CCR to A | A ← (CCR) | - | - | - | - | - | - | INH | 85 | | 1 | | 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> | <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 | | I | 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 | | N | Negative bit | _ | Not affected | # 5.9 Opcode Map The opcode map is provided in Table 5-2. Advance Information - Rev. 1.0 ## Table 5-2. Opcode Map | ance | | Bit Manipulation Branch Read-Modify-Write Control | | | | | | | | | | | | | | Register | jister/Memory | | | | | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|---------------------------------------------------|---------------------|--------------------|--------------------|---------------------|---------------------|------------------------------|--------------------|--------------------|--------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------|--| | \( \text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\ti}}\\ \text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\text{\tex{\tex | | DIR | DIR | REL | DIR | INH | INH | IX1 | SP1 | IX | INH | INH | IMM | DIR | EXT | IX2 | SP2 | IX1 | SP1 | IX | | | Infor | MSB<br>LSB | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 9E6 | 7 | 8 | 9 | A | В | С | D | 9ED | E | 9EE | F | | | Information | 0 | 5<br>BRSET0<br>3 DIR | 4<br>BSET0<br>2 DIR | 3<br>BRA<br>2 REL | 4<br>NEG<br>2 DIR | 1<br>NEGA<br>1 INH | 1<br>NEGX<br>1 INH | | 5<br>NEG<br>3 SP1 | 3<br>NEG<br>1 IX | 7<br>RTI<br>1 INH | 3<br>BGE<br>2 REL | SUB<br>2 IMM | | 4<br>SUB<br>3 EXT | 4<br>SUB<br>3 IX2 | _ | 3<br>SUB<br>2 IX1 | 4<br>SUB<br>3 SP1 | 2<br>SUB<br>1 IX | | | ם | 1 | 5<br>BRCLR0<br>3 DIR | 4<br>BCLR0<br>2 DIR | 3<br>BRN<br>2 REL | 5<br>CBEQ<br>3 DIR | 4<br>CBEQA<br>3 IMM | CBEQX<br>3 IMM | | 6<br>CBEQ<br>4 SP1 | 4<br>CBEQ<br>2 IX+ | 4<br>RTS<br>1 INH | 3<br>BLT<br>2 REL | 2<br>CMP<br>2 IMM | 3<br>CMP<br>2 DIR | 4<br>CMP<br>3 EXT | 4<br>CMP<br>3 IX2 | | 3<br>CMP<br>2 IX1 | 4<br>CMP<br>3 SP1 | 2<br>CMP<br>1 IX | | | | 2 | - | | 3<br>BHI<br>2 REL | | 5<br>MUL<br>1 INH | 7<br>DIV<br>1 INH | 3<br>NSA<br>1 INH | | 2<br>DAA<br>1 INH | | 3<br>BGT<br>2 REL | | | SBC<br>3 EXT | 4<br>SBC<br>3 IX2 | 5<br>SBC<br>4 SP2 | | 4<br>SBC<br>3 SP1 | SBC<br>1 IX | | | | 3 | 5<br>BRCLR1<br>3 DIR | 4<br>BCLR1<br>2 DIR | | COM<br>2 DIR | 1<br>COMA<br>1 INH | COMX<br>1 INH | COM<br>2 IX1 | 5<br>COM<br>3 SP1 | | | 3<br>BLE<br>2 REL | | | 4<br>CPX<br>3 EXT | | 5<br>CPX<br>4 SP2 | | 4<br>CPX<br>3 SP1 | CPX<br>1 IX | | | | 4 | 5<br>BRSET2<br>3 DIR | 4<br>BSET2<br>2 DIR | | 4<br>LSR<br>2 DIR | 1<br>LSRA<br>1 INH | 1<br>LSRX<br>1 INH | | 5<br>LSR<br>3 SP1 | | 2<br>TAP<br>1 INH | 2<br>TXS<br>1 INH | | | 4<br>AND<br>3 EXT | | | 3<br>AND<br>2 IX1 | 4<br>AND<br>3 SP1 | 2<br>AND<br>1 IX | | | | 5 | 5<br>BRCLR2<br>3 DIR | BCLR2<br>2 DIR | BCS<br>2 REL | STHX<br>2 DIR | LDHX<br>3 IMM | 4<br>LDHX<br>2 DIR | CPHX<br>3 IMM | | CPHX<br>2 DIR | 1<br>TPA<br>1 INH | TSX<br>1 INH | BIT<br>2 IMM | BIT<br>2 DIR | BIT<br>3 EXT | 4<br>BIT<br>3 IX2 | 5<br>BIT<br>4 SP2 | 3<br>BIT<br>2 IX1 | 4<br>BIT<br>3 SP1 | BIT<br>1 IX | | | | 6 | | BSET3<br>2 DIR | | 4<br>ROR<br>2 DIR | 1<br>RORA<br>1 INH | 1<br>RORX<br>1 INH | 4<br>ROR<br>2 IX1 | 5<br>ROR<br>3 SP1 | 3<br>ROR<br>1 IX | 2<br>PULA<br>1 INH | | 2<br>LDA<br>2 IMM | | 4<br>LDA<br>3 EXT | | 5<br>LDA<br>4 SP2 | | 4<br>LDA<br>3 SP1 | 2<br>LDA<br>1 IX | | | | 7 | 5<br>BRCLR3<br>3 DIR | BCLR3<br>2 DIR | 3<br>BEQ<br>2 REL | 4<br>ASR<br>2 DIR | 1<br>ASRA<br>1 INH | 1<br>ASRX<br>1 INH | 4<br>ASR<br>2 IX1 | 5<br>ASR<br>3 SP1 | 3<br>ASR<br>1 IX | 2<br>PSHA<br>1 INH | 1<br>TAX<br>1 INH | AIS<br>2 IMM | 3<br>STA<br>2 DIR | 4<br>STA<br>3 EXT | 4<br>STA<br>3 IX2 | 5<br>STA<br>4 SP2 | 3<br>STA<br>2 IX1 | 4<br>STA<br>3 SP1 | 2<br>STA<br>1 IX | | | | 8 | 5<br>BRSET4<br>3 DIR | BSET4<br>2 DIR | 3<br>BHCC<br>2 REL | 4<br>LSL<br>2 DIR | 1<br>LSLA<br>1 INH | 1<br>LSLX<br>1 INH | LSL<br>2 IX1 | 5<br>LSL<br>3 SP1 | 3<br>LSL<br>1 IX | 2<br>PULX<br>1 INH | 1<br>CLC<br>1 INH | EOR<br>2 IMM | 3<br>EOR<br>2 DIR | EOR<br>3 EXT | EOR<br>3 IX2 | 5<br>EOR<br>4 SP2 | 3<br>EOR<br>2 IX1 | 4<br>EOR<br>3 SP1 | 2<br>EOR<br>1 IX | | | | 9 | 5<br>BRCLR4<br>3 DIR | 4<br>BCLR4<br>2 DIR | 3<br>BHCS<br>2 REL | 4<br>ROL<br>2 DIR | 1<br>ROLA<br>1 INH | 1<br>ROLX<br>1 INH | 4<br>ROL<br>2 IX1 | 5<br>ROL<br>3 SP1 | 3<br>ROL<br>1 IX | 2<br>PSHX<br>1 INH | 1<br>SEC<br>1 INH | ADC<br>2 IMM | 3<br>ADC<br>2 DIR | 4<br>ADC<br>3 EXT | 4<br>ADC<br>3 IX2 | | 3<br>ADC<br>2 IX1 | 4<br>ADC<br>3 SP1 | ADC<br>1 IX | | | | A | 5<br>BRSET5<br>3 DIR | 4<br>BSET5<br>2 DIR | | DEC<br>2 DIR | 1<br>DECA<br>1 INH | 1<br>DECX<br>1 INH | 4<br>DEC<br>2 IX1 | 5<br>DEC<br>3 SP1 | DEC<br>1 IX | 2<br>PULH<br>1 INH | | ORA<br>2 IMM | 3<br>ORA<br>2 DIR | 4<br>ORA<br>3 EXT | 4<br>ORA<br>3 IX2 | | 3<br>ORA<br>2 IX1 | 4<br>ORA<br>3 SP1 | ORA<br>1 IX | | | | В | 5<br>BRCLR5<br>3 DIR | 4<br>BCLR5<br>2 DIR | 3<br>BMI<br>2 REL | 5<br>DBNZ<br>3 DIR | 3<br>DBNZA<br>2 INH | 3<br>DBNZX<br>2 INH | 5<br>DBNZ<br>3 IX1 | 6<br>DBNZ<br>4 SP1 | 4<br>DBNZ<br>2 IX | 2<br>PSHH<br>1 INH | 2<br>SEI<br>1 INH | 2<br>ADD<br>2 IMM | 3<br>ADD<br>2 DIR | 4<br>ADD<br>3 EXT | 4<br>ADD<br>3 IX2 | 5<br>ADD<br>4 SP2 | 3<br>ADD<br>2 IX1 | 4<br>ADD<br>3 SP1 | 2<br>ADD<br>1 IX | | | | С | 5<br>BRSET6<br>3 DIR | BSET6<br>2 DIR | 3<br>BMC<br>2 REL | 4<br>INC<br>2 DIR | 1<br>INCA<br>1 INH | 1<br>INCX<br>1 INH | 4<br>INC<br>2 IX1 | 5<br>INC<br>3 SP1 | INC<br>1 IX | 1<br>CLRH<br>1 INH | 1<br>RSP<br>1 INH | | JMP<br>2 DIR | 3<br>JMP<br>3 EXT | 4<br>JMP<br>3 IX2 | | 3<br>JMP<br>2 IX1 | | JMP<br>1 IX | | | MC | D | - | 4<br>BCLR6<br>2 DIR | | TST<br>2 DIR | 1<br>TSTA<br>1 INH | 1<br>TSTX<br>1 INH | 3<br>TST<br>2 IX1 | 4<br>TST<br>3 SP1 | 2<br>TST<br>1 IX | | 1<br>NOP<br>1 INH | 4<br>BSR<br>2 REL | JSR<br>2 DIR | 5<br>JSR<br>3 EXT | 6<br>JSR<br>3 IX2 | | 5<br>JSR<br>2 IX1 | | JSR<br>1 IX | | | 68HC | E | - | BSET7<br>2 DIR | 3<br>BIL<br>2 REL | | 5<br>MOV<br>3 DD | 4<br>MOV<br>2 DIX+ | 4<br>MOV<br>3 IMD | | 4<br>MOV<br>2 IX+D | 1<br>STOP<br>1 INH | * | 2<br>LDX<br>2 IMM | | | 4<br>LDX<br>3 IX2 | _ | 3<br>LDX<br>2 IX1 | 4<br>LDX<br>3 SP1 | LDX<br>1 IX | | | MC68HC908R | F | 5<br>BRCLR7<br>3 DIR | 4<br>BCLR7<br>2 DIR | 3<br>BIH<br>2 REL | 3<br>CLR<br>2 DIR | 1<br>CLRA<br>1 INH | 1<br>CLRX<br>1 INH | 3<br>CLR<br>2 IX1 | 4<br>CLR<br>3 SP1 | CLR<br>1 IX | 1<br>WAIT<br>1 INH | 1<br>TXA<br>1 INH | 2<br>AIX<br>2 IMM | 3<br>STX<br>2 DIR | 4<br>STX<br>3 EXT | 4<br>STX<br>3 IX2 | 5<br>STX<br>4 SP2 | 3<br>STX<br>2 IX1 | 4<br>STX<br>3 SP1 | STX<br>1 IX | | | C24 - | INH Inhe | | | Relative | Offset | | | er, 8-Bit Of<br>er, 16-Bit C | | | | | | MSB | 0 | High Byte | e of Opcod | e in Hexad | lecimal | | | INH Inherent REL Relative IMM Immediate IX Indexed, No Offset DIR Direct IX1 Indexed, 8-Bit Offset EXT Extended IX2 Indexed, 16-Bit Offset IMD Immediate-Direct IX+D Indexed-Direct DIX+ Direct-Indexed \*Prop byte for stock points in devel of the stock property in \*Pre-byte for stack pointer indexed instructions SP1 Stack Pointer, 8-Bit Offset SP2 Stack Pointer, 16-Bit Offset IX+ Indexed, No Offset with Post Increment IX1+ Indexed, 1-Byte Offset with Post Increment Low Byte of Opcode in Hexadecimal MSB High Byte of Opcode in Hexadecimal LSB 5 Cycles BRSET0 Opcode Mnemonic 3 DIR Number of Bytes / Addressing Mode # **Section 6. Resets and Interrupts** ## 6.1 Contents | 6.2 In | troduction6 | 8 | |--------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------| | 6.3 R | esets6 | 8 | | 6.3.1 | Reset Entry | 9 | | 6.3.1.1 | External Reset | 9 | | 6.3.1.2 | COP Reset | 9 | | 6.3.1.3 | Illegal Opcode Reset | 9 | | 6.3.1.4 | Illegal Address Reset7 | | | 6.3.1.5 | Low-Power Reset7 | 0 | | 6.3.2 | Reset Recovery | 0 | | 6.3.2.1 | External Reset Recovery | 1 | | 6.3.2.2 | Active Reset Recovery7 | 1 | | 6.3.2.3 | Power-On Reset (POR) Recovery | | | 6.3.3 | Reset Status Register | 3 | | 6.3.4 | Reset States | 4 | | | | | | | | | | | terrupts | 6 | | 6.4 In | terrupts7 | 6<br>6 | | 6.4 In<br>6.4.1 | terrupts | 6<br>6<br>9 | | 6.4 In<br>6.4.1<br>6.4.2 | terrupts | 6<br>6<br>9 | | 6.4 In<br>6.4.1<br>6.4.2<br>6.4.2.1 | terrupts | 6<br>6<br>9<br>9 | | 6.4 In<br>6.4.1<br>6.4.2<br>6.4.2.1<br>6.4.2.2 | terrupts | 6<br>6<br>9<br>9 | | 6.4 In<br>6.4.1<br>6.4.2<br>6.4.2.1<br>6.4.2.2<br>6.4.2.3<br>6.4.2.4<br>6.4.2.5 | terrupts | 6<br>6<br>9<br>9<br>9<br>9<br>0 | | 6.4 In<br>6.4.1<br>6.4.2<br>6.4.2.1<br>6.4.2.2<br>6.4.2.3<br>6.4.2.4<br>6.4.2.5<br>6.4.2.6 | terrupts. .7 Effects .7 Sources .7 SWI Instruction .7 Break Interrupt .7 IRQ1 Pin .7 CMT Interrupt .7 TIM0I Interrupt .8 KBD0-KBD7 Pins .8 | 6<br>6<br>9<br>9<br>9<br>9<br>0<br>0 | | 6.4 In<br>6.4.1<br>6.4.2<br>6.4.2.1<br>6.4.2.2<br>6.4.2.3<br>6.4.2.4<br>6.4.2.5 | terrupts. .7 Effects .7 Sources .7 SWI Instruction .7 Break Interrupt .7 IRQ1 Pin. .7 CMT Interrupt .7 TIM0I Interrupt .8 KBD0-KBD7 Pins .8 Interrupt Status Registers .8 | 6<br>6<br>9<br>9<br>9<br>9<br>9<br>0<br>0 | | 6.4 In<br>6.4.1<br>6.4.2<br>6.4.2.1<br>6.4.2.2<br>6.4.2.3<br>6.4.2.4<br>6.4.2.5<br>6.4.2.6 | terrupts. .7 Effects .7 Sources .7 SWI Instruction .7 Break Interrupt .7 IRQ1 Pin .7 CMT Interrupt .7 TIM0I Interrupt .8 KBD0-KBD7 Pins .8 | 6 6 9 9 9 9 0 0 0 1 | MC68HC908RC24 — Rev. 1.0 #### 6.2 Introduction Resets and interrupts are responses to exceptional events during program execution. A reset re-initializes the MCU to its startup condition. An interrupt vectors the program counter to a service routine. #### 6.3 Resets A reset immediately returns the MCU to a known startup condition and begins program execution from a user-defined memory location. Figure 6-1 shows the structure of the reset circuits. #### NOTE: The reset circuits are powered by the chip $V_{DD}$ . External circuits should drive the $\overline{RST}$ pin through a resistor between $V_{DD}$ and $V_{SS}$ levels. If external circuits use a pullup device on $\overline{RST}$ , the pin must be pulled to $V_{DD}$ and **not** to BATT. Figure 6-1. Reset Block Diagram ### 6.3.1 Reset Entry Reset entry can be caused by an internal or external event. External events control reset by driving the RST pin. Internal resets, which pull the RST pin low, have several sources: - Computer operating properly (COP) - Illegal opcode - Illegal address - Low-power reset Reset entry immediately stops the operation of the instruction being executed. #### 6.3.1.1 External Reset A logic 0 applied to the $\overline{RST}$ pin for a time, $t_{IRL}$ , generates an external reset. After reset recovery, the PIN bit in the reset status register will be set. #### 6.3.1.2 COP Reset A COP reset is an internal reset caused by an overflow of the COP counter. After reset recovery, the COP bit in the reset status register will be set. To clear the COP counter and prevent a COP reset, write any value to the COP control register at location \$FFFF. #### 6.3.1.3 Illegal Opcode Reset An illegal opcode reset is an internal reset caused by an opcode that is not in the instruction set. After reset recovery, the ILOP bit in the reset status register will be set. If the stop enable bit, STOP, in the configuration register is a logic 0, the STOP instruction causes an illegal opcode reset. ## **Resets and Interrupts** #### 6.3.1.4 Illegal Address Reset An illegal address reset is an internal reset caused by opcode fetch from an unmapped address. After reset recovery, the ILAD bit in the reset status register will be set. A data fetch from an unmapped address does not generate a reset. #### 6.3.1.5 Low-Power Reset The MC68HC908RC24 is designed for remote control applications and has on-chip circuits that force the MCU into low-power reset mode to preserve RAM contents. The low-power reset mode is entered whenever batteries have been removed or when the $V_{DD}$ voltage is detected below the $V_{LVR}$ voltage (a low battery condition exists). The $V_{LVR}$ threshold is defined in 19.10 LVI Characteristics. #### A low-power reset: - Puts the MCU into its low-power reset mode where the clocks to the CPU and modules are disabled - Requires the BATT pin to be pulled low and battery reinsertion to exit this mode - Upon exit, the system will go through the power-on reset recovery sequence. - After reset recovery, the POR and LP bits in the reset status register will be set. ## 6.3.2 Reset Recovery #### Reset recovery: - Initializes certain control and status bits - Loads the program counter with a user-defined reset vector address from locations \$FFFE and \$FFFF - Selects CGMXCLK divided by four as the bus clock ### 6.3.2.1 External Reset Recovery Figure 6-2 shows the relative timing of an external reset recovery. Figure 6-2. External Reset Recovery Timing #### 6.3.2.2 Active Reset Recovery An active reset recovery occurs immediately after internal resets from a COP, illegal address, or illegal opcode have occurred. These reset sources pull the $\overline{RST}$ pin low for 32 CGMXCLK cycles to allow resetting of external devices. The MCU is held in reset for an additional 32 CGMXCLK cycles after releasing the $\overline{RST}$ pin. Figure 6-3 shows the relative timing of an active reset recovery. Figure 6-3. Active Reset Recovery Timing #### 6.3.2.3 Power-On Reset (POR) Recovery A power-on reset (POR) is an internal reset caused by a positive transition on the BATT pin. This will occur when the entire system is initially powered up or when the system is experiencing a battery change. MC68HC908RC24 — Rev. 1.0 #### A power-on reset: - After the batteries have been inserted, holds the clocks to the CPU and modules inactive for 262,144 CGMXCLK cycles for the external capacitor charge time - Keeps the clocks inactive for an additional 512 CGMXCLK cycles for LVI enable time: the LVI will force re-entry into low-power reset mode if V<sub>DD</sub> is below the V<sub>LVR</sub> + H<sub>LVR</sub> voltage - Keeps the clocks inactive for a system stabilization delay of 4096 CGMXCLK cycles - Drives the RST pin low during the startup process and releases the RST pin 32 CGMXCLK cycles after the system stabilization delay - Releases the CPU to begin the reset vector sequence 64 CGMXCLK cycles after the system stabilization delay - Sets the POR and LP bits in the reset status register and clears all other bits in the register Figure 6-4 shows the relative timing of a power-on reset recovery. Figure 6-4. Power-on Reset (POR) Recovery Advance Information MC68HC908RC24 — Rev. 1.0 # 6.3.3 Reset Status Register This read-only register contains flags to show reset sources. All flag bits are cleared automatically following a read of the register. Reset service can read the reset status register to clear the register after power-on reset and to determine the source of any subsequent reset. The register is initialized on power-up as shown with the POR and the LP bits set and all other bits cleared. During a POR or any other internal reset, the $\overline{RST}$ pin is pulled low. After the pin is released, it will be sampled 32 CGMXCLK cycles later. If the pin is not above a V $_{IH}$ at that time, the PIN bit in the RSR may be set in addition to whatever other bits are set. ### **NOTE:** Only a read of the reset status register clears all reset flags. After multiple resets from different sources without reading the register, multiple flags remain set. Figure 6-5. Reset Status Register (RSR) POR — Power-On Reset Flag 1 = Power-on reset since last read of RSR 0 = Read of RSR since last power-on reset PIN — External Reset Flag 1 = External reset since last read of RSR 0 = Power-on reset or read of RSR since last external reset COP — Computer Operating Properly Reset Bit 1 = Last reset caused by timeout of COP counter 0 = POR or read of RSR # **Resets and Interrupts** - ILOP Illegal Opcode Reset Bit - 1 = Last reset caused by an illegal opcode - 0 = POR or read of RSR - ILAD Illegal Address Reset Bit - 1 = Last reset caused by an opcode fetch from an illegal address - 0 = POR or read of RSR - LPRST Low-Power Mode Reset Bit - 1 = Last reset caused by low-power supply voltage - 0 = POR or read of RSR ### 6.3.4 Reset States A brief description of how the various resets initialize the MCU is given here. - Central processor unit (CPU): - Accumulator (A) Unaffected - Index register (H:X) Bits 15:8 cleared, bits 7:0 indeterminate - Stack pointer (SP) Loaded with \$FF - Program counter (PC) Loaded with vector from locations \$FFFE and \$FFFF - Condition code register (CCR) I bit is set, other bits indeterminate - Resets: - Reset status register (RSR) Bit indicating last cause of reset is set, other bits are unaffected by reset - Interrupts: - Interrupt status register (INT1) Cleared - Low-voltage inhibit (LVI) reset: - LVI status register (LVISR) Unaffected - Configuration register (CONFIG): - CONFIG Value fixed at time of manufacture - Input/output (I/O) ports: - Data registers (PTA, PTB, and PTC) Unaffected - Data direction registers (DDRA, DDRB, and DDRC) — Cleared - Carrier modulator transmitter (CMT): - CMT primary carrier data registers (CCH1/CCL1) IROLN, IROLP, and CMTPOL are cleared, all other bits are unaffected - CMT secondary carrier data registers (CCH2/CCL2) Unaffected - CMT modulator control and status register (CMCS) Cleared - CMT modulator data register (CMD1, CMD2, and CMD3) Unaffected - Modulo timer (TIM0I): - TIM status and control register (TSC) TSTOP set, other bits cleared - TIM counter registers (TCNTH/TCNTL) Cleared - TIM counter modulo registers (TMODH/TMODL) Set - External interrupt (IRQ): - IRQ status and control register (ISCR) Cleared - Keyboard interrupt module (KBI): - Keyboard status and control register (KBSCR) Cleared - Keyboard interrupt enable register (KBIER) Cleared - Computer operating properly (COP): - COP control register (COPCTL) Unaffected - Break module (BRK): - Break status register (BSR) Cleared - Break flag control register (BFCR) Cleared - Break address registers (BRKH/BRKL) Cleared - Break status and control register (BSCR) Cleared # 6.4 Interrupts An interrupt temporarily changes the sequence of program execution to respond to a particular event. An interrupt does not stop the operation of the instruction being executed, but begins when the current instruction completes its operation. ### 6.4.1 Effects # An interrupt: - Saves the CPU registers on the stack. At the end of the interrupt, the RTI instruction recovers the CPU registers from the stack so that normal processing can resume. See Figure 6-6. - Sets the interrupt mask (I bit) to prevent additional interrupts. Once an interrupt is latched, no other interrupt can take precedence, regardless of its priority. - Loads the program counter with a user-defined vector address Figure 6-6. Interrupt Stacking Order Advance Information MC68HC908RC24 — Rev. 1.0 After every instruction, the CPU checks all pending interrupts if the I bit is not set. If more than one interrupt is pending when an instruction is done, the highest priority interrupt is serviced first. In the example shown in **Figure 6-7**, if an interrupt is pending upon exit from the interrupt service routine, the pending interrupt is serviced before the load accumulator from memory (LDA) instruction is executed. Figure 6-7. Interrupt Recognition Example The LDA opcode is prefetched by both the interrupt 1 (INT1) and interrupt 2 (INT2) return-from-interrupt (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, save the H register and then restore it prior to exiting the routine. Figure 6-8. Interrupt Processing # 6.4.2 Sources The sources shown in **Table 6-1** can generate CPU interrupt requests. **Table 6-1. Interrupt Sources** | Source | Flag | Mask <sup>(1)</sup> | INT<br>Register<br>Flag | Priority <sup>(2)</sup> | Vector<br>Address | |------------------|-------|---------------------|-------------------------|-------------------------|-------------------| | SWI instruction | None | None | None | 0 | \$FFFC-\$FFFD | | ĪRQ1 pin | IRQ1F | IMASK1 | IF1 | 1 | \$FFFA—\$FFFB | | CMT end of cycle | EOCF | EOCIE | IF2 | 2 | \$FFF8-\$FFF9 | | TIM0I overflow | TOF | TOIE | IF3 | 3 | \$FFF6-\$FFF7 | | Keyboard pin | KEYF | IMASKK | IF4 | 4 | \$FFF4-\$FFF5 | The I bit in the condition code register is a global mask for all interrupt sources except the SWI instruction. ### 6.4.2.1 SWI Instruction The software interrupt instruction (SWI) causes a non-maskable interrupt. ### **NOTE:** A software interrupt pushes PC onto the stack. An SWI does **not** push PC – 1, as a hardware interrupt does. ### 6.4.2.2 Break Interrupt The break module causes the CPU to execute an SWI instruction at a software-programmable break point. ### 6.4.2.3 TRQ1 Pin A logic 0 on the IRQ1 pin latches an external interrupt request. # 6.4.2.4 CMT Interrupt The end-of-cycle flag (EOCF) can generate an interrupt request. The EOCF bit is set at the end of each modulation cycle. The EOC interrupt MC68HC908RC24 — Rev. 1.0 Advance Information <sup>2. 0 =</sup> highest priority # **Resets and Interrupts** enable (EOCIE) bit in the CMT control and status register enables CPU interrupt requests. # 6.4.2.5 TIM0I Interrupt The TIM0I overflow flag (TOF) can generate an interrupt request. The TOF bit is set when the TIM0I counter value rolls over to \$0000 after matching the value in the TIM0I counter modulo registers. The TIM0I overflow interrupt enable bit, TOIE, enables CPU interrupt requests. TOF and TOIE are in the TIM0I status and control register. ### 6.4.2.6 KBD0-KBD7 Pins A logic 0 on a keyboard interrupt pin latches an external interrupt request. # 6.4.3 Interrupt Status Registers The flags in the interrupt status registers identify maskable interrupt sources. **Table 6-2** summarizes the interrupt sources and the interrupt status register flags that they set. The interrupt status registers can be useful for debugging. **Table 6-2. Interrupt Source Flags** | Interrupt Source | Interrupt Status<br>Register Flag | |------------------|-----------------------------------| | Reset | _ | | SWI instruction | _ | | IRQ1 pin | IF1 | | СМТ | IF2 | | TIMOI | IF3 | | Keyboard pin | IF4 | # 6.4.3.1 Interrupt Status Register 1 Figure 6-9. Interrupt Status Register 1 (INT1) IF6-IF5 — Interrupt Flags 6-5 Since the MC68HC908RC24 does not use these interrupt flags, these bits will always read 0. IF4-IF1 — Interrupt Flags 4-1 These flags indicate the presence of interrupt requests from the sources shown in **Table 6-2**. 1 = Interrupt request present 0 = No interrupt request present Bit 0 and Bit 1 — Always read 0 # 6.4.3.2 Interrupt Status Register 2 Figure 6-10. Interrupt Status Register 2 (INT2) IF14-IF7 — Interrupt Flags 14-7 Since the MC68HC908RC24 does not use these interrupt flags, these bits will always read 0. # **Section 7. Low-Power Modes** # 7.1 Contents | 7.2 | Introduction | |--------------------------------|-------------------------------------------------------------------------------------------------------| | 7.3 | Wait Mode | | 7.4 | Stop Mode | | 7.5<br>7.5.1<br>7.5.2<br>7.5.3 | Low-Power Reset Mode.84External Circuits.85Low-Power Reset Operation.86RAM Retention Determination.87 | | 7.6<br>7.6.1<br>7.6.2 | Central Processor Unit (CPU) | | 7.7<br>7.7.1<br>7.7.2 | Break Module (BRK) | | 7.8<br>7.8.1<br>7.8.2 | Computer Operating Properly Module (COP) | | 7.9<br>7.9.1<br>7.9.2 | External Interrupt Module (IRQ) | | 7.10<br>7.10.1<br>7.10.2 | | | 7.11<br>7.11.1<br>7.11.2 | | MC68HC908RC24 — Rev. 1.0 Advance Information | 7.12 | Carrier Modulator Transmitter (CMT) | 11 | |--------|-------------------------------------|----| | 7.12.1 | Wait Mode9 | 1 | | 7.12.2 | Stop Mode | 11 | | 7.13 | Timer Interface Module (TIM0I) | 2 | | 7.13.1 | Wait Mode9 | 2 | | 7.13.2 | Stop Mode | 2 | | 7.14 | Exiting Wait Mode9 | 2 | | 7.15 | Exiting Stop Mode | 3 | # 7.2 Introduction The MCU may enter three low-power modes. Two of the modes, wait mode and stop mode, are common to all HC08 MCUs and are entered through instruction execution. A third low-power mode, the low-power reset mode (LPRST), is entered when a low voltage condition exists. # 7.3 Wait Mode The WAIT instruction puts the MCU in a low-power standby mode in which the CPU clock is disabled but the bus clock continues to run. # 7.4 Stop Mode Stop mode is entered when a STOP instruction is executed. Both the CPU clock and the bus clock are disabled in stop mode. ### 7.5 Low-Power Reset Mode The MC68HC908RC24 is designed for remote control applications and has on-chip circuits that force the MCU into low-power reset mode to preserve RAM contents. The low-power reset mode is entered whenever batteries have been removed or when the $V_{DD}$ voltage is detected below the $V_{LVR}$ voltage (a low battery condition exists). The $V_{LVR}$ threshold is defined in 19.10 LVI Characteristics. Advance Information MC68HC908RC24 — Rev. 1.0 # A low-power reset: - Puts the MCU into its low-power reset mode where the clocks to the CPU and modules are disabled - Requires the BATT pin to be pulled low and battery reinsertion to exit this mode - Upon exit, the system will go through the power-on reset recovery sequence. - After reset recovery, the POR and LP bits in the reset status register will be set. ### 7.5.1 External Circuits The required external components for low-power mode operation are shown in **Figure 7-1**. Refer to **19.11 Battery Detection Characteristics** for full component specifications. Power supply for the MCU is provided through the BATT pin. Figure 7-1. External Low-Power Circuit **NOTE:** Other pin connections necessary for proper MCU operation (for example, $\overline{IRQ1}$ and $\overline{RST}$ ) are not shown. The reset and external interrupt circuits are powered by the chip $V_{DD}$ . External circuits should drive these pins between $V_{DD}$ and $V_{SS}$ levels. If external circuits use a pullup device on $\overline{RST}$ or $\overline{IRQ1}$ , the pins must be pulled to $V_{DD}$ and **not** to BATT. # 7.5.2 Low-Power Reset Operation A block diagram of the low-power reset circuit is shown in **Figure 7-2**. The LPRST signal controls entry and exit from the low power reset mode. Low-power reset mode is entered whenever the batteries are removed or when $V_{DD}$ is detected below $V_{LVR}$ and is exited upon battery insertion. The $V_{DD}$ isolator is a MOSFET transistor connected to the BATT pin. This circuit blocks discharging of the external bulk capacitor when batteries have been removed. When the batteries are removed, the external 1-M $\Omega$ pulldown resistor will force the BATT pin low. The external bulk capacitor continues to source the chip $V_{DD}$ . The removed battery is detected and asserts LPRST. The low-power reset condition cannot be cleared until batteries have been reinstalled. When new batteries are inserted, a 262,144 CGMXCLK cycle delay is started. This delay is used for charging the external bulk capacitor through the $V_{DD}$ isolator. This delay (32 ms with an 8-MHz external crystal) provides enough time for the $V_{DD}$ supply to get above $V_{LVR}$ . Figure 7-2. Internal Low-Battery Detection Block Diagram After the 262,144 CGMXCLK cycle delay, a 512 CGMXCLK cycle delay occurs while the LVI is enabled and samples $V_{DD}$ . The LVI is enabled at this time to sample $V_{DD}$ to check if weak batteries were reinstalled. If $V_{DD}$ is detected below $V_{LVR}$ , the LVI will cause the MCU to re-enter the low-power reset mode before the CPU begins operation. The low-power reset mode cannot be exited until batteries have been removed and reinserted. The low-power reset condition is cleared after the 512 CGMXCLK cycle delay and a system stabilization delay of 4096 CGMXCLK cycles occurs. The complete power-on reset recovery sequence is detailed in 6.3.2.3 Power-On Reset (POR) Recovery. ### 7.5.3 RAM Retention Determination The external bulk capacitor is the power storage device used for RAM retention when the battery supply has been removed. The decay rate of the capacitor and the $V_{DD}$ level at the time low-power reset mode is entered will determine actual retention time. The low-power mode is entered when the LVI forces entry into low-power reset mode or when batteries have been removed. The LVI forced low-power reset provides the minimum data retention time. The retention time calculation is derived from: $$i = C \frac{dV}{dt} \Rightarrow t_{RDR} = C \frac{\Delta V}{i}$$ where: $C = 100 \,\mu F$ i = Typical I<sub>DD</sub> current when battery removed @ 25°C = 100 nA $\Delta V$ = Voltage difference of where the LVI forces entry into low-power reset mode ( $V_{DD} = V_{LVR}$ ) to the guaranteed RAM retention voltage Assuming a run current less than 10 mA, the voltage drop from the time the LVI senses the low voltage to the time the LVI forces entry into low-power reset mode is negligible (< 1 mV). Example calculation: $$t_{RDR} = 100 \,\mu\text{F} \, \frac{1.8 \,\text{V} - 1.3 \,\text{V}}{0.1 \,\mu\text{A}} = 500 \,\text{seconds}$$ # 7.6 Central Processor Unit (CPU) ### 7.6.1 Wait Mode The WAIT instruction: - Clears the interrupt mask (I bit) in the condition code register, enabling interrupts. After exit from wait mode by interrupt, the I bit remains clear. After exit by reset, the I bit is set. - Disables the CPU clock ### 7.6.2 Stop Mode The STOP instruction: - Clears the interrupt mask (I bit) in the condition code register, enabling external interrupts. After exit from stop mode by external interrupt, the I bit remains clear. After exit by reset, the I bit is set. - Disables the CPU clock After exiting stop mode, the CPU clock begins running after the system stabilization delay. **MOTOROLA** # 7.7 Break Module (BRK) ### 7.7.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 the BW bit in the break status register is set. # 7.7.2 Stop Mode The break module is inactive in stop mode. A break interrupt causes exit from stop mode and sets the BW bit in the break status register. # 7.8 Computer Operating Properly Module (COP) ### 7.8.1 Wait Mode The COP remains active in wait mode. To prevent a COP reset during wait mode, periodically clear the COP counter in a CPU interrupt routine. # 7.8.2 Stop Mode Stop mode turns off the CGMXCLK input to the COP and clears the COP prescaler. Service the COP immediately before entering or after exiting stop mode to ensure a full COP timeout period after entering or exiting stop mode. The STOP bit in the configuration register (CONFIG) enables the STOP instruction. To prevent inadvertently turning off the COP with a STOP instruction, disable the STOP instruction by clearing the STOP bit. # 7.9 External Interrupt Module (IRQ) ### 7.9.1 Wait Mode The IRQ module remains active in wait mode. Clearing the IMASK1 bit in the IRQ status and control register enables $\overline{\text{IRQ1}}$ CPU interrupt requests to bring the MCU out of wait mode. # 7.9.2 Stop Mode The IRQ module remains active in stop mode. Clearing the IMASK1 bit in the IRQ status and control register enables IRQ1 CPU interrupt requests to bring the MCU out of stop mode. # 7.10 Keyboard Interrupt Module (KBI) ### 7.10.1 Wait Mode The keyboard module remains active in wait mode. Clearing the IMASKK bit in the keyboard status and control register enables keyboard interrupt requests to bring the MCU out of wait mode. # **7.10.2 Stop Mode** The keyboard module remains active in stop mode. Clearing the IMASKK bit in the keyboard status and control register enables keyboard interrupt requests to bring the MCU out of stop mode. **MOTOROLA** # 7.11 Low-Voltage Inhibit Module (LVI) ### **7.11.1 Wait Mode** The LVI module remains active in wait mode. The LVI module can force entry into the low-power reset mode if a $V_{DD}$ voltage below the $V_{LVR}$ threshold is detected. # **7.11.2 Stop Mode** The LVI module is disabled in stop mode. The LVI module cannot generate a reset and bring the MCU out of stop mode. # 7.12 Carrier Modulator Transmitter (CMT) ### 7.12.1 Wait Mode The CMT remains active in wait mode. Any enabled CPU interrupt request from the CMT can bring the MCU out of wait mode. If CMT functions are not required during wait mode, reduce power consumption by stopping the CMT before executing the WAIT instruction. # **7.12.2 Stop Mode** The CMT is inactive in stop mode. The STOP instruction does not affect register states or the state of the CMT counter. CMT operation resumes when the MCU exits stop mode after an external interrupt. # 7.13 Timer Interface Module (TIM0I) ### 7.13.1 Wait Mode The TIM0I remains active in wait mode. Any enabled CPU interrupt request from the TIM0I can bring the MCU out of wait mode. If TIM0I functions are not required during wait mode, reduce power consumption by stopping the TIM0I before executing the WAIT instruction. # **7.13.2 Stop Mode** The TIM0I is inactive in stop mode. The STOP instruction does not affect register states or the state of the TIM0I counter. TIM0I operation resumes when the MCU exits stop mode after an external interrupt. # 7.14 Exiting Wait Mode These events restart the CPU clock and load the program counter with the reset vector or with an interrupt vector: - External reset A logic 0 on the RST pin resets the MCU and loads the program counter with the contents of locations \$FFFE and \$FFFF. - External interrupt A high-to-low transition on an external interrupt pin (IRQ1 pin) loads the program counter with the contents of locations \$FFFA and \$FFFB. - Break interrupt A break interrupt loads the program counter with the contents of \$FFFC and \$FFFD. - Computer operating properly module (COP) reset A timeout of the COP counter resets the MCU and loads the program counter with the contents of \$FFFE and \$FFFF. - Low-voltage inhibit module (LVI) reset A V<sub>DD</sub> voltage below the V<sub>LVR</sub> voltage forces entry into the low-power reset mode. Advance Information - Carrier modulator transmitter module (CMT) interrupt A CPU interrupt request from the CMT module (end of cycle detect) loads the program counter with the contents of \$FFF8 and \$FFF9. - Timer interface module (TIM0I) interrupt A CPU interrupt request from the TIM0I (TIM0I overflow) loads the program counter with the contents of \$FFF6 and \$FFE7. - Keyboard module (KBI) interrupt A CPU interrupt request from the KBI module loads the program counter with the contents of \$FFF4 and \$FFF5. # 7.15 Exiting Stop Mode These events restart the system clocks and load the program counter with the reset vector or with an interrupt vector: - External reset A logic 0 on the RST pin resets the MCU and loads the program counter with the contents of locations \$FFFE and \$FFFF. - External interrupt A high-to-low transition on an external interrupt pin loads the program counter with the contents of locations: - \$FFFA and \$FFFB (IRQ1 pin) - \$FFF4 and \$FFF5 (keyboard interrupt pins) - Break interrupt A break interrupt loads the program counter with the contents of locations \$FFFC and \$FFFD. Upon exit from stop mode, the system clocks begin running after the system stabilization delay. A 12-bit stop recovery counter inhibits the system clocks for 4096 CGMXCLK cycles after the reset or external interrupt. During this stabilization period, the LVI is enabled and a low $V_{DD}$ will force entry into the low-power reset mode. The short stop recovery bit, SSREC, in the configuration register controls the system stabilization delay during stop recovery. When the configuration is selected, stop recovery time is reduced from 4096 CGMXCLK cycles to 32 CGMXCLK cycles. **NOTE:** Use the full stop recovery time (SSREC = 0) in applications that use an external crystal. MOTOROLA # Section 8. Low-Voltage Inhibit (LVI) # 8.1 Contents | Introduction95 | |--------------------------------------------------------------------------------| | Features | | Functional Description.96False Trip Protection.97Short Stop Recovery Option.98 | | LVI Status Register98 | | LVI Interrupts98 | | Low-Power Modes.99Wait Mode.99Stop Mode.99 | | | # 8.2 Introduction The low-voltage inhibit (LVI) module monitors the voltage on the $V_{DD}$ pin and will set a low-voltage sense bit when $V_{DD}$ voltage falls to the LVI sense voltage. The LVI will force a low-power reset when the $V_{DD}$ voltage falls to the LVI trip voltage. MC68HC908RC24 — Rev. 1.0 **Advance Information** # Low-Voltage Inhibit (LVI) # 8.3 Features Features of the LVI module include: - Detects two levels of low battery condition - Forces entry into low-power reset mode - Disabled during stop mode - Disabled during low-power reset mode # 8.4 Functional Description **Figure 8-1** shows the structure of the LVI module, which contains a bandgap reference circuit and two comparators. The LVI monitors $V_{DD}$ voltage during normal MCU operation and is disabled when in stop mode or low-power reset mode. When enabled, the LVI module forces entry into low-power reset mode when $V_{DD}$ falls below the $V_{LVR}$ threshold. Once a low-power reset occurs, the MCU remains in low-power reset mode until the BATT pin sees a rising edge (batteries are removed and then reinstalled). That is, the LVI can force MCU entry into the low-power reset mode, but it is dependent on other chip circuits to bring the MCU out of a low-power reset. A low-power reset also drives the RST pin low to provide low-voltage protection to external peripheral devices. See **7.5** Low-Power Reset Mode. In addition to forcing a reset condition, the LVI module has a second circuit dedicated to detecting low batteries. When $V_{DD}$ falls below $V_{LVS}$ , the output of the weak battery comparator asserts the LOWV flag in the LVI status register (LVISR). In applications that require detecting low batteries, software can monitor by polling the LOWV bit. Figure 8-1. LVI Module Block Diagram # 8.4.1 False Trip Protection The $V_{DD}$ pin level is digitally filtered to reduce false dead battery detection due to power supply noise. For the LVI module to reset due to a low-power supply, $V_{DD}$ must remain at or below the $V_{LVR}$ level for a minimum 32 to 40 CGMXCLK cycles. See **Table 8-1**. **Table 8-1. LVI Digital Filter Characteristics** | | V <sub>DD</sub> | Result | | |------------------------------------|-------------------------------------|----------------------------------------------------|--| | At Level: | For Number of CGMXCLK Cycles: | | | | V <sub>DD</sub> > V <sub>LVR</sub> | Any | Filter counter remains clear | | | V <sub>DD</sub> < V <sub>LVR</sub> | < 32 CGMXCLK cycles | No reset, continue counting CGMXCLK | | | V <sub>DD</sub> < V <sub>LVR</sub> | Between 32 and 40<br>CGMXCLK cycles | LVI may force entry into<br>LPRST after 32 CGMXCLK | | | V <sub>DD</sub> < V <sub>LVR</sub> | > 40 CGMXCLK cycles | LVI guaranteed to force entry into LPRST mode | | # 8.4.2 Short Stop Recovery Option The LVI has an enable time of $t_{\text{EN}}$ . The system stabilization time for power on reset and long stop recovery (both 4096 CGMXCLK cycles) gives a delay longer than the LVI enable time for these startup scenarios. There is no period where the MCU is not protected from a low-power condition. However, when using the short stop recovery mask option, the 32 CGMXCLK delay must be greater than the LVI turn on time to avoid a period in startup where the LVI is not protecting the MCU. **NOTE:** Use the full stop recovery time (SSREC = 0) in applications that use an external crystal. # 8.5 LVI Status Register The LVI status register flags $V_{DD}$ voltages below the $V_{LVS}$ level. Figure 8-2. LVI Status Register (LVISR) LOWV— LVI Low Indicator Bit This read-only flag becomes set when the LVI is detecting $V_{DD}$ voltage below the $V_{LVS}$ threshold. # 8.6 LVI Interrupts The LVI module does not generate CPU interrupt requests. Advance Information # 8.7 Low-Power Modes The STOP and WAIT instructions put the MCU in low power-consumption standby modes. ### 8.7.1 Wait Mode The LVI module remains active in wait mode. The LVI module can force entry into the low-power reset mode if a $V_{DD}$ voltage below the $V_{LVR}$ voltage is detected. # 8.7.2 Stop Mode The LVI module is disabled in stop mode. The LVI module cannot generate a reset and bring the MCU out of stop mode. # Low-Voltage Inhibit (LVI) # Section 9. Oscillator # 9.1 Contents | 9.2 | Introduction | |-----------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 9.3 | Oscillator External Connections | | 9.4<br>9.4.1<br>9.4.2<br>9.4.3<br>9.4.4<br>9.4.5<br>9.4.6 | I/O Signals103Crystal Amplifier Input Pin (OSC1)103Crystal Amplifier Output Pin (OSC2)103Oscillator Enable Signal (SIMOSCEN)103External Clock Source (CGMXCLK)103Oscillator Out (CGMOUT)103Bus Clocks103 | | 9.5<br>9.5.1<br>9.5.2 | Low-Power Modes | | 9.6 | Oscillator During Break Mode104 | ### 9.2 Introduction The oscillator circuit is designed for use with crystals or ceramic resonators. The oscillator circuit generates the crystal clock signal, CGMXCLK, at the frequency of the crystal. This signal is divided by two before being passed on to the system integration module (SIM) for bus clock generation. **Figure 9-1** shows the structure of the oscillator. The oscillator requires various external components. # 9.3 Oscillator External Connections In its typical configuration, the oscillator requires five external components. The crystal oscillator is normally connected in a Pierce oscillator configuration, as shown in **Figure 9-1**. This figure shows only the logical representation of the internal components and may not represent actual circuitry. The oscillator configuration uses five components: - 1. Crystal, X<sub>1</sub> - 2. Fixed capacitor, C<sub>1</sub> - 3. Tuning capacitor, C<sub>2</sub>, which can also be a fixed capacitor - 4. Feedback resistor, R<sub>B</sub> - 5. Optional series resistor, R<sub>S</sub> Figure 9-1. Oscillator External Connections 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. Advance Information **MOTOROLA** # 9.4 I/O Signals This section describes the oscillator input/output (I/O) signals. # 9.4.1 Crystal Amplifier Input Pin (OSC1) The OSC1 pin is an input to the crystal oscillator amplifier. # 9.4.2 Crystal Amplifier Output Pin (OSC2) The OSC2 pin is the output of the crystal oscillator inverting amplifier. # 9.4.3 Oscillator Enable Signal (SIMOSCEN) The SIMOSCEN signal enables the oscillator. # 9.4.4 External Clock Source (CGMXCLK) CGMXCLK is the crystal oscillator output signal. It runs at the full speed of the crystal ( $f_{XCLK}$ ) and comes directly from the crystal oscillator circuit. **Figure 9-1** shows only the logical relation of CGMXCLK to OSC1 and OSC2 and may not represent the actual circuitry. The duty cycle of CGMXCLK is unknown and may depend on the crystal and other external factors. Also, the frequency and amplitude of CGMXCLK can be unstable at startup. ### 9.4.5 Oscillator Out (CGMOUT) CGMOUT is the clock output of the OSC circuits. This signal is used for generation of the MCU bus clocks. CGMOUT is a 50 percent duty cycle clock running at twice the bus frequency. ### 9.4.6 Bus Clocks Several bus clocks that are derived from the CGMOUT signal are one fourth the CGMXCLK frequency. # 9.5 Low-Power Modes The WAIT and STOP instructions put the MCU in low powerconsumption standby modes. ### 9.5.1 Wait Mode The WAIT instruction has no effect on the oscillator logic. CGMXCLK and CGMOUT clocks continue to be driven out. # 9.5.2 Stop Mode The STOP instruction disables the CGMXCLK and CGMOUT outputs. # 9.6 Oscillator During Break Mode The oscillator continues to drive CGMXCLK when the chip enters the break state. # Section 10. Configuration Register (CONFIG) ### 10.1 Contents | 10.2 | Introduction | 105 | |------|------------------------|-----| | 10.3 | Functional Description | 105 | ### 10.2 Introduction This section describes the configuration register (CONFIG). The configuration register enables or disables these options: - Stop mode recovery time (32 CGMXCLK cycles or 4096 CGMXCLK cycles) - COP timeout period (2<sup>18</sup> 2<sup>4</sup> or 2<sup>13</sup> 2<sup>4</sup> CGMXCLK cycles) - STOP instruction - Computer operating properly module (COP) # 10.3 Functional Description The configuration register is used in the initialization of various options. The configuration register can be written once after each reset. All of the configuration register bits are cleared during reset. Since the various options affect the operation of the MCU, it is recommended that this register be written immediately after reset. The configuration register is located at \$001F. For compatibility, a write to a ROM version of the MCU at this location will have no effect. The configuration register may be read at anytime. NOTE: The CONFIG module is known as an MOR (mask option register) on a ROM device. MC68HC908RC24 — Rev. 1.0 Advance Information # **Configuration Register (CONFIG)** Figure 10-1. Configuration Register (CONFIG) SSREC — Short Stop Recovery Bit SSREC enables the CPU to exit stop mode with a delay of 32 CGMXCLK cycles instead of a 4096 CGMXCLK cycle delay. 1 = Stop mode recovery after 32 CGMXCLK cycles 0 = Stop mode recovery after 4096 CGMXCLKC cycles **NOTE:** Exiting stop mode by pulling reset will result in the long stop recovery. If using an external crystal oscillator, do not set the SSREC bit. The LVI has an enable time of $t_{\rm EN}$ . The standard system stabilization time for power on reset and long stop recovery (both 4096 CGMXCLK cycles) gives a delay longer than the LVI enable time for these startup scenarios. There is no period where the MCU is not protected from a low-power condition. However, when using the short stop recovery configuration option, the 32 CGMXCLK delay must be greater than the LVI's turn on time to avoid a period in startup where the LVI is not protecting the MCU. COPRS — COP Rate Select Bit COPRS selects the COP timeout period. Reset clears COPRS. (See Section 16. Computer Operating Properly (COP).) 1 = COP timeout period = $2^{13} - 2^4$ CGMXCLK cycles $0 = COP \text{ timeout period} = 2^{18} - 2^4 CGMXCLK cycles}$ STOP — STOP Instruction Enable Bit STOP enables the STOP instruction. 1 = STOP instruction enabled 0 = STOP instruction treated as illegal opcode Advance Information MC68HC908RC24 — Rev. 1.0 COPD — COP Disable Bit COPD disables the COP module. (See **Section 16. Computer Operating Properly (COP)**.) 1 = COP module disabled 0 = COP module enabled # **Configuration Register (CONFIG)** # Section 11. Input/Output Ports (I/O) #### 11.1 Contents | 11.2 | Introduction1 | 09 | |--------|----------------------------|----| | 11.3 | Port A | 11 | | 11.3.1 | Port A Data Register1 | 11 | | 11.3.2 | Data Direction Register A1 | 11 | | 11.4 | Port B | 13 | | 11.4.1 | Port B Data Register1 | 13 | | 11.4.2 | Data Direction Register B1 | 14 | | 11.5 | Port C | 16 | | 11.5.1 | Port C Data Register1 | 16 | | 11.5.2 | Data Direction Register C | 17 | #### 11.2 Introduction Twenty 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. MC68HC908RC24 — Rev. 1.0 **Advance Information** 109 ## Input/Output Ports (I/O) INC/-DDING4 are not available. Set DDING/-DDING4 to 1 on 20-pin packages. = Unimplemented Figure 11-1. I/O Port Register Summary #### 11.3 Port A Port A is an 8-bit, general-purpose, bidirectional I/O port. #### 11.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 11-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. #### 11.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 11-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 11-4 shows the port A I/O logic. Figure 11-4. Port A I/O Circuit When bit DDRAx is a logic 1, reading address \$0000 reads the PTAx data latch. When bit DDRAx is a logic 0, reading address \$0000 reads the voltage level on the pin. The data latch can always be written, regardless of the state of its data direction bit. **Table 11-1** summarizes the operation of the port A pins. | DDRA<br>Bit | PTA<br>Bit | | I/O Pin<br>Mode | Accesses<br>to DDRA | | esses<br>PTA | |-------------|------------------|----------------------------|-----------------|---------------------|--------------------------|--------------| | - Dit | | IVIOGE | Read/Write | Read | Write | | | 0 | X <sup>(1)</sup> | Input, Hi-Z <sup>(2)</sup> | DDRA7-DDRA0 | Pin | PTA7-PTA0 <sup>(3)</sup> | | | 1 | Х | Output | DDRA7-DDRA0 | PTA7-PTA0 | PTA7-PTA0 | | **Table 11-1. Port A Pin Functions** - 1. X = Don't care - 2. Hi-Z = High impedance - 3. Writing affects data register, but does not affect input. Advance Information MC68HC908RC24 — Rev. 1.0 **MOTOROLA** #### 11.4 Port B Port B is an 8-bit, general-purpose, bidirectional I/O port that shares its pins with the keyboard interrupt module (KBI). #### 11.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 11-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 keyboard interrupt enable bits, KBIE7–KBIE0, in the keyboard interrupt control register (KBICR), enable the port B pins as external interrupt pins. (See Section 15. Keyboard Interrupt Module (KBI).) #### 11.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 11-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 11-7 shows the port B I/O logic. Figure 11-7. Port B I/O Circuit Advance Information MC68HC908RC24 — Rev. 1.0 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 11-2** summarizes the operation of the port B pins. **Table 11-2. Port B Pin Functions** | DDRB<br>Bit | PTB<br>Bit | I/O Pin<br>Mode | Accesses<br>to DDRB | | esses<br>PTB | |-------------|------------------|----------------------------|---------------------|-----------|--------------------------| | | | WIOGE | Read/Write | Read | Write | | 0 | X <sup>(1)</sup> | Input, Hi-Z <sup>(2)</sup> | DDRB7-DDRB0 | Pin | PTB7-PTB0 <sup>(3)</sup> | | 1 | Х | Output | DDRB7-DDRB0 | PTB7-PTB0 | PTB7-PTB0 | <sup>1.</sup> X = Don't care <sup>2.</sup> Hi-Z = High impedance <sup>3.</sup> Writing affects data register, but does not affect input. #### 11.5 Port C Port C is an 8-bit, general-purpose, bidirectional I/O port. PTC0–PTC3 have higher than standard current drive capabilities. Refer to **Section 19. Preliminary Electrical Specifications** for the port C drive specifications. ## 11.5.1 Port C Data Register The port C data register (PTC) contains a data latch for each of the four port C pins. Figure 11-8. Port C Data Register (PTC) #### PTC7-PTC4 — Port C Data Bits PTC7–PTC4 pads are not bonded out. Set these ports to outputs by writing an \$FX to data direction register C and write \$00 to the port C data register after any reset to avoid floating inputs and erroneous data. #### PTC[3:0] — Port C Data Bits These read/write bits are software-programmable. Data direction of each port C pin is under the control of the corresponding bit in data direction register C. Reset has no effect on port C data. #### 11.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 11-9. Data Direction Register C (DDRC) DDRC7-DDRC4 — Data Direction Register C Bits DDRC7–DDRC4 pads are not bonded out. Set these ports to outputs by writing an \$FX to data direction register C and write \$00 to the port C data register after any reset to avoid floating inputs and erroneous data. DDRC3-DDRC0 — Data Direction Register C Bits These read/write bits control port C data direction. Reset clears DDRC3–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 11-10 shows the port C I/O logic. 117 Figure 11-10. Port C I/O Circuit When bit DDRCx is a logic 1, reading address \$0002 reads the PTCx data latch. When bit DDRCx is a logic 0, reading address \$0002 reads the voltage level on the pin. The data latch can always be written, regardless of the state of its data direction bit. **Table 11-3** summarizes the operation of the port C pins. **Table 11-3. Port C Pin Functions** | DDRC<br>Bit | PTC<br>Bit | I/O Pin<br>Mode | Accesses<br>to DDRC | | esses<br>PTC | |-------------|------------------|----------------------------|---------------------|-----------|--------------------------| | ы | | IVIOGE | Read/Write | Read | Write | | 0 | X <sup>(1)</sup> | Input, Hi-Z <sup>(2)</sup> | DDRC3-DDRC0 | Pin | PTC3-PTC0 <sup>(3)</sup> | | 1 | Х | Output | DDRC3-DDRC0 | PTC3-PTC0 | PTC3-PTC0 | - 1. X = don't care - 2. Hi-Z = high impedance - 3. Writing affects data register, but does not affect input. # **Section 12. Carrier Modulator Transmitter (CMT)** ## 12.1 Contents | 12.2 Introduction | |---------------------------------------| | 12.3 Clock Generation | | 12.4 Overview | | 12.5 Carrier Generator | | 12.6 Modulator | | Generator in Time Mode | | 12.6.4.1 EXSPC Operation in Time Mode | | 12.7 Transmitter | | 12.8 IRO Latch | | 12.9 Flags and Interrupts | | 12.10 I/O Registers | | (CCH1, CCL1, CCH2, and CCL2) | | | | 12.11 Wait Mode Operation | | 12.12 Stop Mode Operation | #### 12.2 Introduction The carrier modulator transmitter (CMT) module provides a means to generate the protocol timing and carrier signals for a wide variety of encoding schemes. The CMT incorporates hardware to off-load the critical and/or lengthy timing requirements associated with code generation from the central processor unit (CPU), releasing much of its bandwidth to handle other tasks such as code data generation, data decompression, or keyboard scanning. The CMT does not include dedicated hardware configurations for specific protocols but is intended to be sufficiently programmable in its function to handle the timing requirements of most protocols with minimal CPU intervention. When the modulator is disabled, certain CMT registers can be used to change the state of the infrared out pin (IRO) directly. This feature allows for the generation of future protocols not readily producible by the current architecture. #### 12.3 Clock Generation The CMT module uses the CGMOUT signal from the oscillator circuits as a clock. With an 8-MHz crystal, CGMOUT is a 4-MHz clock. The DIV2 bit in the CMT modulator control and status register (CMCS) provides an option to divide the CMT clock source by another divide-by-2 circuit, thus extending the CMT periods. The block diagram for CMT clock circuits is shown in Figure 12-1. **Table 12-1** shows the relationship between typical system clock values and the CMT operating speeds. Figure 12-1. CMT Clock Generation **Table 12-1. System Clock Examples** | Crystal<br>(MHz) | Internal<br>Bus<br>(MHz) | CGMOUT<br>(MHz)<br>(Feed to CMT) | DIV2<br>Bit | Carrier<br>Generator<br>Resolution<br>(µs) | Min Carrier<br>Generator<br>Period<br>(μs) | Min<br>Modulator<br>Period<br>(μs) | |------------------|--------------------------|----------------------------------|-------------|--------------------------------------------|--------------------------------------------|------------------------------------| | 8 | 2 | 4 | 0 | 0.25 | 0.5 | 2 | | 8 | 2 | 4 | 1 | 0.5 | 1 | 4 | | 4 | 1 | 2 | 0 | 0.5 | 1 | 4 | | 4 | 1 | 2 | 1 | 1 | 2 | 8 | **NOTE:** Period and frequency calculations shown in **Table 12-1** will be affected by the state of the DIV2 bit. When DIV2 is set: $$CMTCLK = \frac{CGMOUT}{2} = \frac{CGMXCLK}{4}$$ When DIV2 is clear: $$\mathsf{CMTCLK} = \mathsf{CGMOUT} = \frac{\mathsf{CGMXCLK}}{2}$$ #### 12.4 Overview The module consists of: - Carrier generator - Modulator - Transmitter output - Registers The block diagram is shown in **Figure 12-2**. The module has three main modes of operation: time, baseband, and frequency shift key (FSK). When operating in time mode, the user independently defines the high and low times of the carrier signal to determine both period and duty cycle. The carrier generator resolution is 250 ns when operating with an 8-MHz crystal and the DIV2 bit in the CMCS clear. The carrier generator can generate signals with periods between 500 ns (2 MHz) and 31.5 $\mu s$ (31.75 kHz) in steps of 250 ns. The possible duty cycle options will depend upon the number of counts required to complete the carrier period. Figure 12-2. Carrier Modulator Transmitter Module Block Diagram For example, an 800-kHz signal has a period of 1.25 $\mu$ s and will therefore require 5 x 250 ns counts to generate. These counts may be split between high and low times so the duty cycles available will be: - 20 percent (one high, four low) - 40 percent (two high, three low) - 60 percent (three high, two low) - 80 percent (four high, one low) For lower frequency signals with larger periods, higher resolution (as a percentage of the total period) duty cycles are possible. When the BASE bit in the CMT modulator control and status register (CMCS) is set, the carrier output to the modulator is held high continuously to allow for the generation of baseband protocols. A third mode allows the carrier generator to alternate between two sets of high and low times. When operating in FSK mode, the generator will toggle between the two sets when instructed by the modulator, allowing the user to dynamically switch between two carrier frequencies without CPU intervention. The modulator provides a simple method to control protocol timing. The modulator has a resolution of 2 $\mu s$ with an 8-MHz oscillator. It can count system clocks (to provide real-time control) or it can count carrier clocks (for self-clocked protocols). See 12.6 Modulator for more details. The transmitter output block controls the state of the infrared out pin (IRO). The modulator output is gated on to the IRO pin when the modulator/carrier generator is enabled. When the module is not enabled, the IRO pin is controlled by the state of the IRO latch. A polarity bit enables the IRO pin to be high true or low true. See 12.8 IRO Latch. A summary of the possible modes is shown in **Table 12-2**. **Table 12-2. CMT Modes of Operation** | Mode | MCGEN<br>Bit <sup>(1)</sup> | BASE<br>Bit <sup>(2)</sup> | MODE<br>Bit <sup>(2)</sup> | EXSPC<br>Bit | Comment | |----------------|-----------------------------|----------------------------|----------------------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | Time | 1 | 0 | 0 | 0 | $f_{cg}$ controlled by primary high and low registers. $f_{cg}$ transmitted to IRO pin when modulator gate is open. | | Baseband | 1 | 1 | 0 | 0 | f <sub>cg</sub> is always high. IRO pin high when modulator gate is open. | | FSK | 1 | 0 | 1 | 0 | f <sub>cg</sub> control alternates between primary high/low registers and secondary high/low registers. f <sub>cg</sub> transmitted to IRO pin when modulator gate is open. | | Extended space | 1 | х | x | 1 | Setting the EXSPC bit causes subsequent modulator cycles to be spaces (modulator out not asserted) for the duration of the modulator period (mark and space times). | | IRO latch | 0 | х | Х | х | IRO latch controls state of IRO pin. The IRO latch can be written to on positive or negative edge of internal bus clock. | <sup>1.</sup> To prevent spurious operation, initialize all data and control registers before beginning a transmission (MCGEN = 1). #### 12.5 Carrier Generator The carrier signal is generated by counting a register-selected number of input clocks (250 ns for an 8-MHz oscillator) for both the carrier high time and the carrier low time. The period is determined by the total number of clocks counted. The duty cycle is determined by the ratio of high time clocks to total clocks counted. The high and low time values are user programmable and are held in two registers. An alternate set of high/low count values is held in another set of registers to allow the generation of dual frequency FSK (frequency shift keying) protocols without CPU intervention. **NOTE:** Data values for the high and low times should be non-zero to prevent spurious operation. <sup>2.</sup> These bits are not double buffered and should not be changed during a transmission (while MCGEN = 1). The MCGEN bit in the CMCS must be set and the BASE bit in the CMCS must be cleared to enable carrier generator clocks. When the BASE bit in the CMT modulator control and status register (CMCS) is set, the carrier output to the modulator is held high continuously. The block diagram is shown in Figure 12-3. Figure 12-3. Carrier Generator Block Diagram #### 12.5.1 Time Counter The high/low time counter is a 6-bit up counter. After each increment, the contents of the counter are compared with the appropriate high or low count value register. When the compare value is reached, the counter is reset (to a value of 1) and the compare is redirected to the other count value register. Assuming that the high time count compare register is currently active, a valid compare will cause the carrier output to be driven low. The counter will continue to increment (starting at reset value of 1). When the value stored in the selected low count value register is reached, the counter will again be reset and the carrier output will be driven high. MC68HC908RC24 — Rev. 1.0 The cycle repeats, automatically generating a periodic signal which is directed to the modulator. The lowest frequency (maximum period) and highest frequency (minimum period) which can be generated are: $$f_{max} = CMTCLK \div (2 \times 1) Hz$$ $f_{min} = CMTCLK \div (2 \times (2^6 - 1)) Hz$ In the general case, the carrier generator output frequency is: $$f_{cq} = CMTCLK \div (Highcount + Lowcount) Hz$$ Where: 0 < *Highcount* < 64 0 < Lowcount < 64 The duty cycle of the carrier signal is controlled by varying the ratio of high time to low + high time. As the input clock period is fixed, the duty cycle resolution will be proportional to the number of counts required to generate the desired carrier period. $$Duty Cycle = \frac{Highcount}{Highcount + Lowcount}$$ #### 12.6 Modulator The modulator has three main modes of operation: - 1. The modulator can gate the carrier onto the modulator output (TIME). - The modulator can control the logic level of the modulator output (BASEBAND). - The modulator can count carrier periods and instruct the carrier generator to alternate between two carrier frequencies whenever a modulation period (mark + space counts) expires (FSK) The modulator includes a 13-bit down counter with underflow detection. The counter is loaded from the 12-bit modulation mark period buffer register, MBUFF. The most significant bit is loaded with a 0 and serves as a sign bit. When the counter holds a positive value, the modulator gate is open and the carrier signal is driven to the transmitter block. When the counter underflows, the modulator gate is closed and a 12-bit comparator is enabled which compares the logical complement of the contents of the decrementing counter with the contents of the modulation space period register, SREG. When a match is obtained, the cycle repeats by opening the modulator gate, reloading the counter with the contents of MBUFF and reloading SREG with the contents of SBUFF. Should SREG = 0, the match will be immediate and no space period will be generated (for instance, for FSK protocols which require successive bursts of different frequencies). The MCGEN bit in the CMCS must be set to enable the modulator timer. The 12-bit MBUFF and SBUFF registers are accessed through three 8-bit modulator period registers, CMD1, CMD2, and CMD3. Refer to Figure 12-4 for a block diagram of the modulator. Figure 12-4. Modulator Block Diagram #### **12.6.1 Time Mode** When the modulator operates in time mode (BASE bit is clear, MODE bit is clear), the modulation mark period consists of an integer number of CMTCLK $\div$ 8 clocks. The modulation space period consists of 0 or an integer number of CMTCLK $\div$ 8 clocks. The mark and space periods are controlled by the MBUFF and SBUFF registers, respectively. With a 2-MHz crystal and DIV2 = 0, the modulator resolution is 4 $\mu$ s and has a maximum mark and space period of about 16 ms each. See **Figure 12-5** for an example of the time mode output. The mark and space time equations for time and baseband mode are: $$t_{mark} = \frac{(MBUFF + 1) \times 8}{CMTCLK} secs$$ $$t_{space} = \frac{SBUFF \times 8}{CMTCLK} secs$$ Figure 12-5. CMT Operation in Time Mode #### 12.6.1.1 Synchronization of Modulator and Carrier Generator in Time Mode To prevent carrier glitches which could affect carrier spectral purity, the modulator control gate and carrier clock are synchronized. The carrier signal is activated when the modulator gate opens. The modulator gate can close only when the carrier signal is low (the output logic level during space periods is low). When the modulator gate closes, the carrier is reset to a 1 on the next rising edge of CMTCLK. The carrier counter is held in the reset state until the beginning of the next mark period. In some special cases, where the carrier is high for the duration of the space period, the modulator gate does not close and the carrier continues to be gated to the IRO output without interruption into the next mark period. These special cases can occur when modulation space periods are shorter than carrier high times. #### 12.6.2 Baseband Mode Baseband mode (BASE bit is set, MODE bit is clear) is a derivative of time mode, where the mark and space period is based on (CMTCLK $\div$ 8) counts. The mark and space calculations are the same as in time mode. In this mode the modulator output will be at a logic 1 for the duration of the mark period and at a logic 0 for the duration of a space period. See **Figure 12-5**. #### 12.6.3 FSK Mode When the modulator operates in FSK mode, the modulation mark and space periods consist of an integer number of carrier clocks (space period can be 0). When the mark period expires, the space period is transparently started (as in time mode). The carrier generator toggles between primary and secondary data register values whenever the modulator space period expires. The space period provides an interpulse gap (no carrier). If SBUFF = 0, then the modulator and carrier generator will switch between carrier frequencies without a gap or any carrier glitches (0 space). Using timing data for carrier burst and interpulse gap length calculated by the CPU, FSK mode can automatically generate a phase-coherent, dual-frequency FSK signal with programmable burst and interburst gaps. The mark and space time equations for FSK mode are: $$t_{mark} = \frac{MBUFF + 1}{f_{CG}} secs$$ $$t_{space} = \frac{SBUFF}{fCG} secs$$ Where $f_{\text{CG}}$ is the frequency output from the carrier generator. #### 12.6.4 Extended Space Operation In either time, baseband, or FSK mode, the space period can be made longer than the maximum possible value of SBUFF. Setting the EXSPC bit in the CMCS will force the modulator to treat the next modulation period (beginning with the next load of MBUFF/SBUFF) as a space period equal in length to the mark and space counts combined. Subsequent modulation periods will consist entirely of these extended space periods with no mark periods. Clearing EXSPC will return the modulator to standard operation at the beginning of the next modulation period. #### 12.6.4.1 EXSPC Operation in Time Mode To calculate the length of an extended space in time or baseband modes, use the equation: $$t_{exspace} = \frac{\left( (SBUFF_1) + (MBUFF_2 + 1 + SBUFF_2) + ... \left( MBUFF_n + 1 + SBUFF_n \right) \right) \times 8}{CMTCLK}$$ secs Where the subscripts 1, 2, ... n refer to the modulation periods that elapsed while the EXSPC bit was set. For an example of extended space operation, see Figure 12-6. **NOTE:** The EXSPC feature can be used to emulate a zero mark event. Figure 12-6. Extended Space Operation #### 12.6.4.2 EXSPC Operation in FSK Mode In FSK mode, the modulator continues to count f<sub>CG</sub> clocks, alternating between the primary and secondary registers at the end of each modulation period. To calculate the length of an extended space in FSK mode, one needs to know whether the EXSPC bit was set on a primary or secondary modulation period. A status bit for the current modulation is not accessible to the CPU. If necessary, software should maintain tracking of the current modulation cycle (primary or secondary). If the EXSPC bit was set during a primary modulation cycle, use the equation: $$t_{\text{EXSPACE}} = \frac{\text{SBUFF}_1}{f_{\text{CG1}}} + \frac{\text{MBUFF}_2 + 1 + \text{SBUFF}_2}{f_{\text{CG2}}} + \frac{\text{MBUFF}_3 + 1 + \text{SBUFF}_3}{f_{\text{CG1}}} + \dots = \frac{\text{SBUFF}_1}{f_{\text{CG1}}} + \frac{\text{MBUFF}_2 + 1 + \text{SBUFF}_2}{f_{\text{CG1}}} + \dots = \frac{\text{SBUFF}_3}{f_{\text{CG1}}} \frac{\text{$$ #### Where: - The subscripts 1, 2, ... n refer to the modulation periods that elapsed while the EXSPC bit was set. - f<sub>cg1</sub> is the frequency output from the carrier generator for the primary registers. - f<sub>cg2</sub> is the frequency output from the carrier generator for the secondary registers. If the EXSPC bit was set during a secondary modulation cycle, use the equation: $$t_{\text{EXSPACE}} = \frac{\text{SBUFF}_1}{f_{\text{CG2}}} + \frac{\text{MBUFF}_2 + 1 + \text{SBUFF}_2}{f_{\text{CG1}}} + \frac{\text{MBUFF}_3 + 1 + \text{SBUFF}_3}{f_{\text{CG2}}} + \dots \dots \text{secs}$$ #### 12.7 Transmitter The transmitter output block controls the state of the infrared out pin (IRO). The modulator output is gated onto the IRO pin when the modulator/carrier generator is enabled. When the modulator/carrier generator is disabled, the IRO pin is controlled by the state of the IRO latch. A polarity bit in the CCH1 register enables the IRO pin to be high true or low true. #### 12.8 IRO Latch The IRO latch is accessible to the CPU through bit 7 of the carrier generator data registers CCH1 (IROLN bit) and CCL1 (IROLP bit). When the MCGEN bit is clear, the IRO latch is driven to the IRO pin. Through the IROLN and IROLP bits, the IRO latch can be written on either edge of the internal bus clock, allowing for IR waveforms which have a resolution of twice the bus clock frequency (CGMOUT). When IROLN is written, the IRO latch will be updated with the new data on the negative edge of the internal bus clock. When IROLP is written, the IRO latch will be updated with the new data on the positive edge of the internal bus clock. ## 12.9 Flags and Interrupts The end-of-cycle (EOCF) flag is set: - When the modulator is not currently active and the MCGEN bit is set to begin the initial CMT transmission - At the end of each modulation cycle (when the counter is reloaded from MBUFF) while the MCGEN bit is set In the condition where the MCGEN bit is cleared and then set before the end of the modulation cycle, the EOC will not be set when the MCGEN is set, but will become set at the end of the current modulation cycle. When the MCGEN becomes disabled, the CMT module does not set the EOC flag at the end of the last modulation cycle. The EOCF bit is cleared by reading the CMT modulator control and status register (CMCS) followed by an access of CMD2 or CMD3. If the EOC interrupt enable (EOCIE) bit was previously set, the CMT module will generate an interrupt request to the CPU. The EOCF bit must be cleared within the interrupt service routine (ISR) to prevent another interrupt being generated after exiting the ISR. If the EOC interrupt is not being used (EOCIE = 0), the EOCF flag need not be cleared. The EOC interrupt is coincidental with reloading the down-counter with the contents of MBUFF and reloading the SREG with the contents of SBUFF. The EOC interrupt provides a means for the user to reload new mark/space values into the MBUFF and SBUFF registers. An MBUFF and/or SBUFF update will take effect at the end of the current modulation cycle. **NOTE:** The down-counter and SREG are updated at the end of every modulation cycle, irrespective of interrupt handling and the state of the EOCF flag. ## 12.10 I/O Registers These I/O registers control and monitor CMT operation: - CMT carrier generator data registers (CCH1, CCL1, CCH2, CCL2) - CMT modulator control and status register (CMCS) - CMT modulator period data registers (CMD1, CMD2, CMD3) #### 12.10.1 Carrier Generator Data Registers (CCH1, CCL1, CCH2, and CCL2) The carrier generator contains: - One 8-bit data register CMT primary high time, CCH1 - One 7-bit data register CMT primary low time, CCL1 - Two 6-bit data registers: - CMT secondary high time, CCH2 - CMT secondary low time, CCL2 Bit 7 of CCH1 and CCL1 is used to read and write the IRO latch. Figure 12-7. CMT Carrier Generator Data Register (CCH1, CCL1, CCH2, and CCL2) MC68HC908RC24 — Rev. 1.0 Register Name and Address: CCL2—\$0013 Figure 12-7. CMT Carrier Generator Data Register (CCH1, CCL1, CCH2, and CCL2) (Continued) PH0-PH5 and PL0-PL5 — Primary Carrier High and Low Time Data Values When selected, these bits contain the number of input clocks required to generate the carrier high and low time periods. When operating in time mode (see 12.6.1 Time Mode), this register pair is always selected. When operating in FSK mode (see 12.6.3 FSK Mode), this register pair and the secondary register pair are alternately selected under control of the modulator. The primary carrier high and low time values are undefined out of reset. These bits must be written to non-zero values before the carrier generator is enabled to avoid spurious results. #### NOTE: Writing to CCH1 to update PH0–PH5 or to CCL1 to update PL0–PL5 will also update the IRO latch. When MCGEN (bit 0 in the CMCS) is clear, the IRO latch value appears on the IRO output pin. Care should be taken that bit 7 of the data to be written to CCH1 or CCL1 should contain the desired state of the IRO latch. Additionally, writing to CCH1 to update PH0–PH5 will also update the CMT polarity bit. Care should be taken that bit 6 of the data to be written to CCH1 should contain the desired state of the polarity bit. Advance Information MC68HC908RC24 — Rev. 1.0 # SH0–SH5 and SL0–SL5 — Secondary Carrier High and Low Time Data Values When selected, these bits contain the number of input clocks required to generate the carrier high and low time periods. When operating in time mode (see 12.6.1 Time Mode), this register pair is never selected. When operating in FSK mode (see 12.6.3 FSK Mode), this register pair and the primary register pair are alternately selected under control of the modulator. The secondary carrier high and low time values are undefined out of reset. These bits must be written to non-zero values before the carrier generator is enabled when operating in FSK mode. #### CMTPOL — CMT Output Polarity Bit This bit controls the polarity of the CMT output (IRO). When this bit is a 0, then the CMT output is active high. When this bit is set to 1 the CMT output is active low, in other words inverted. The reset state of this bit is 0. #### IROLN and IROLP — IRO Latch Control Bit Reading IROLN or IROLP reads the state of the IRO latch. Writing IROLN updates the IRO latch with the data being written on the negative edge of the internal processor clock (IT12). Writing IROLP updates the IRO latch on the positive edge of the internal processor clock; for example, one CGMOUT period later. The IRO latch is clear out of reset. #### **NOTE:** Writing to CCH1 to update IROLN or to CCL1 to update IROLP will also update the primary carrier high and low data values. Care should be taken that bits 5–0 of the data to be written to CCH1 or CCL1 should contain the desired values for the primary carrier high or low data. In addition, writing to CCH1 to update IROLN will update the CMT polarity bit. Care should be taken that bit 6 of the data to be written to CCH1 should contain the desired values for the polarity bit. #### 12.10.2 CMT Modulator Control and Status Register The CMT modulator control and status register (CMCS) contains the modulator and carrier generator enable (MCGEN), interrupt enable (EOCIE), mode select (MODE), baseband enable (BASE), extended space (EXSPC), divide-by-two prescaler (DIV2) bit, and the end of cycle (EOCF) status bit. Figure 12-8. CMT Modulator Control and Status Register (CMCS) EOCF — End-of-Cycle Status Flag - 1 = End of modulator cycle has occurred. - 0 = No end of modulation cycle occurrence since flag last cleared #### EOCF is set when: - The modulator is not currently active and the MCGEN bit is set to begin the initial CMT transmission. - At the end of each modulation cycle while the MCGEN bit is set. This is recognized when a match occurs between the contents of the space period register, SREG, and the down counter. At this time, the counter is initialized with the (possibly new) contents of the mark period buffer, MBUFF, and the space period register, SREG, is loaded with the (possibly new) contents of the space period buffer, SBUFF. This flag is cleared by a read of the CMCS followed by an access of CMD2 or CMD3. The EOC flag is cleared by reset. In the condition where the MCGEN bit is cleared and then set before the end of the modulation cycle, the EOC will not be set when the MCGEN is set, but will become set at the end of the current modulation cycle. When the MCGEN becomes disabled, the CMT module does not set the EOC flag at the end of the last modulation cycle. DIV2 — Divide-by-Two Prescaler Bit 1 = Divide-by-two prescaler enabled 0 = Divide-by-two prescaler disabled The divide-by-two prescaler causes the CMT to be clocked at the bus rate when enabled and 2 x the bus rate when disabled (CGMOUT). Since this bit is not double buffered, it should not be set during a transmission. EXSPC — Extended Space Enable Bit 1 = Extended space enabled 0 = Extended space disabled For a description of the extended space enable bit, see **12.6.4 Extended Space Operation**. This bit is cleared by reset. BASE — Baseband Enable Bit 1 = Baseband enabled 0 = Baseband disabled When set, the BASE bit disables the carrier generator and forces the carrier output high for generation of baseband protocols. When BASE is clear, the carrier generator is enabled and the carrier output toggles at the frequency determined by values stored in the carrier data registers. See 12.6.2 Baseband Mode. This bit is cleared by reset. This bit is not double buffered and should not be written to during a transmission. MODE — Mode Select Bit 1 = CMT operates in FSK mode. 0 = CMT operates in time mode. For a description of CMT operation in time mode, see 12.6.1 Time Mode. For a description of CMT operation in FSK mode, see 12.6.3 FSK Mode. This bit is cleared by reset. This bit is not double buffered and should not be written to during a transmission. EOCIE — End-of-Cycle Interrupt Enable Bit 1 = CPU interrupt enabled 0 = CPU interrupt disabled A CPU interrupt will be requested when EOCF is set if EOCIE was previously set. If EOCIE is clear, EOCF will not request a CPU interrupt. MCGEN — Modulator and Carrier Generator Enable Bit 1 = Modulator and carrier generator enabled 0 = Modulator and carrier generator disabled Setting MCGEN will initialize the carrier generator and modulator and will enable all clocks. Once enabled, the carrier generator and modulator will function continuously. When MCGEN is cleared, the current modulator cycle will be allowed to expire before all carrier and modulator clocks are disabled (to save power) and the modulator output is forced low. To prevent spurious operation, the user should initialize all data and control registers before enabling the system. This bit is cleared by reset. #### 12.10.3 CMT Modulator Data Registers (CMD1, CMD2, and CMD3) The 12-bit MBUFF and SBUFF registers are accessed through three 8-bit registers, CMD1, CMD2, and CMD3. CMD2 and CMD3 contain the least significant eight bits of MBUFF and SBUFF respectively. CMD1 contains the two most significant nibbles of MBUFF and SBUFF. In many applications, periods greater than those obtained by eight bits will not be required. Splitting the registers up in this manner allows the user to clear CMD1 and generate 8-bit periods with just two data writes. Figure 12-9. CMT Modulator Data Registers (CMD1, CMD2, and CMD3) MC68HC908RC24 — Rev. 1.0 ## 12.11 Wait Mode Operation During wait mode the CMT, if enabled, will continue to operate normally. However, there will be no new codes or changes of pattern mode while in wait mode, as the CPU is not operating. ## 12.12 Stop Mode Operation During stop mode, clocks to the CMT module are halted. No registers are affected. #### **NOTE:** Notice that because the clocks are halted, the CMT will resume upon exit from stop. Software should ensure that the stop mode is not entered while the modulator is still in operation to prevent the IRO pin from being asserted while in stop mode. This may require a timeout period from the time that the MCGEN bit is cleared to allow the last modulator cycle to complete. # Section 13. Modulo Timer (TIM0I) #### 13.1 Contents | 13.2 | Introduction | |------------------|-----------------------------------------------| | 13.3 | Features | | | Functional Description | | 13.5 | Interrupts146 | | 13.6.1 | Low-Power Modes.146Wait Mode.146Stop Mode.146 | | 13.7 | TIM0I During Break Interrupts147 | | 13.8.1<br>13.8.2 | TIM0I Counter Registers150 | | 13.8.3 | TIM0I Counter Modulo Registers | #### 13.2 Introduction This section describes the modulo timer (TIM0I) which is a periodic interrupt timer whose counter is clocked internally via software programmable options. **Figure 13-1** is a block diagram of the TIM0I. MC68HC908RC24 — Rev. 1.0 #### 13.3 Features Features of the TIM0I include: - Programmable TIM0I clock input - Free-running or modulo up-count operation - TIM0I counter stop and reset bits ## 13.4 Functional Description Figure 13-1 shows the structure of the TIM0I. The central component of the TIM0I is the 16-bit TIM0I counter that can operate as a free-running counter or a modulo up-counter. The counter provides the timing reference for the interrupt. The TIM0I counter modulo registers, TMODH and TMODL, control the modulo value of the counter. Software can read the counter value at any time without affecting the counting sequence. Figure 13-1. TIM0I Block Diagram 144 | Addr. | Register Name | | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | |-----------------------------------|-----------------------------|--------|--------|-----------|---------|------|----|------|-------|-------| | TIM Status and Contro | | Read: | d: TOF | TOIE | TSTOP | 0 | 0 | PS2 | PS1 | PS0 | | \$0018 | Register (TSC) | | 0 | TOIL | 13101 | TRST | | F 32 | F 3 1 | F 30 | | | See page 148. | Reset: | 0 | 0 | 1 | 0 | 0 | 0 | 0 | 0 | | | TIM Counter Register High | Read: | Bit 15 | 14 | 13 | 12 | 11 | 10 | 9 | Bit 8 | | \$0019 | (TCNTH) | Write: | | | | | | | | | | | See page 150. | Reset: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | TIM Counter Register Low | | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | | \$001A | | Write: | | | | | | | | | | | | Reset: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | TIM Counter Modulo Register | Read: | Bit 15 | 14 | 13 | 12 | 11 | 10 | 9 | Bit 8 | | \$001B High (TMODH) See page 151. | High (TMODH) | Write: | DIL 13 | 14 | 13 | 12 | 11 | 10 | 7 | DILO | | | Reset: | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | | TIM Counter Modulo Register | | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | | \$001C Lo | Low (TMODL) | Write: | Dit 7 | U | 7 | т | , | 2 | - | Dit 0 | | See page 151 | | Reset: | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | | | | = Unimple | emented | | | | | | **Table 13-1. TIM0I Register Summary** #### 13.4.1 TIM0I Counter Prescaler The clock source can be one of the seven prescaler outputs. The prescaler generates seven clock rates from the internal bus clock. The prescaler select bits, PS2–PS0, in the status and control register select the TIM0I clock source. The value in the TIM0I counter modulo registers and the selected prescaler output determines the frequency of the periodic interrupt. The TIM0I overflow flag (TOF) is set when the TIM0I counter value rolls over to \$0000 after matching the value in the TIM0I counter modulo registers. The TIM0I interrupt enable bit, TOIE, enables TIM0I overflow CPU interrupt requests. TOF and TOIE are in the TIM0I status and control register. MC68HC908RC24 — Rev. 1.0 ## **Modulo Timer (TIM0I)** ## 13.5 Interrupts The TIM0I overflow flag (TOF) can generate an interrupt request. The TOF bit is set when the TIM0I counter value rolls over to \$0000 after matching the value in the TIM0I counter modulo registers. The TIM0I overflow interrupt enable bit, TOIE, enables TIM0I overflow CPU interrupt requests. TOF and TOIE are in the TIM0I status and control register. #### 13.6 Low-Power Modes The WAIT and STOP instructions put the MCU in low powerconsumption standby modes. #### 13.6.1 Wait Mode The TIM0I remains active in wait mode. Any enabled CPU interrupt request from the TIM0I can bring the MCU out of wait mode. If TIM0I functions are not required during wait mode, reduce power consumption by stopping the TIM0I before executing the WAIT instruction. ### 13.6.2 Stop Mode The TIM0I is inactive in stop mode. The STOP instruction does not affect register conditions or the state of the TIM0I counter. TIM0I operation resumes when the MCU exits stop mode after an external interrupt. ## 13.7 TIM0I During Break Interrupts A break interrupt stops the TIM0I 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 break flag control register (BFCR) enables software to clear status bits during the break state. (See Section 18. Break Module (BRK).) 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. ## 13.8 I/O Registers These I/O registers control and monitor operation of the TIM0I: - TIM0I status and control register (TSC) - TIM0I counter registers (TCNTH and TCNTL) - TIM0I counter modulo registers (TMODH and TMODL) ## 13.8.1 TIM0I Status and Control Register The TIM0I status and control register: - Enables TIM0I overflow interrupt - Flags TIM0I overflows - Stops the TIM0I counter - Resets the TIM0I counter - Prescales the TIM0I counter clock Figure 13-2. TIM0I Status and Control Register (TSC) #### TOF — TIM0I Overflow Flag Bit This read/write flag is set when the TIM0I counter resets to \$0000 after reaching the modulo value programmed in the TIM0I counter modulo registers. Clear TOF by reading the TIM0I status and control register when TOF is set and then writing a logic 0 to TOF. If another TIM0I 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 = TIM0I counter has reached modulo value. - 0 = TIM0I counter has not reached modulo value. #### TOIE — TIM0I Overflow Interrupt Enable Bit This read/write bit enables TIM0I overflow interrupts when the TOF bit becomes set. Reset clears the TOIE bit. - 1 = TIM0I overflow interrupts enabled - 0 = TIM0I overflow interrupts disabled #### TSTOP — TIM0I Stop Bit This read/write bit stops the TIM0I counter. Counting resumes when TSTOP is cleared. Reset sets the TSTOP bit, stopping the TIM0I counter until software clears the TSTOP bit. - 1 = TIM0I counter stopped - 0 = TIM0I counter active # **NOTE:** Do not set the TSTOP bit before entering wait mode if the TIM0I is required to exit wait mode. Advance Information MC68HC908RC24 — Rev. 1.0 #### TRST — TIM0I Reset Bit Setting this write-only bit resets the TIM0I counter and the TIM0I prescaler. Setting TRST has no effect on any other registers. Counting resumes from \$0000. TRST is cleared automatically after the TIM0I counter is reset and always reads as logic 0. Reset clears the TRST bit. - 1 = Prescaler and TIM0I counter cleared - 0 = No effect # **NOTE:** Setting the TSTOP and TRST bits simultaneously stops the TIM0I counter at a value of \$0000. #### PS2-PS0 — Prescaler Select Bits 011 100 101 110 111 These read/write bits select one of the seven prescaler outputs as the input to the TIM0I counter as **Table 13-2** shows. Reset clears the PS2–PS0 bits. PS2-PS0 TIM0I Clock Source 000 Internal bus clock ÷1 001 Internal bus clock ÷ 2 010 Internal bus clock ÷ 4 Internal bus clock ÷ 8 Internal bus clock + 16 Internal bus clock ÷ 32 Internal bus clock ÷ 64 Internal bus clock ÷ 64 **Table 13-2. Prescaler Selection** #### 13.8.2 TIM0I Counter Registers The two read-only TIM0I counter registers contain the high and low bytes of the value in the TIM0I counter. Reading the high byte (TCNTH) latches the contents of the low byte (TCNTL) into a buffer. Subsequent reads of TCNTH do not affect the latched TCNTL value until TCNTL is read. Reset clears the TIM0I counter registers. Setting the TIM0I reset bit (TRST) also clears the TIM0I counter registers. #### **NOTE:** If TCNTH is read during a break interrupt, be sure to unlatch TCNTL by reading TCNTL before exiting the break interrupt. Otherwise, TCNTL retains the value latched during the break. Figure 13-3. TIM0I Counter Registers (TCNTH and TCNTL) #### 13.8.3 TIM0I Counter Modulo Registers The read/write TIM0I modulo registers contain the modulo value for the TIM0I counter. When the TIM0I counter reaches the modulo value, the overflow flag (TOF) becomes set, and the TIM0I counter resumes counting from \$0000 at the next clock. Writing to the high byte (TMODH) inhibits the TOF bit and overflow interrupts until the low byte (TMODL) is written. Reset sets the TIM0I counter modulo registers. Figure 13-4. TIM0I Counter Modulo Registers (TMODH and TMODL) **NOTE:** Reset the TIM0I counter before writing to the TIM0I counter modulo registers. At every system clock, the TMODH and TMODL value is compared to the TCNTH and TCNTL value. A valid compare flag is asserted on the first cycle in which the values match. If TMODH and TMODL are set to \$0000, a TOF is generated on the first cycle in which the match occurs, but not subsequently. The circuit detects a change in the match value at each clock. ## Section 14. External Interrupt (IRQ) #### 14.1 Contents | 14.2 | Introduction | |------|---------------------------------------| | 14.3 | Features | | 14.4 | Functional Description154 | | 14.5 | IRQ1 Pin | | 14.6 | IRQ Module During Break Interrupts156 | | 14.7 | IRQ Status and Control Register | #### 14.2 Introduction The external interrupt (IRQ) module provides a maskable interrupt input. #### 14.3 Features Features of the IRQ module include: - A dedicated external interrupt pin (IRQ1) - IRQ1 interrupt control bits - Hysteresis buffer - Programmable edge-only or edge- and level-interrupt sensitivity - Automatic interrupt acknowledge ## 14.4 Functional Description A logic 0 applied to the external interrupt pin can latch a central processor unit (CPU) interrupt request. **Figure 14-1** shows the structure of the IRQ module. **NOTE:** The IRQ circuits are powered by the chip $V_{DD}$ . External circuits should drive a logic 1 at the $V_{DD}$ level. If external circuits use a pullup device on $\overline{IRQ1}$ , the pin should be pulled to $V_{DD}$ and **not** to BATT. Interrupt signals on the $\overline{IRQ1}$ pin are latched into the IRQ1 latch. An interrupt latch remains set until one of these actions occurs: - Vector fetch A vector fetch automatically generates an interrupt acknowledge signal that clears the latch that caused the vector fetch. - Software clear Software can clear an interrupt latch by writing to the appropriate acknowledge bit in the interrupt status and control register (ISCR). Writing a logic 1 to the ACK1 bit clears the IRQ1 latch. - Reset A reset automatically clears the interrupt latch. Figure 14-1. IRQ Module Block Diagram The external interrupt pin is falling-edge-triggered and is software-configurable to be either falling-edge or low-level-triggered. The MODE1 bit in the ISCR controls the triggering sensitivity of the IRQ1 pin. When an interrupt pin is edge-triggered only, the interrupt 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 remains set until both of these occur: - Vector fetch or software clear - Return of the interrupt pin to logic 1 The vector fetch or software clear may occur before or after the interrupt pin returns to logic 1. As long as the pin is low, the interrupt request remains pending. A reset will clear the latch and the MODE1 control bit, thereby clearing the interrupt even if the pin stays low. When set, the IMASK1 bit in the ISCR masks all external interrupt requests. A latched interrupt request is not presented to the interrupt priority logic unless the IMASK1 bit is clear. NOTE: The interrupt mask (I) in the condition code register (CCR) masks all interrupt requests, including external interrupt requests. #### 14.5 **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 IRQ1: Vector fetch or software clear — A vector fetch generates an interrupt acknowledge signal to clear the latch. Software may generate the interrupt acknowledge signal by writing a logic 1 to the 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 prior to leaving an interrupt service routine can also prevent MC68HC908RC24 — Rev. 1.0 ## **External Interrupt (IRQ)** 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 generates 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, IRQ1 remains active. 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. A reset will clear the latch and the MODE1 control bit, thereby clearing the interrupt even if the pin stays low. If the MODE1 bit is clear, the $\overline{IRQ1}$ pin is falling-edge-sensitive only. With MODE1 clear, a vector fetch or software clear immediately clears the IRQ1 latch. The IRQF1 bit in the ISCR register can be used to check for pending interrupts. The IRQF1 bit is not affected by the IMASK1 bit, which makes it useful in applications where polling is preferred. 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. ## 14.6 IRQ Module During Break Interrupts The BCFE bit in the break flag control register (BFCR) enables software to clear the latch during the break state. See **Section 18. Break Module** (BRK). To allow software to clear the IRQ1 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 CPU interrupt flags during the break state, write a logic 0 to the BCFE bit. With BCFE at logic 0 (its default state), writing to the ACK1 bit in the IRQ status and control register during the break state has no effect on the IRQ interrupt flags. Advance Information MC68HC908RC24 — Rev. 1.0 ### 14.7 IRQ Status and Control Register The IRQ status and control register (ISCR) controls and monitors operation of the IRQ module. The ISCR has these functions: - Shows the state of the IRQ1 flag - · Clears the IRQ1 latch - Masks IRQ1 interrupt request - Controls triggering sensitivity of the IRQ1 interrupt pin Figure 14-2. IRQ Status and Control Register (ISCR) IRQF1 — IRQ1 Flag This read-only status bit is high when the IRQ1 interrupt is pending. 1 = IRQ1 interrupt pending $0 = \overline{IRQ1}$ interrupt not pending 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 requests on falling edges and low levels $0 = \overline{IRQ1}$ interrupt requests on falling edges only MC68HC908RC24 — Rev. 1.0 ## External Interrupt (IRQ) ## Section 15. Keyboard Interrupt Module (KBI) #### 15.1 Contents | Introduction | |-----------------------------------------| | Features | | Functional Description | | Keyboard Initialization162 | | Low-Power Modes | | Keyboard Module During Break Interrupts | | I/O Registers | | | #### 15.2 Introduction The keyboard interrupt module (KBI) provides eight independently maskable external interrupts. #### 15.3 Features #### Features of the KBI include: - Eight keyboard interrupt pins with separate keyboard interrupt enable bits and one keyboard interrupt mask - Hysteresis buffers - Programmable edge-only or edge- and level- interrupt sensitivity - Exit from low-power modes Figure 15-1. Keyboard Module Block Diagram Figure 15-2. Keyboard Module I/O Register Summary Advance Information MC68HC908RC24 — Rev. 1.0 ## **15.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 is latched when one or more keyboard pins goes low after all were high. The MODEK bit in the keyboard status and control register controls the triggering mode of the keyboard interrupt. - If the keyboard interrupt is edge-sensitive only, a falling edge on a keyboard pin does not latch an interrupt request if another keyboard pin is already low. To prevent losing an interrupt request on one pin because another pin is still low, software can disable the latter pin while it is low. - If the keyboard interrupt is falling edge- and low level-sensitive, an interrupt request is present as long as any keyboard pin is low. If the MODEK bit is set, the keyboard interrupt pins are both falling edgeand low level-sensitive, and both of the following actions must occur to clear a keyboard interrupt request: • Vector fetch or software clear — A vector fetch generates an interrupt acknowledge signal to clear the interrupt request. Software may generate the interrupt acknowledge signal by writing a logic 1 to the ACKK bit in the keyboard status and control register (KBSCR). The ACKK bit is useful in applications that poll the keyboard interrupt pins and require software to clear the keyboard interrupt request. Writing to the ACKK bit prior to leaving an interrupt service routine can also prevent spurious interrupts due to noise. Setting ACKK does not affect subsequent transitions on the keyboard interrupt pins. A falling edge that occurs after writing to the ACKK bit latches another interrupt request. If the keyboard interrupt mask bit, IMASKK, is clear, the CPU loads the program counter with the vector address at locations \$FFF4 and \$FFF5. MC68HC908RC24 — Rev. 1.0 ## **Keyboard Interrupt Module (KBI)** 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 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. If the MODEK bit is clear, the keyboard interrupt pin is falling-edge-sensitive only. With MODEK clear, a vector fetch or software clear immediately clears the keyboard interrupt request. Reset clears the keyboard interrupt request and the MODEK bit, clearing the interrupt request even if a keyboard interrupt pin stays at logic 0. The keyboard flag bit (KEYF) in the keyboard status and control register can be used to see if a pending interrupt exists. The KEYF bit is not affected by the keyboard interrupt mask bit (IMASKK) which makes it useful in applications where polling is preferred. 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. ## 15.5 Keyboard Initialization When a keyboard interrupt pin is enabled, the pin may initially be low and cause a false interrupt to occur. A false interrupt on an edge-triggered pin can be acknowledged immediately after enabling the pin. A false interrupt on an edge- and level-triggered interrupt pin must be acknowledged after the pin has been pulled high. The internal pullup device, the pin capacitance, as well as the external load will factor into the actual amount of time it takes for the pin to pull high. Considering only an internal pullup of 48 k $\Omega$ and pin capacitance of 8 pF, the pullup time will be on the order of 1 $\mu$ s. To prevent a false interrupt on keyboard initialization: - 1. Mask keyboard interrupts by setting the IMASKK bit in the keyboard status and control register. - 2. Enable the KBI pins by setting the appropriate KBIEx bits in the keyboard interrupt enable register. - 3. Write to the ACKK bit in the keyboard status and control register to clear any false interrupts. - 4. Clear the IMASKK bit. 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. #### 15.6 Low-Power Modes The WAIT and STOP instructions put the MCU in low powerconsumption standby modes. #### 15.6.1 Wait Mode The keyboard module remains active in wait mode. Clearing the IMASKK bit in the keyboard status and control register enables keyboard interrupt requests to bring the MCU out of wait mode. #### **15.6.2 Stop Mode** The keyboard module remains active in stop mode. Clearing the IMASKK bit in the keyboard status and control register enables keyboard interrupt requests to bring the MCU out of stop mode. MC68HC908RC24 — Rev. 1.0 ## **Keyboard Interrupt Module (KBI)** ## 15.7 Keyboard Module During Break Interrupts The system integration module (SIM) controls whether the keyboard interrupt latch can be cleared during the break state. The BCFE bit in the break flag control register (BFCR) enables software to clear status bits during the break state. To allow software to clear the keyboard 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 latch during the break state, write a logic 0 to the BCFE bit. With BCFE at logic 0 (its default state), writing to the keyboard acknowledge bit (ACKK) in the keyboard status and control register during the break state has no effect. See 15.8.1 Keyboard Status and Control Register. ## 15.8 I/O Registers Two input/output registers control and monitor operation of the keyboard module: - Keyboard status and control register (KBSCR) - Keyboard interrupt enable register (KBIER) ### 15.8.1 Keyboard Status and Control Register The keyboard status and control register (KBSCR): - Flags keyboard interrupt requests - Acknowledges keyboard interrupt requests - Masks keyboard interrupt requests - Controls keyboard interrupt triggering sensitivity Figure 15-3. Keyboard Status and Control Register (KBSCR) Bits 7-4 — Not used These read-only bits always read as logic 0s. #### KEYF — Keyboard Flag This read-only bit is set when a keyboard interrupt is pending. Reset clears the KEYF bit. - 1 = Keyboard interrupt pending - 0 = No keyboard interrupt pending #### ACKK — Keyboard Acknowledge Bit Writing a logic 1 to this write-only bit clears the keyboard interrupt request. ACKK always reads as logic 0. Reset clears ACKK. #### IMASKK — Keyboard Interrupt Mask Bit Writing a logic 1 to this read/write bit prevents the output of the keyboard interrupt mask from generating interrupt requests. Reset clears the IMASKK bit. - 1 = Keyboard interrupt requests masked - 0 = Keyboard interrupt requests not masked #### MODEK — Keyboard Triggering Sensitivity Bit This read/write bit controls the triggering sensitivity of the keyboard interrupt pins. Reset clears MODEK. - 1 = Keyboard interrupt requests on falling edges and low levels - 0 = Keyboard interrupt requests on falling edges only ## 15.8.2 Keyboard Interrupt Enable Register The keyboard interrupt enable register (KBIER) enables or disables each port B pin to operate as a keyboard interrupt pin. Figure 15-4. 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 = PTBx pin enabled as keyboard interrupt pin - 0 = PTBx pin not enabled as keyboard interrupt pin ## **Section 16. Computer Operating Properly (COP)** ## 16.1 Contents | 16.2 | Introduction | |--------|------------------------------| | 16.3 | Functional Description168 | | 16.4 | I/O Signals | | 16.4.1 | CGMXCLK | | 16.4.2 | STOP Instruction | | 16.4.3 | COPCTL Write | | 16.4.4 | Power-On Reset | | 16.4.5 | Internal Reset | | 16.4.6 | Reset Vector Fetch170 | | 16.4.7 | COPD (COP Disable)170 | | 16.4.8 | | | 16.5 | COP Control Register170 | | 16.6 | Interrupts171 | | 16.7 | Monitor Mode | | 16.8 | Low-Power Modes | | 16.8.1 | Wait Mode | | 16.8.2 | Stop Mode | | 16.9 | COP Module During Break Mode | #### 16.2 Introduction This computer operating properly (COP) module contains a free-running counter that generates a reset if allowed to overflow. The COP module helps software recover from runaway code. Clearing the COP counter periodically prevents a reset. ## 16.3 Functional Description Figure 16-1 shows the structure of the COP module. Figure 16-1. COP Block Diagram The COP counter is a free-running 6-bit counter preceded by a 12-bit prescaler counter. If not cleared by software, the COP counter overflows and generates an asynchronous reset after $2^{18} - 2^4$ or $2^{13} - 2^4$ CGMXCLK cycles, depending on the state of the COP rate select bit COPRS, in the configuration register (CONFIG). With a $2^{18} - 2^4$ CGMXCLK cycle overflow option, a 4.9152-MHz crystal gives a COP timeout period is 53.3 ms. Writing any value to location \$FFFF before an overflow occurs prevents a COP reset by clearing the COP counter and stages 12 through 5 of the prescaler. #### NOTE: Service the COP immediately after reset and before entering or after exiting stop mode to guarantee the maximum time before the first COP counter overflow. A COP reset pulls the RST pin low for 32 CGMXCLK cycles and sets the COP bit in the reset status register (RSR). In monitor mode, the COP is disabled if the $\overline{RST}$ pin or the $\overline{IRQ1}$ is held at $V_{TST}$ . During the break state, $V_{TST}$ on the $\overline{RST}$ pin disables the COP. #### NOTE: Place COP clearing instructions in the main program and not in an interrupt subroutine. Such an interrupt subroutine could keep the COP from generating a reset even while the main program is not working properly. ## 16.4 I/O Signals This section describes the signals shown in Figure 16-1. #### 16.4.1 CGMXCLK CGMXCLK is the crystal oscillator output signal. CGMXCLK frequency is equal to the crystal frequency. #### 16.4.2 STOP Instruction The STOP instruction clears the COP prescaler. #### 16.4.3 COPCTL Write Writing any value to the COP control register (COPCTL) (see **16.5 COP Control Register**) clears the COP counter and clears bits 12–5 of the prescaler. Reading the COP control register returns the low byte of the reset vector. MC68HC908RC24 — Rev. 1.0 ## **Computer Operating Properly (COP)** #### 16.4.4 Power-On Reset The power-on reset (POR) circuit clears the COP prescaler 4096 CGMXCLK cycles after power-up. #### 16.4.5 Internal Reset An internal reset clears the COP prescaler and the COP counter. #### 16.4.6 Reset Vector Fetch A reset vector fetch occurs when the vector address appears on the data bus. A reset vector fetch clears the COP prescaler. #### 16.4.7 COPD (COP Disable) The COPD signal reflects the state of the COP disable bit (COPD) in the configuration register (CONFIG). #### 16.4.8 COPRS (COP Rate Select) The COPRS signal reflects the state of the COP rate select bit (COPRS) in the configuration register. ## 16.5 COP Control Register The COP control register is located at address \$FFFF and overlaps the reset vector. Writing any value to \$FFFF clears the COP counter and starts a new timeout period. Reading location \$FFFF returns the low byte of the reset vector. See **Figure 16-2**. Figure 16-2. COP Control Register (COPCTL) ## 16.6 Interrupts The COP does not generate central processor unit (CPU) interrupt requests. #### 16.7 Monitor Mode The COP is disabled in monitor mode when $V_{TST}$ is present on the $\overline{IRQ1}$ pin or on the $\overline{RST}$ pin. #### 16.8 Low-Power Modes The WAIT and STOP instructions put the MCU in low powerconsumption standby modes. #### **16.8.1 Wait Mode** The COP remains active during wait mode. To prevent a COP reset during wait mode, periodically clear the COP counter in a CPU interrupt routine. #### 16.8.2 Stop Mode Stop mode turns off the CGMXCLK input to the COP and clears the COP prescaler. Service the COP immediately before entering or after exiting stop mode to ensure a full COP timeout period after entering or exiting stop mode. MC68HC908RC24 — Rev. 1.0 ## **Computer Operating Properly (COP)** The STOP bit in the CONFIG register enables the STOP instruction. To prevent inadvertently turning off the COP with a STOP instruction, disable the STOP instruction by clearing the STOP bit. ## 16.9 COP Module During Break Mode The COP is disabled during a break interrupt when $V_{TST}$ is present on the $\overline{RST}$ pin. ## **Section 17. Monitor ROM (MON)** #### 17.1 Contents | 17.2 | Introduction173 | |--------|------------------------| | 17.3 | Features | | 17.4 | Functional Description | | 17.4.1 | Entering Monitor Mode | | 17.4.2 | Data Format | | 17.4.3 | Break Signal | | 17.4.4 | Baud Rate178 | | 17.4.5 | Commands179 | | 17.5 | Security 183 | ## 17.2 Introduction This section describes the monitor read-only memory (MON). The monitor ROM allows complete testing of the MCU through a single-wire interface with a host computer. MC68HC908RC24 — Rev. 1.0 #### 17.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 - Execution of code in random-access memory (RAM) or ROM - ROM memory security<sup>(1)</sup> ## 17.4 Functional Description The monitor ROM receives and executes commands from a host computer. **Figure 17-1** shows an example 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. Advance Information MC68HC908RC24 — Rev. 1.0 <sup>1.</sup> No security feature is absolutely secure. However, Motorola's strategy is to make reading or copying the ROM difficult for unauthorized users. Figure 17-1. Monitor Mode Circuit MC68HC908RC24 — Rev. 1.0 #### 17.4.1 Entering Monitor Mode **Table 17-1** shows the pin conditions for entering monitor mode. **Table 17-1. Monitor Mode Entry** | IRQ1 Pin | PTA7 Pin | PTC1 Pin | PTC2 Pin | PTA0 Pin | PTC3 Pin | CGMOUT | Bus<br>Frequency | |------------------|----------|----------|----------|----------|----------|--------------|------------------| | V <sub>TST</sub> | 0 | 1 | 0 | 1 | 1 | CGMXCLK<br>2 | CGMOUT | | VISI | | ' | | , I | 0 | CGMXCLK | 2 | If PTC3 is low upon monitor mode entry, CGMOUT is equal to the crystal frequency. The bus frequency in this case is a divide-by-two of the input clock. If PTC3 is high upon monitor mode entry, the bus frequency will be a divide-by-four of the input clock. **NOTE:** Holding the PTC3 pin low when entering monitor mode causes a bypass of a divide-by-two stage at the oscillator. The CGMOUT frequency is equal to the CGMXCLK frequency, and the OSC1 input directly generates internal bus clocks. In this case, the OSC1 signal must have a 50 percent duty cycle at maximum bus frequency. Enter monitor mode with the pin configuration shown above by pulling RST low and then high. The rising edge of RST latches monitor mode. Once monitor mode is latched, the values on the specified pins can change. **NOTE:** The PTA7 pin must remain at logic 0 for 24 bus cycles after the RST pin goes high. Once out of reset, the MCU waits for the host to send eight security bytes. (See 17.5 Security.) After the security bytes, the MCU sends a break signal (10 consecutive logic 0s) to the host, indicating that it is ready to receive a command. In monitor mode, the MCU uses different vectors for reset, software interrupt (SWI), and break interrupt than those for user mode. 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_{TST}$ is applied to either the $\overline{IRQ}$ pin or the $\overline{RST}$ pin. **Table 17-2** summarizes the differences between user mode and monitor mode. **Functions** SWI Reset Reset **Break Break** SWI Modes COP Vector Vector Vector Vector Vector Vector High High Low High Low Low User Enabled \$FFFE \$FFFF \$FFFC \$FFFD \$FFFC \$FFFD Disabled<sup>(1)</sup> Monitor \$FEFE \$FEFF \$FEFC \$FEFD \$FEFC \$FEFD **Table 17-2. Mode Differences** #### 17.4.2 Data Format Communication with the monitor ROM is in standard non-return-to-zero (NRZ) mark/space data format. Transmit and receive baud rates must be identical. Figure 17-2. Monitor Data Format If the high voltage (V<sub>TST</sub>) is removed from the IRQ1 pin or the RST pin, the SIM asserts its COP enable output. The COP is a configuration option enabled or disabled by the COPD bit in the configuration register. #### 17.4.3 Break Signal A start bit (logic 0) followed by nine logic 0 bits is a break signal. When the monitor receives a break signal, it drives the PTA0 pin high for the duration of two bits and then echoes back the break signal. Figure 17-3. Break Transaction #### 17.4.4 Baud Rate The communication baud rate is controlled by the crystal frequency and the state of the PTC3 pin upon entry into monitor mode. When PTC3 is high, the divide by ratio is 1024. If the PTC3 pin is at logic 0 upon entry into monitor mode, the divide by ratio is 512. **Table 17-3** lists crystal frequencies required to achieve standard baud rates. Other standard baud rates can be accomplished using higher crystal frequencies. Table 17-3. Monitor Baud Rate Selection | Crystal<br>Frequency (MHz) | PTC3 Pin | Baud Rate | |----------------------------|----------|-----------| | 4.9152 | 0 | 9600 | | 4.9152 | 1 | 4800 | #### 17.4.5 Commands The monitor ROM firmware uses these commands: - READ (read memory) - WRITE (write memory) - IREAD (indexed read) - IWRITE (indexed write) - READSP (read stack pointer) - RUN (run user program) The monitor ROM firmware echoes each received byte back to the PTA0 pin for error checking. An 11-bit delay at the end of each command allows the host to send a break character to cancel the command. A delay of two bit times occurs before each echo and before READ, IREAD, or READSP data is returned. The data returned by a read command appears after the echo of the last byte of the command. **NOTE:** Wait one bit time after each echo before sending the next byte. Figure 17-4. Read Transaction Figure 17-5. Write Transaction MC68HC908RC24 — Rev. 1.0 Refer to Table 17-4, Table 17-5, Table 17-6, Table 17-7, Table 17-8, and Table 17-9 for brief descriptions of each monitor mode command. Description Read byte from memory 2-byte address in high byte:low byte order **Operand** Data Returns contents of specified address Returned **Opcode** \$4A **Command Sequence** SENT TO **MONITOR** ADDRESS LOW ADDRESS ADDRESS ADDRESS READ DATA READ HIGH HIGH LOW ЕСНО RETURN Table 17-4. READ (Read Memory) Command Table 17-5. WRITE (Write Memory) Command | Description | Write byte to memory | | | | | | | | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|--|--|--|--|--|--|--| | Operand | 2-byte address in high byte:low byte order; low byte followed by data byte | | | | | | | | | Data<br>Returned | None | | | | | | | | | Opcode | \$49 | | | | | | | | | Command Sequence | | | | | | | | | | FROM<br>HOST | | | | | | | | | | WRITE WRITE WADDRESS ADDRESS A | | | | | | | | | Advance Information MC68HC908RC24 — Rev. 1.0 Table 17-6. IREAD (Indexed Read) Command Table 17-7. IWRITE (Indexed Write) Command **NOTE:** A sequence of IREAD or IWRITE commands can access a block of memory sequentially over the full 64-Kbyte memory map. Table 17-8. READSP (Read Stack Pointer) Command Table 17-9. RUN (Run User Program) Command | Description | Executes PULH and RTI instructions | |------------------|------------------------------------| | Operand | None | | Data<br>Returned | None | | Opcode | \$28 | | | Command Sequence | | | FROM HOST V RUN V RUN ECHO | **Advance Information** MC68HC908RC24 — Rev. 1.0 The MCU executes the SWI and PSHH instructions when it enters monitor mode. The RUN command tells the MCU to execute the PULH and RTI instructions. Before sending the RUN command, the host can modify the stacked CPU registers to prepare to run the host program. The READSP command returns the incremented stack pointer value, SP + 1. The high and low bytes of the program counter are at addresses SP + 5 and SP + 6. Figure 17-6. Stack Pointer at Monitor Mode Entry ## 17.5 Security A security feature discourages unauthorized reading of ROM and FLASH locations while in monitor mode. The host can bypass the security feature at monitor mode entry by sending eight security bytes that match the bytes at locations \$FFF6-\$FFFD. Locations \$FFF6-\$FFFD contain user-defined data. #### **NOTE:** Do not leave locations \$FFF6—\$FFFD blank. For security reasons, program locations \$FFF6—\$FFFD even if they are not used for vectors. During monitor mode entry, the MCU waits after the power-on reset for the host to send the eight security bytes on pin PA0. Figure 17-7. Monitor Mode Entry Timing If the received bytes match those at locations \$FFF6—\$FFFD, the host bypasses the security feature and can read all ROM locations and execute code from ROM. Security remains bypassed until a power-on reset occurs. After the host bypasses security, any reset other than a power-on reset requires the host to send another eight bytes. If the reset was not a power-on reset, security remains bypassed regardless of the data that the host sends. If the received bytes do not match the data at locations \$FFF6—\$FFFD, the host fails to bypass the security feature. The MCU remains in monitor mode, but reading ROM locations returns undefined data, and trying to execute code from ROM causes an illegal address reset. After the host fails to bypass security, any reset other than a power-on reset causes an endless loop of illegal address resets. After receiving the eight security bytes from the host, the MCU transmits a break character signalling that it is ready to receive a command. **NOTE:** The MCU does not transmit a break character until after the host sends the eight security bytes. Advance Information MC68HC908RC24 — Rev. 1.0 # Section 18. Break Module (BRK) #### 18.1 Contents | 18.2 | Introduction | |--------|--------------------------------------------| | 18.3 | Features | | 18.4 | Functional Description186 | | 18.4.1 | Flag Protection During Break Interrupts188 | | 18.4.2 | CPU During Break Interrupts | | 18.4.3 | TIM0I During Break Interrupts | | 18.4.4 | COP During Break Interrupts | | 18.5 | Low-Power Modes | | 18.5.1 | Wait Mode | | 18.5.2 | Stop Mode | | 18.6 | Break Module Registers | | 18.6.1 | Break Status and Control Register189 | | 18.6.2 | Break Address Registers | | 18.6.3 | Break Status Register191 | | 18.6.4 | Break Flag Control Register192 | ## 18.2 Introduction This section describes the break module (BRK). The break module can generate a break interrupt that stops normal program flow at a defined address to enter a background program. MC68HC908RC24 — Rev. 1.0 Advance Information #### 18.3 Features Features of the break module include: - Accessible input/output (I/O) registers during the break interrupt - Central processor unit (CPU) generated break interrupts - Software-generated break interrupts - Computer operating properly (COP) disabling during break interrupts ## **18.4 Functional Description** When the internal address bus matches the value written in the break address registers, the break module issues a breakpoint signal to the CPU. The CPU then loads 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 18-1 shows the structure of the break module. Figure 18-1. Break Module Block Diagram | Addr. | Register Name | | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | |------------------------------------|---------------------------------------|-----------------|-----------|---------|----|------------|----|----|------|-------| | | Break Status Register | Read: | 0 | 0 | 0 | 1 | 0 | 0 | BW | 0 | | \$FE00 | (BSR) | Write: | R | R | R | R | R | R | Note | R | | See page 191. | Reset: | 0 | 0 | 0 | 1 | 0 | 0 | 0 | 0 | | | \$FE03 | | Read:<br>Write: | BCFE | R | R | R | R | R | R | R | | See page 192 | Reset: | 0 | | | | | | | | | | \$FE0C | Break Address Register High<br>(BRKH) | Read:<br>Write: | Bit 15 | 14 | 13 | 12 | 11 | 10 | 9 | Bit 8 | | | See page 190. | Reset: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | \$FE0D | Break Address Register Low<br>(BRKL) | Read:<br>Write: | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | | | See page 190. | Reset: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Break Status and Control | Read: | BRKE | BRKA | 0 | 0 | 0 | 0 | 0 | 0 | | \$FE0E | Register (BSCR) | Write: | DKKE | DKKA | | | | | | | | | See page 189. | Reset: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Note: Writing a logic 0 clears BW. | | | = Unimple | emented | R | = Reserved | | | | | Figure 18-2. Break Module Register Summary MC68HC908RC24 — Rev. 1.0 Advance Information ## 18.4.1 Flag Protection During Break Interrupts The BCFE bit in the break flag control register (BFCR) enables software to clear status bits during the break state. ## 18.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 and \$FFFD (\$FEFC and \$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. ## 18.4.3 TIM0I During Break Interrupts A break interrupt stops the timer counter. ## **18.4.4 COP During Break Interrupts** The COP is disabled during a break interrupt when $V_{TST}$ is present on the $\overline{RST}$ pin. #### 18.5 Low-Power Modes The WAIT and STOP instructions put the MCU in low powerconsumption standby modes. #### **18.5.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. See **Section 7. Low-Power Modes**. Clear the BW bit by writing logic 0 to it. Advance Information MC68HC908RC24 — Rev. 1.0 ## **18.5.2 Stop Mode** A break interrupt causes exit from stop mode and sets the SBSW bit in the break status register. ## 18.6 Break Module Registers These registers control and monitor operation of the break module: - Break status and control register (BSCR) - Break address register high (BRKH) - Break address register low (BRKL) - Break status register (BSR) - Break flag control register (BFCR) ## 18.6.1 Break Status and Control Register The break status and control register (BSCR) contains break module enable and status bits. Figure 18-3. Break Status and Control Register (BSCR) #### 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 = When read, break address match - 0 = When read, no break address match ## 18.6.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. | Register Name and Address: BRKH—\$FE0C | | | | | | | | | |----------------------------------------|------------|-------------|--------|----|----|----|---|-------| | | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | | Read:<br>Write: | Bit 15 | 14 | 13 | 12 | 11 | 10 | 9 | Bit 8 | | Reset: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | Register Na | ame and Ad | dress: BRKI | \$FE0D | | | | | | | Read: Write: | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | | Reset: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | Figure 18-4. Break Address Registers (BRKH and BRKL) #### 18.6.3 Break Status Register The break status register (BSR) contains a flag to indicate that a break caused an exit from wait mode. The flag is useful in applications requiring a return to wait mode after exiting from a break interrupt. Figure 18-5. Break Status Register (BSR) #### BW — Break Wait Bit This read/write bit is set when a break interrupt causes an exit from wait mode. Clear BW by writing a logic 0 to it. Reset clears BW. - 1 = Break interrupt during wait mode - 0 = No break interrupt during wait mode BW can be read within the break interrupt routine. The user can modify the return address on the stack by subtracting 1 from it. The following code is an example. This code works if the H register was stacked in the break interrupt routine. Execute this code at the end of the break interrupt routine. ``` HIBYTEEOU LOBYTE EQU 6 If not BW, do RTI BRCLRBW, BSR, RETURN ; See if wait mode or stop mode ; was exited by break. TST LOBYTE, SP ; If RETURNLO is not 0, ; then just decrement low byte. BNE DOLO DEC HIBYTE, SP ; Else deal with high byte also. DEC LOBYTE, SP DOLO ; Point to WAIT/STOP opcode. RETURNPULH ; Restore H register. RTI ``` MC68HC908RC24 — Rev. 1.0 Advance Information ## 18.6.4 Break Flag Control Register The break flag control register (BFCR) contains a bit that enables software to clear status bits while the MCU is in a break state. Figure 18-6. Break Flag Control Register (BFCR) ## 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 # **Section 19. Preliminary Electrical Specifications** ## 19.1 Contents | 19.2 | Introduction | |-------|---------------------------------------------| | 19.3 | Absolute Maximum Ratings | | 19.4 | Functional Operating Range195 | | 19.5 | Thermal Characteristics | | 19.6 | 3.3-Volt DC Electrical Characteristics196 | | 19.7 | 2.0-Volt DC Electrical Characteristics197 | | 19.8 | Control Timing | | 19.9 | Oscillator Characteristics | | 19.10 | LVI Characteristics | | 19.11 | Battery Detection Characteristics200 | | 19.12 | Battery Circuit Component Specifications200 | | 19.13 | Memory Characteristics201 | ## 19.2 Introduction This section contains electrical and timing specifications. These values are design targets and have not yet been fully tested. ## **Preliminary Electrical Specifications** ## 19.3 Absolute Maximum Ratings Maximum ratings are the extreme limits to which the MCU can be exposed without permanently damaging it. NOTE: This device is not guaranteed to operate properly at the maximum ratings. Refer to 19.6 3.3-Volt DC Electrical Characteristics and 19.7 2.0-Volt DC Electrical Characteristics for guaranteed operating conditions. | Characteristic <sup>(1)</sup> | Symbol | Value | Unit | |-----------------------------------------------------------------------|-------------------|--------------------------------|------| | Supply voltage | $V_{DD}$ | -0.3 to +6.0 | V | | Input voltage | V <sub>In</sub> | $V_{SS}$ =0.3 to $V_{DD}$ +0.3 | V | | Maximum current per pin 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 | <sup>1.</sup> Voltages referenced to $V_{SS}$ . NOTE: This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields; however, it is advised that normal precautions be taken to avoid application of any voltage higher than maximum-rated voltages to this high-impedance circuit. For proper operation, it is recommended that $V_{ln}$ and $V_{Out}$ be constrained to the range $V_{SS} \leq (V_{ln} \text{ or } V_{Out}) \leq V_{DD}$ . Reliability of operation is enhanced if unused inputs are connected to an appropriate logic voltage level (for example, either $V_{SS}$ or $V_{DD}$ .) ## 19.4 Functional Operating Range | Characteristic | Symbol | Min | Max | Unit | |-------------------------------------------|-----------------|-----|-----|------| | Operating temperature range | T <sub>A</sub> | 0 | 70 | °C | | Operating voltage range (1) | V <sub>DD</sub> | 1.8 | 3.6 | V | | Battery input operating voltage range (2) | BATT | 2.1 | 3.6 | ٧ | V<sub>DD</sub> is the supply node for the MCU. V<sub>DD</sub> is supplied from the BATT pin and is calculated as V<sub>DD</sub> = V<sub>BATT</sub> - V<sub>F</sub> where V<sub>F</sub> is the forward voltage of the internal P-channel MOSFET. See 19.11 Battery Detection Characteristics. Minimum to be a supply of the internal P-channel MCU operation. The MCU will operate lower than the battery voltage for guaranteed MCU operation. The MCU will operate lower ## 19.5 Thermal Characteristics | Characteristic | Symbol | Value | Unit | |-----------------------------------|------------------|-------------------------------------------------------------|------| | Thermal resistance SOIC PDIP LQFP | $\theta_{JA}$ | 60<br>60<br>124 | °C/W | | I/O pin power dissipation | P <sub>I/O</sub> | User determined | W | | Power dissipation <sup>(1)</sup> | P <sub>D</sub> | (I <sub>BATT</sub> x V <sub>BATT</sub> ) + P <sub>I/O</sub> | W | | Average junction temperature | T <sub>J</sub> | $T_A + (P_D \times \theta_{JA})$ | °C | | Maximum junction temperature | T <sub>JM</sub> | 125 | °C | <sup>1.</sup> Power dissipation is a function of temperature. when the LVI trip point (V<sub>LVR</sub>) is less than maximum. ## **Preliminary Electrical Specifications** #### 19.6 3.3-Volt DC Electrical Characteristics | Characteristic <sup>(1)</sup> | Symbol | Min | Тур <sup>(2)</sup> | Max | Unit | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|----------------------------------------------------------------------|-----------------------------------------|-------------------------------------------|----------------------------------| | Output high voltage (I <sub>Load</sub> = -2.5 mA) port A, port B (I <sub>Load</sub> = -12 mA) IRO (I <sub>Load</sub> = -3.0 mA) port C | V <sub>OH</sub><br>V <sub>OH</sub><br>V <sub>OH</sub> | V <sub>DD</sub> -0.3<br>V <sub>DD</sub> -0.7<br>V <sub>DD</sub> -0.3 | | | V<br>V<br>V | | Output low voltage (I <sub>Load</sub> = 4 mA) port A, port B (I <sub>Load</sub> = 24 mA) IRO (I <sub>Load</sub> = 14 mA) port C | V <sub>OL</sub><br>V <sub>OL</sub><br>V <sub>OL</sub> | _<br>_<br>_<br>_ | | 0.3<br>0.8<br>0.3 | V<br>V<br>V | | Input high voltage All ports, IRQ1, RST, BATT, OSC1 | V <sub>IH</sub> | 0.7 x V <sub>DD</sub> | _ | V <sub>DD</sub> | V | | Input low voltage All ports, IRQ1, RST, BATT, OSC1 | V <sub>IL</sub> | V <sub>SS</sub> | _ | 0.3 x V <sub>DD</sub> | V | | $V_{DD}$ supply current Run, $f_{OP} = 2.0 \text{ MHz}^{(3)}$ Wait <sup>(4)</sup> Stop <sup>(5)</sup> 25°C 0°C to 70°C LP reset with battery out <sup>(6)</sup> 25°C 0°C to 70°C | I <sub>DD</sub> | _<br>_<br>_<br>_<br>_ | 3<br>1.25<br>1.0<br>1.0<br>0.25<br>0.25 | 3.3<br>1.75<br>1.0<br>1.0<br>0.25<br>0.25 | mA<br>mA<br>μA<br>μA<br>μA<br>mA | | I/O ports hi-z leakage current | I <sub>IL</sub> | _ | _ | ± 4 | μА | | Input current | I <sub>In</sub> | _ | _ | ± 1 | μΑ | | Capacitance Ports (as input or output), RST, IRQ1, BATT | C <sub>Out</sub><br>C <sub>In</sub> | | _ | 12<br>8 | pF | | Monitor mode entry voltage | V <sub>TST</sub> | V <sub>DD</sub> + 2.5 | _ | 9 | V | | Pullup resistor PTB7/KBD7–PTB0/KBD0 25°C 0°C to 70°C | R <sub>PU</sub> | 27<br>24 | _ | 39<br>48 | kΩ | <sup>1.</sup> $V_{DD}$ = 3.3 Vdc $\pm$ 10%, $V_{SS}$ = 0 Vdc, $T_A$ = $T_L$ to $T_H$ , unless otherwise noted 2. Typical values reflect average measurements at midpoint of voltage range, 25°C only. <sup>3.</sup> Run (operating) I<sub>DD</sub> measured using external square wave clock source. LVI enabled. 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<sub>DD</sub>. Measured with all modules enabled. <sup>4.</sup> Wait I<sub>DD</sub> measured using external square wave clock source (f<sub>CGMXCLK</sub> = 4 MHz); all inputs 0.2 V from rail; no dc loads; less than 100 pF on all outputs. $C_L = 20$ pF on OSC2; OSC2 capacitance linearly affects wait $I_{DD}$ . <sup>5.</sup> Stop I<sub>DD</sub> measured with OSC1 grounded and no port pins sourcing current. LVI is disabled by stop entry. <sup>6.</sup> I<sub>DD</sub> measurement when BATT supply is removed and part is in LP reset. ## 19.7 2.0-Volt DC Electrical Characteristics | Characteristic <sup>(1)</sup> | Symbol | Min | Typ <sup>(2)</sup> | Max | Unit | |--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|----------------------------------------------------------------------|--------------------------------------|---------------------------------|----------------------------| | Output high voltage (I <sub>Load</sub> = -1.2 mA) port A, port B (I <sub>Load</sub> = -6 mA) IRO (I <sub>Load</sub> = -1.2 mA) port C | V <sub>OH</sub><br>V <sub>OH</sub><br>V <sub>OH</sub> | V <sub>DD</sub> -0.3<br>V <sub>DD</sub> -0.7<br>V <sub>DD</sub> -0.3 | | _<br>_<br>_ | V<br>V<br>V | | Output low voltage (I <sub>Load</sub> = 2 mA) port A,port B (I <sub>Load</sub> = 11 mA) IRO (I <sub>Load</sub> = 7 mA) port C | V <sub>OL</sub><br>V <sub>OL</sub><br>V <sub>OL</sub> | _<br>_<br>_ | | 0.3<br>0.8<br>0.3 | V<br>V<br>V | | Input high voltage All ports, IRQ1, RST, BATT, OSC1 | V <sub>IH</sub> | 0.7 x V <sub>DD</sub> | _ | V <sub>DD</sub> | V | | Input low voltage All ports, IRQ1, RST, BATT, OSC1 | V <sub>IL</sub> | V <sub>SS</sub> | _ | 0.3 x V <sub>DD</sub> | V | | V <sub>DD</sub> supply current Run, f <sub>OP</sub> = 2.0 MHz <sup>(3)</sup> Wait <sup>(4)</sup> Stop <sup>(5)</sup> or LP reset with battery in <sup>(6)</sup> 25°C 0°C to 70°C LP reset with battery out <sup>(7)</sup> 25°C 0°C to 70°C | I <sub>DD</sub> | _<br>_<br>_<br>_<br>_ | 1<br>0.5<br>0.3<br>0.3<br>0.1<br>0.1 | 1.1<br>0.6<br>0.5<br>0.5<br>0.1 | mA<br>mA<br>μA<br>μA<br>μA | | I/O ports hi-z leakage current | I <sub>IL</sub> | _ | _ | ± 4 | μА | | Input current | I <sub>In</sub> | _ | _ | ± 1 | μΑ | | Capacitance Ports (as input or output), RST, IRQ1, BATT | C <sub>Out</sub> | _<br>_ | _ | 12<br>8 | pF | | Monitor mode entry voltage | V <sub>TST</sub> | V <sub>DD</sub> + 2.5 | _ | 9 | V | | Pullup resistor PTB7/KBD7–PTB0/KBD0 25°C 0°C to 70°C | R <sub>PU</sub> | 27<br>24 | _ | 39<br>48 | kΩ | MC68HC908RC24 — Rev. 1.0 Advance Information <sup>1.</sup> $V_{DD}$ = 2.0 Vdc $\pm$ 10%, $V_{SS}$ = 0 Vdc, $T_A$ = $T_L$ to $T_H$ , unless otherwise noted 2. Typical values reflect average measurements at midpoint of voltage range, 25°C only. <sup>3.</sup> Run (operating) $I_{DD}$ measured using external square wave clock source. LVI enabled. 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<sub>DD</sub>. Measured with all modules enabled. Wait I<sub>DD</sub> measured using external square wave clock source (f<sub>CGMXCLK</sub> = 4 MHz); all inputs 0.2 V from rail; no dc loads; less than 100 pF on all outputs. C<sub>L</sub> = 20 pF on OSC2; OSC2 capacitance linearly affects wait I<sub>DD</sub>. Stop I<sub>DD</sub> measured with OSC1 grounded and no port pins sourcing current. LVI is disabled by stop entry. I<sub>DD</sub> measurement when BATT supply is below V<sub>LVR</sub> and part is in LP reset. I<sub>DD</sub> measurement when BATT supply is removed and part is in LP reset. ## **Preliminary Electrical Specifications** ## 19.8 Control Timing | Characteristic <sup>(1)</sup> | Symbol | Min | Max | Unit | |----------------------------------------------------------------|-------------------|-----|-----|------| | Internal operating frequency <sup>(2)</sup> | f <sub>OP</sub> | _ | 2.0 | MHz | | RST input pulse width low <sup>(3)</sup> | t <sub>IRL</sub> | 125 | _ | ns | | IRQ1 interrupt pulse width low <sup>(4)</sup> (edge-triggered) | t <sub>ILIH</sub> | 125 | _ | ns | - 1. $V_{DD}$ = 1.8 to 5.5 Vdc; $V_{SS}$ = 0 Vdc; timing shown with respect to 20% $V_{DD}$ and 70% $V_{DD}$ , unless otherwise noted 2. Some modules may require a minimum frequency greater than dc for proper operation; see appropriate table for this in- - 3. Minimum pulse width reset is guaranteed to be recognized. It is possible for a smaller pulse width to cause a reset. - 4. Minimum pulse width is for guaranteed interrupt. It is possible for a smaller pulse width to be recognized. #### 19.9 Oscillator Characteristics | Characteristic | Symbol | Min | Тур | Max | Unit | |-------------------------------------------------------|-------------------------------------|-----|--------------------|-----|------| | Crystal frequency <sup>(1)</sup> | f <sub>CGMXCLK</sub> <sup>(2)</sup> | 1 | _ | 8 | MHz | | External clock Reference frequency <sup>(1) (3)</sup> | f <sub>CGMXCLK</sub> <sup>2</sup> | dc | _ | 8 | MHz | | Crystal load capacitance <sup>(4)</sup> | C <sub>L</sub> | _ | _ | _ | | | Crystal fixed capacitance <sup>(4)</sup> | C <sub>1</sub> | _ | 2 x C <sub>L</sub> | _ | | | Crystal tuning capacitance <sup>(4)</sup> | C <sub>2</sub> | _ | 2 x C <sub>L</sub> | _ | | | Feedback bias resistor | R <sub>B</sub> | _ | 10 MΩ | _ | | | Series resistor <sup>(4) (5)</sup> | R <sub>S</sub> | _ | _ | _ | | - 1. The CMT module is designed to function at f<sub>CGMXCLK</sub> = 8 MHz. The values given here are oscillator specifications. - 2. $f_{OP} = f_{CGMXCLK/4}$ 3. No more than 10% duty cycle deviation from 50% - 4. Consult crystal vendor data sheet - 5. Not required for high frequency crystals ## 19.10 LVI Characteristics | Characteristic | Symbol | Min | Тур | Max | Unit | |------------------------------------------------------------------------------------------------------|-------------------|------|------|-----------------------------------------------------------------------------------------------------------------|----------------| | LVI low battery sense voltage (1) | V <sub>LVS</sub> | 2.00 | 2.05 | 2.10 | V | | LVI trip voltage | V <sub>LVR</sub> | 1.85 | 1.9 | 1.95 | V | | LVI Trip voltage hysteresis | H <sub>LVR</sub> | 40 | 70 | 100 | mV | | V <sub>DD</sub> slew rate, rising | SR <sub>R</sub> | _ | _ | 0.05 | V/µs | | V <sub>DD</sub> slew rate, falling | SR <sub>F</sub> | _ | _ | 0.10 | V/µs | | Response time $R \leq SR_{MAX}$ | t <sub>RESP</sub> | _ | _ | 6.0 + <u>40</u><br>f <sub>CGMXCLK</sub> | μѕ | | Response time<br>SR > SR <sub>MAX</sub> | t <sub>RESP</sub> | _ | _ | $\left(\frac{\sqrt{DD^{-V}LVR}}{SR_{max}} - \frac{\sqrt{DD^{-V}LVR}}{SR}\right) + 6.0 + \frac{40}{f_{CGMXCLK}}$ | μs | | LVI supply current @ $V_{DD} = 5.5 \text{ V}$ @ $V_{DD} = 3.6 \text{ V}$ @ $V_{DD} = 1.8 \text{ V}$ | I <sub>LVI</sub> | | | 100<br>50<br>25 | mA<br>μA<br>μA | | Enable time (enable to output transition) | t <sub>EN</sub> | _ | _ | 50 | μs | <sup>1.</sup> The LVI samples $\rm V_{DD}.~V_{LVR}$ and $\rm V_{LVS}$ are $\rm V_{DD}$ voltages. ## **Preliminary Electrical Specifications** ## 19.11 Battery Detection Characteristics | Characteristic | Symbol | Min | Max | Unit | |------------------------------------------------|------------------|-------|-----|------| | Battery insertion rearm voltage <sup>(1)</sup> | $V_{BR}$ | _ | 100 | mV | | BATT to V <sub>DD</sub> voltage @ BATT = 2.1 V | V <sub>F</sub> | _ | 200 | mV | | BATT to V <sub>DD</sub> voltage @ BATT = 3.3 V | V <sub>F</sub> | _ | 300 | mV | | Supply rise time ramp rate <sup>(2)</sup> | R <sub>POR</sub> | 0.035 | _ | V/ms | <sup>1.</sup> When supply is removed from the BATT pin, the pin voltage must fall below V<sub>BR</sub> before supply is reapplied to guarantee that battery reinsertion is detected. ## 19.12 Battery Circuit Component Specifications | Characteristic | Symbol | Тур | Max | Unit | |----------------------------------------------------------|--------------------|-----------|-----------|------| | External V <sub>DD</sub> supply capacitor <sup>(1)</sup> | C <sub>VBULK</sub> | _ | 470 ± 20% | μF | | External V <sub>DD</sub> bypass capacitor <sup>(2)</sup> | C <sub>VBYP</sub> | 0.1 ± 20% | _ | μF | | External BATT capacitor <sup>2</sup> | C <sub>BATT</sub> | 0.1 ± 20% | _ | μF | | External BATT resistor | R <sub>BATT</sub> | 1 ± 5% | _ | MΩ | <sup>1.</sup> Capacitor is electrolytic, $\pm$ 20%, ESR < 4 $\Omega$ If minimum BATT pin voltage is not reached before the internal POR reset is released, RST must be driven low externally until minimum BATT voltage is reached. <sup>2.</sup> Capacitor is ceramic, ± 20% ## **19.13** Memory Characteristics | Characteristic | Symbol | Min | Max | Unit | |---------------------------------------------------------------------------|--------------------------------------|------|-------|--------| | RAM data retention voltage | V <sub>RDR</sub> | 1.3 | _ | V | | FLASH pages per row | _ | 8 | 8 | Pages | | FLASH bytes per page | _ | 8 | 8 | Bytes | | FLASH read bus clock frequency | f <sub>Read</sub> <sup>(1)</sup> | 32 K | 8.4 M | Hz | | FLASH charge pump clock frequency (see 4.5 Charge Pump Frequency Control) | f <sub>Pump</sub> <sup>(2)</sup> | 1.8 | 2.3 | MHz | | FLASH block/bulk erase time | t <sub>Erase</sub> | 100 | _ | ms | | FLASH high voltage kill time | t <sub>Kill</sub> | 200 | _ | μs | | FLASH return to read time | t <sub>HVD</sub> | 50 | _ | μs | | FLASH page program pulses | fls <sub>Pulses</sub> <sup>(3)</sup> | 1 | 20 | Pulses | | FLASH page program step size | t <sub>Step</sub> <sup>(4)</sup> | 0.8 | 5 | ms | | FLASH cumulative program time per row between erase cycles | t <sub>Row</sub> <sup>(5)</sup> | _ | 800 | ms | | FLASH HVEN low to MARGIN high time | t <sub>HVTV</sub> | 50 | _ | μs | | FLASH MARGIN high to PGM low time | t <sub>VTP</sub> | 150 | _ | μs | | FLASH row erase endurance <sup>(6)</sup> | | 100 | | Cycles | | FLASH row program endurance <sup>(7)</sup> | _ | 100 | _ | Cycles | | FLASH data retention time <sup>(8)</sup> | _ | 10 | _ | Years | - 1. f<sub>Read</sub> is defined as the frequency range for which the FLASH memory can be read. - 2. f<sub>Pump</sub> is defined as the charge pump clock frequency required for program, erase, and margin read operations. 3. fls<sub>Pulses</sub> is defined as the number of pulses used to program the FLASH using the required smart program algorithm. - 4. t<sub>Step</sub> is defined as the amount of time during one page program cycle that HVEN is held high. - 5. t<sub>Row</sub> is defined as the cumulative time a row can see the program voltage before the row must be erased before further programming. - 6. The minimum row endurance value specifies each row of the FLASH memory is guaranteed to work for at least this many erase / program cycles. - 7. The minimum row endurance value specifies each row of the FLASH memory is guaranteed to work for at least this many erase / program cycles. - 8. The FLASH is guaranteed to retain data over the entire temperature range for at least the minimum time specified. # Section 20. Mechanical Specifications #### 20.1 Contents | 20.2 | Introduction | 203 | |--------|------------------------------------------------|-----| | 20.3 | Available Packages | 204 | | 20.3.1 | 28-Pin Plastic Dual In-Line Package (Case 710) | 204 | | 20.3.2 | 2 28-Pin Small Outline Package (Case 751F) | 205 | ## 20.2 Introduction This section provides package information for the MC68HC908RC24. ## 20.3 Available Packages The sections 20.3.1 28-Pin Plastic Dual In-Line Package (Case 710) and 20.3.2 28-Pin Small Outline Package (Case 751F) show the latest information at the time of this publication. To make sure that you have the latest package specifications, contact one of these sources: - Local Motorola sales office - Motorola Fax Back System (Mfax<sup>™</sup>) - Phone 1-602-244-6609 - EMAIL RMFAX0@email.sps.mot.com; http://sps.motorola.com/mfax/ - Worldwide Web (wwweb) home page at http://www.mcu.motsps.com Follow Mfax or wwweb on-line instructions to retrieve the current mechanical specifications. ## 20.3.1 28-Pin Plastic Dual In-Line Package (Case 710) Mfax is a trademark of Motorola, Inc. #### NOTES: - 1. POSITIONAL TOLERANCE OF LEADS (D), SHALL BE WITHIN 0.25mm (0.010) AT MAXIMUM MATERIAL CONDITION, IN RELATION TO SEATING PLANE AND EACH OTHER. - DIMENSION L TO CENTER OF LEADS WHEN FORMED PARALLEL. - 3. DIMENSION B DOES NOT INCLUDE MOLD FLASH | | MILLIM | ETERS | INC | HES | |-----|-----------|-------|-----------|-------| | DIM | MIN | MAX | MIN | MAX | | Α | 36.45 | 37.21 | 1.435 | 1.465 | | В | 13.72 | 14.22 | 0.540 | 0.560 | | С | 3.94 | 5.08 | 0.155 | 0.200 | | D | 0.36 | 0.56 | 0.014 | 0.022 | | F | 1.02 | 1.52 | 0.040 | 0.060 | | G | 2.54 | BSC | 0.100 BSC | | | Н | 1.65 | 2.16 | 0.065 | 0.085 | | J | 0.20 | 0.38 | 0.008 | 0.015 | | K | 2.92 | 3.43 | 0.115 | 0.135 | | L | 15.24 BSC | | 0.600 | BSC | | M | 0° | 15° | 0° | 15° | | N | 0.51 | 1.02 | 0.020 | 0.040 | Advance Information MC68HC908RC24 — Rev. 1.0 ## 20.3.2 28-Pin Small Outline Package (Case 751F) - NOTES: 1. DIMENSIONING AND TOLERANCING PER ANSI Y14.5M, 1982. 2. CONTROLLING DIMENSION: MILLIMETER. 3. DIMENSION A AND B DO NOT INCLUDE MOLD PROTRUSION. 4. MAXIMUM MOLD PROTRUSION 0.15 (0.006) PER SIDE. 5. DIMENSION D DOES NOT INCLUDE DAMBAR PROTRUSION. ALLOWABLE DAMBAR PROTRUSION SHALL BE 0.13 (0.005) TOTAL IN EXCESS OF D DIMENSION AT MAXIMUM MATERIAL CONDITION. | | MILLIMETERS INCHES | | | | |-----|--------------------|-------|-----------|-------| | | WILLIMETERS | | INC | HES | | DIM | MIN | MAX | MIN | MAX | | Α | 17.80 | 18.05 | 0.701 | 0.711 | | В | 7.40 | 7.60 | 0.292 | 0.299 | | С | 2.35 | 2.65 | 0.093 | 0.104 | | D | 0.35 | 0.49 | 0.014 | 0.019 | | F | 0.41 | 0.90 | 0.016 | 0.035 | | G | 1.27 | BSC | 0.050 BSC | | | J | 0.23 | 0.32 | 0.009 | 0.013 | | K | 0.13 | 0.29 | 0.005 | 0.011 | | M | 0° | 8° | 0° | 8° | | P | 10.05 | 10.55 | 0.395 | 0.415 | | R | 0.25 | 0.75 | 0.010 | 0.029 | # **Mechanical Specifications** # **Section 21. Ordering Information** ## 21.1 Contents | 21.2 | Introduction | | |------|------------------|----| | 21 3 | XC Order Numbers | 20 | ## 21.2 Introduction This section contains instructions for ordering the MC68HC908RC24. Packages available are: - 28-pin plastic dual in-line package (PDIP) - 28-pin small outline package (SOIC) ## 21.3 XC Order Numbers Table 21-1, XC Order Numbers | MC Order Number <sup>(1)</sup> | Operating Temperature Range | |--------------------------------|-----------------------------| | XC68HC908RC24P | −0°C to + 70°C | | XC68HC908RC24DW | −0°C to + 70°C | 1. P = Dual in-line plastic (PDIP) DW = Small outline (SOIC) # 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 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 injury or death associated with such unintended or unauthorized use, even if such claim alleges that Motorola was negligent regarding the #### 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-26668334 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