Welcome to **E-XFL.COM** What is "Embedded - Microcontrollers"? "Embedded - Microcontrollers" refer to small, integrated circuits designed to perform specific tasks within larger systems. These microcontrollers are essentially compact computers on a single chip, containing a processor core, memory, and programmable input/output peripherals. They are called "embedded" because they are embedded within electronic devices to control various functions, rather than serving as standalone computers. Microcontrollers are crucial in modern electronics, providing the intelligence and control needed for a wide range of applications. Applications of "<u>Embedded - Microcontrollers</u>" | Core Processor H Core Size 8 Speed 8 Connectivity LI Peripherals L | Obsolete HC08 8-Bit 8MHz LINbus, SCI, SPI LVD, POR, PWM | |--------------------------------------------------------------------|---------------------------------------------------------------| | Core Processor H Core Size 8 Speed 8 Connectivity LI Peripherals L | HC08 8-Bit 8MHz LINbus, SCI, SPI LVD, POR, PWM | | Core Size 8- Speed 8- Connectivity LI Peripherals LY | 8-Bit 8MHz LINbus, SCI, SPI LVD, POR, PWM | | Speed 8l Connectivity Ll Peripherals L | 8MHz<br>LINbus, SCI, SPI<br>LVD, POR, PWM | | Connectivity LI Peripherals LY | LINbus, SCI, SPI<br>LVD, POR, PWM | | Peripherals L | LVD, POR, PWM | | · | | | Number of I/O 3 | 37 | | | - | | Program Memory Size 1 | 16KB (16K x 8) | | Program Memory Type FI | FLASH | | EEPROM Size - | - | | RAM Size 1 | 1K x 8 | | Voltage - Supply (Vcc/Vdd) 3' | 3V ~ 5.5V | | Data Converters A | A/D 8x10b | | Oscillator Type In | Internal | | Operating Temperature -4 | -40°C ~ 125°C (TA) | | Mounting Type S | Surface Mount | | Package / Case 4 | 48-LQFP | | Supplier Device Package 4 | 48-LQFP (7x7) | | Purchase URL ht | https://www.e-xfl.com/pro/item?MUrl=&PartUrl=mc68hc908gr16mfa | Email: info@E-XFL.COM Address: Room A, 16/F, Full Win Commercial Centre, 573 Nathan Road, Mongkok, Hong Kong ## **Table of Contents** # Chapter 1 General Description | 1.1 | Introduction | 19 | |--------------------|------------------------------------------------------------------------------------------------------------------|----| | 1.2 | Features | 19 | | 1.2.1 | Standard Features of the MC68HC908GR16 | 19 | | 1.2.2 | Features of the CPU08 | 21 | | 1.3 | MCU Block Diagram | 21 | | 1.4 | Pin Assignments | 21 | | 1.5 | Pin Functions | 24 | | 1.5.1 | Power Supply Pins (V <sub>DD</sub> and V <sub>SS</sub> ) | 24 | | 1.5.2 | Oscillator Pins (OSC1 and OSC2) | | | 1.5.3 | External Reset Pin (RST) | | | 1.5.4 | External Interrupt Pin (IRQ) | | | 1.5.5 | CGM Power Supply Pins (V <sub>DDA</sub> and V <sub>SSA</sub> ) | | | 1.5.6 | External Filter Capacitor Pin (V <sub>CGMXFC</sub> ) | | | 1.5.7 | ADC Power Supply/Reference Pins (V <sub>DDAD</sub> /V <sub>REFH</sub> and V <sub>SSAD</sub> /V <sub>REFL</sub> ) | | | 1.5.8 | Port A Input/Output (I/O) Pins (PTA7/KBD7–PTA0/KBD0) | | | 1.5.9 | Port B I/O Pins (PTB7/AD7–PTB0/AD0) | | | 1.5.10 | Port C I/O Pins (PTC6–PTC0) | | | 1.5.11 | Port D I/O Pins (PTD7/T2CH1–PTD0/SS) | | | 1.5.12 | Port E I/O Pins (PTE5–PTE2 and PTE0/TxD) | 26 | | | Chapter 2 | | | 0.4 | Memory | | | 2.1 | Introduction | | | 2.2 | Unimplemented Memory Locations | | | 2.3 | Reserved Memory Locations | | | 2.4 | Input/Output (I/O) Section | | | 2.5 | Random-Access Memory (RAM) | | | 2.6 | FLASH Memory (FLASH) | | | 2.6.1 | Functional Description | | | 2.6.1.1 | 3 | | | 2.6.1.2<br>2.6.1.3 | · | | | 2.6.1.3 | · · | | | 2.6.1.5 | | | | 2.6.1.6 | | | | 2.6.2 | Wait Mode | | | 2.6.3 | Stop Mode | | | | · | | #### **Table of Contents** # Chapter 3 Analog-to-Digital Converter (ADC) | 3.1 | Introduction | 47 | |---------|-----------------------------------------------------|----| | 3.2 | Features | 47 | | 3.3 | Functional Description | 47 | | 3.3.1 | ADC Port I/O Pins | 47 | | 3.3.2 | Voltage Conversion | 49 | | 3.3.3 | Conversion Time | 50 | | 3.3.4 | Conversion | 50 | | 3.3.5 | Accuracy and Precision | 50 | | 3.3.6 | Result Justification | 50 | | 3.4 | Monotonicity | 51 | | 3.5 | Interrupts | 51 | | 3.6 | Low-Power Modes | 51 | | 3.6.1 | Wait Mode | 52 | | 3.6.2 | Stop Mode | 52 | | 3.7 | I/O Signals | | | 3.7.1 | ADC Analog Power Pin (V <sub>DDAD</sub> ) | | | 3.7.2 | ADC Analog Ground Pin (V <sub>SSAD</sub> ) | | | 3.7.3 | ADC Voltage Reference High Pin (V <sub>REFH</sub> ) | | | 3.7.4 | ADC Voltage Reference Low Pin (V <sub>REFL</sub> ) | | | 3.7.5 | ADC Voltage In (V <sub>ADIN</sub> ) | | | 3.8 | I/O Registers | | | 3.8.1 | ADC Status and Control Register | | | 3.8.2 | ADC Data Register High and Data Register Low | | | 3.8.2.1 | Left Justified Mode | | | 3.8.2.2 | 9 | 55 | | 3.8.2.3 | <b>5</b> | | | 3.8.2.4 | <b>5</b> | | | 3.8.3 | ADC Clock Register | 57 | | | Chapter 4 | | | | Clock Generator Module (CGM) | | | 4.1 | Introduction | 59 | | 4.2 | Features | | | 4.3 | Functional Description | 59 | | 4.3.1 | Crystal Oscillator Circuit | | | 4.3.2 | Phase-Locked Loop Circuit (PLL) | | | 4.3.3 | PLL Circuits | | | 4.3.4 | Acquisition and Tracking Modes | | | 4.3.5 | Manual and Automatic PLL Bandwidth Modes | 62 | | 4.3.6 | Programming the PLL | 63 | | 4.3.7 | Special Programming Exceptions | | | 4.3.8 | Base Clock Selector Circuit | | | 4.3.9 | CGM External Connections | 66 | | | | | **Clock Generator Module (CGM)** #### 4.3.7 Special Programming Exceptions The programming method described in 4.3.6 Programming the PLL does not account for three possible exceptions. A value of 0 for R, N, or L is meaningless when used in the equations given. To account for these exceptions: - A 0 value for R or N is interpreted exactly the same as a value of 1. - A 0 value for L disables the PLL and prevents its selection as the source for the base clock. See 4.3.8 Base Clock Selector Circuit. #### 4.3.8 Base Clock Selector Circuit This circuit is used to select either the crystal clock, CGMXCLK, or the VCO clock, CGMVCLK, as the source of the base clock, CGMOUT. The two input clocks go through a transition control circuit that waits up to three CGMXCLK cycles and three CGMVCLK cycles to change from one clock source to the other. During this time, CGMOUT is held in stasis. The output of the transition control circuit is then divided by two to correct the duty cycle. Therefore, the bus clock frequency, which is one-half of the base clock frequency, is one-fourth the frequency of the selected clock (CGMXCLK or CGMVCLK). The BCS bit in the PLL control register (PCTL) selects which clock drives CGMOUT. The VCO clock cannot be selected as the base clock source if the PLL is not turned on. The PLL cannot be turned off if the VCO clock is selected. The PLL cannot be turned on or off simultaneously with the selection or deselection of the VCO clock. The VCO clock also cannot be selected as the base clock source if the factor L is programmed to a 0. This value would set up a condition inconsistent with the operation of the PLL, so that the PLL would be disabled and the crystal clock would be forced as the source of the base clock. #### 4.3.9 CGM External Connections In its typical configuration, the CGM requires up to nine external components. Five of these are for the crystal oscillator and two or four are for the PLL. The crystal oscillator is normally connected in a Pierce oscillator configuration, as shown in Figure 4-2. Figure 4-2 shows only the logical representation of the internal components and may not represent actual circuitry. The oscillator configuration uses five components: - Crystal, X₁ - Fixed capacitor, C<sub>1</sub> - Tuning capacitor, C<sub>2</sub> (can also be a fixed capacitor) - Feedback resistor, R<sub>B</sub> - Series resistor, R<sub>S</sub> The series resistor (R<sub>S</sub>) is included in the diagram to follow strict Pierce oscillator guidelines. Refer to the crystal manufacturer's data for more information regarding values for C1 and C2. Figure 4-2 also shows the external components for the PLL: - Bypass capacitor, C<sub>BYP</sub> - Filter network Routing should be done with great care to minimize signal cross talk and noise. See 20.9 Clock Generation Module Characteristics for capacitor and resistor values. #### 4.5.3 PLL Multiplier Select Register High The PLL multiplier select register high (PMSH) contains the programming information for the high byte of the modulo feedback divider. Figure 4-6. PLL Multiplier Select Register High (PMSH) #### **MUL11-MUL8** — Multiplier Select Bits These read/write bits control the high byte of the modulo feedback divider that selects the VCO frequency multiplier N. (See 4.3.3 PLL Circuits and 4.3.6 Programming the PLL.) A value of \$0000 in the multiplier select registers configures the modulo feedback divider the same as a value of \$0001. Reset initializes the registers to \$0040 for a default multiply value of 64. #### NOTE The multiplier select bits have built-in protection such that they cannot be written when the PLL is on (PLLON = 1). #### PMSH[7:4] — Unimplemented Bits These bits have no function and always read as 0s. ## 4.5.4 PLL Multiplier Select Register Low The PLL multiplier select register low (PMSL) contains the programming information for the low byte of the modulo feedback divider. Figure 4-7. PLL Multiplier Select Register Low (PMSL) #### **MUL7-MUL0** — Multiplier Select Bits These read/write bits control the low byte of the modulo feedback divider that selects the VCO frequency multiplier, N. (See 4.3.3 PLL Circuits and 4.3.6 Programming the PLL.) MUL7–MUL0 cannot be written when the PLLON bit in the PCTL is set. A value of \$0000 in the multiplier select registers configures the modulo feedback divider the same as a value of \$0001. Reset initializes the register to \$40 for a default multiply value of 64. #### NOTE The multiplier select bits have built-in protection such that they cannot be written when the PLL is on (PLLON = 1). #### 7.3.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 to \$FF and does not affect the most significant byte. The stack pointer decrements as data is pushed onto the stack and increments as data is pulled from the stack. In the stack pointer 8-bit offset and 16-bit offset addressing modes, the stack pointer can function as an index register to access data on the stack. The CPU uses the contents of the stack pointer to determine the conditional address of the operand. Figure 7-4. Stack Pointer (SP) #### NOTE The location of the stack is arbitrary and may be relocated anywhere in random-access memory (RAM). Moving the SP out of page 0 (\$0000 to \$00FF) frees direct address (page 0) space. For correct operation, the stack pointer must point only to RAM locations. ## 7.3.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 7-5. Program Counter (PC) ## **Central Processor Unit (CPU)** Table 7-1. Instruction Set Summary (Sheet 3 of 6) | Source | Operation | | | | Effect<br>on CCR | | | | Address<br>Mode | Opcode | Operand | es | |------------------------------------------------------------------------------------------------|----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---|------------------|----------|----------|---|-----------------------------------------------------|--------------------------------------------------|-------------------------------------------------|--------------------------------------| | Form | Operation | Description | ٧ | Н | I | N | Z | С | Add | obc | Ope | Cycles | | CLR opr<br>CLRA<br>CLRX<br>CLRH<br>CLR opr,X<br>CLR,X<br>CLR opr,SP | Clear | M ← \$00<br>A ← \$00<br>X ← \$00<br>H ← \$00<br>M ← \$00<br>M ← \$00<br>M ← \$00 | 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 | 3 1 1 1 3 2 4 | | CMP #opr<br>CMP opr<br>CMP opr<br>CMP opr,X<br>CMP opr,X<br>CMP,X<br>CMP opr,SP<br>CMP opr,SP | Compare A with M | (A) – (M) | Î | _ | _ | ţ | ‡ | ţ | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP1<br>SP2 | A1<br>B1<br>C1<br>D1<br>E1<br>F1<br>9EE1<br>9ED1 | ii<br>dd<br>hh II<br>ee ff<br>ff<br>ff<br>ee ff | 2 3 4 4 3 2 4 5 | | COM opr<br>COMA<br>COMX<br>COM opr,X<br>COM ,X<br>COM opr,SP | Complement (One's Complement) | $\begin{array}{l} 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 | _ | ı | 1 | ‡ | 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) | 1 | - | 1 | ‡ | 1 | ‡ | IMM<br>DIR | 65<br>75 | ii ii+1<br>dd | 3 | | 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) | î | _ | | 1 | 1 | ‡ | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP1<br>SP2 | A3<br>B3<br>C3<br>D3<br>E3<br>F3<br>9EE3<br>9ED3 | ii<br>dd<br>hh II<br>ee ff<br>ff<br>ff | 23443245 | | DAA | Decimal Adjust A | (A) <sub>10</sub> | U | - | _ | 1 | 1 | 1 | INH | 72 | | 2 | | 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) + 3 + 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 | 533546 | | 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}$ | 1 | - | - | <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 \leftarrow (H:A)/(X)$<br>$H \leftarrow Remainder$ | - | - | _ | - | ‡ | ‡ | INH | 52 | | 7 | | EOR #opr<br>EOR opr<br>EOR opr,<br>EOR opr,X<br>EOR opr,X<br>EOR,X<br>EOR opr,SP<br>EOR opr,SP | Exclusive OR M with A | $A \leftarrow (A \oplus M)$ | 0 | _ | _ | ‡ | <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}$ | 1 | _ | Ī | 1 | <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 | ## Table 7-1. Instruction Set Summary (Sheet 6 of 6) | Source | Operation | Description | Effe<br>on C | | | | - | | Address<br>Mode | Opcode | Operand | es | |--------------------------------------------------------------|---------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|---|---|----------|---|---|---------------------------------------|------------------------------------|----------------|--------| | Form | Form | | | | | | Z | С | Add | Opc | Ope | Cycles | | SWI | Software Interrupt | $\begin{array}{c} PC \leftarrow (PC) + 1; Push (PCL) \\ SP \leftarrow (SP) - 1; Push (PCH) \\ SP \leftarrow (SP) - 1; Push (X) \\ SP \leftarrow (SP) - 1; Push (A) \\ SP \leftarrow (SP) - 1; Push (CCR) \\ SP \leftarrow (SP) - 1; I \leftarrow 1 \\ PCH \leftarrow Interrupt Vector High Byte \\ PCL \leftarrow Interrupt Vector Low Byte \\ \end{array}$ | _ | _ | 1 | _ | _ | _ | INH | 83 | | 9 | | TAP | Transfer A to CCR | CCR ← (A) | 1 | 1 | 1 | ‡ | 1 | 1 | INH | 84 | | 2 | | TAX | Transfer A to X | X ← (A) | - | - | _ | - | - | - | INH | 97 | | 1 | | TPA | Transfer CCR to A | $A \leftarrow (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> | 1 | ı | 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 | 311324 | | 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 | | WAIT | Enable Interrupts; Wait for Interrupt | I bit ← 0; Inhibit CPU clocking until interrupted | - | - | 0 | - | - | _ | INH | 8F | | 1 | | Α | 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 | 1 | Logical OR | | IMM | Immediate addressing mode | $\oplus$ | Logical EXCLUSIVE OR | | INH | Inherent addressing mode | () | Contents of | | IX | Indexed, no offset addressing mode | <del>-</del> () | Negation (two's complement) | | IX+ | Indexed, no offset, post increment addressing mode | #`´ | Immediate value | | IX+D | Indexed with post increment to direct addressing mode | ** | 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 | ‡ | Set or cleared | | N | Negative bit | _ | Not affected | | | | | | ## 7.8 Opcode Map See Table 7-2. # Chapter 8 External Interrupt (IRQ) #### 8.1 Introduction The IRQ (external interrupt) module provides a maskable interrupt input. #### 8.2 Features Features of the IRQ module include: - A dedicated external interrupt pin (IRQ) - IRQ interrupt control bits - Hysteresis buffer - Programmable edge-only or edge and level interrupt sensitivity - Automatic interrupt acknowledge - Internal pullup resistor ## 8.3 Functional Description A falling edge on the external interrupt pin can latch a central processor unit (CPU) interrupt request. Figure 8-2 shows the structure of the IRQ module. Interrupt signals on the $\overline{IRQ}$ pin are latched into the IRQ latch. An interrupt latch remains set until one of the following actions occurs: - Vector fetch A vector fetch automatically generates an interrupt acknowledge signal that clears the latch that caused the vector fetch. - Software clear Software can clear an interrupt latch by writing to the appropriate acknowledge bit in the interrupt status and control register (INTSCR). Writing a 1 to the ACK bit clears the IRQ latch. - Reset A reset automatically clears the interrupt latch. The external interrupt pin is falling-edge triggered out of reset and is software-configurable to be either falling-edge or fa<u>lling</u>-edge and low-level triggered. The MODE bit in the INTSCR controls the triggering sensitivity of the IRQ pin. When an interrupt pin is edge-triggered only (MODE = 0), the interrupt remains set until a vector fetch, software clear, or reset occurs. ## Chapter 10 Low-Power Modes #### 10.1 Introduction The microcontroller (MCU) may enter two low-power modes: wait mode and stop mode. They are common to all HC08 MCUs and are entered through instruction execution. This section describes how each module acts in the low-power modes. #### 10.1.1 Wait Mode The WAIT instruction puts the MCU in a low-power standby mode in which the central processor unit (CPU) clock is disabled but the bus clock continues to run. Power consumption can be further reduced by disabling the low-voltage inhibit (LVI) module through bits in the CONFIG1 register. See Chapter 5 Configuration Register (CONFIG). ## **10.1.2 Stop Mode** Stop mode is entered when a STOP instruction is executed. The CPU clock is disabled and the bus clock is disabled if the OSCENINSTOP bit in the CONFIG2 register is at a 0. See Chapter 5 Configuration Register (CONFIG). ## 10.2 Analog-to-Digital Converter (ADC) #### 10.2.1 Wait Mode The analog-to-digital converter (ADC) continues normal operation during wait mode. Any enabled CPU interrupt request from the ADC can bring the MCU out of wait mode. If the ADC is not required to bring the MCU out of wait mode, power down the ADC by setting ADCH4–ADCH0 bits in the ADC status and control register before executing the WAIT instruction. ## **10.2.2 Stop Mode** The ADC module is inactive after the execution of a STOP instruction. Any pending conversion is aborted. ADC conversions resume when the MCU exits stop mode after an external interrupt. Allow one conversion cycle to stabilize the analog circuitry. ## Input/Output Ports (PORTS) | Addr. | Register Name | | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | | | | |--------|------------------------------------------------------|-----------------|---------------------|-------------|---------|---------|---------|---------|---------|---------|--|--|--| | \$0005 | Data Direction Register B (DDRB) | Read:<br>Write: | DDRB7 | DDRB6 | DDRB5 | DDRB4 | DDRB3 | DDRB2 | DDRB1 | DDRB0 | | | | | | See page 126. | Reset: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | \$0006 | Data Direction Register C (DDRC) | Read:<br>Write: | 0 | DDRC6 | DDRC5 | DDRC4 | DDRC3 | DDRC2 | DDRC1 | DDRC0 | | | | | | See page 128. | Reset: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | \$0007 | Data Direction Register D<br>(DDRD) | Read:<br>Write: | DDRD7 | DDRD6 | DDRD5 | DDRD4 | DDRD3 | DDRD2 | DDRD1 | DDRD0 | | | | | | See page 131. | Reset: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | 40000 | Port E Data Register | Read: | 0 | 0 | PTE5 | PTE4 | PTE3 | PTE2 | PTE1 | PTE0 | | | | | \$0008 | (PTE)<br>See page 133. | Write: | | | | | | | | | | | | | | 1 0 | Reset: | Unaffected by reset | | | | | | | | | | | | \$000C | Data Direction Register E<br>(DDRE)<br>See page 134. | Read:<br>Write: | 0 | 0 | DDRE5 | DDRE4 | DDRE3 | DDRE2 | DDRE1 | DDRE0 | | | | | | | Reset: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | \$000D | Port A Input Pullup Enable<br>Register (PTAPUE) | Read:<br>Write: | PTAPUE7 | PTAPUE6 | PTAPUE5 | PTAPUE4 | PTAPUE3 | PTAPUE2 | PTAPUE1 | PTAPUE0 | | | | | | See page 125. | Reset: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | Port C Input Pullup Enable | Read: | 0 | PTCPUE6 | PTCPUE5 | PTCPUE4 | PTCPUE3 | PTCPUE2 | PTCPUE1 | PTCPUE0 | | | | | \$000E | Register (PTCPUE) | Write: | | FICFUE | FICFUES | FIGFUE4 | FICFUES | FIGFUEZ | FICFUEI | FICFUEU | | | | | | See page 129. | Reset: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | \$000F | Port D Input Pullup Enable<br>Register (PTDPUE) | Read:<br>Write: | PTDPUE7 | PTDPUE6 | PTDPUE5 | PTDPUE4 | PTDPUE3 | PTDPUE2 | PTDPUE1 | PTDPUE0 | | | | | | See page 132. | Reset: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | | | | = Unimpleme | ented | | | | | | | | | Figure 12-1. I/O Port Register Summary (Continued) MC68HC908GR16 Data Sheet, Rev. 5.0 #### **Enhanced Serial Communications Interface (ESCI) Module** #### 14.4.3 Receiver Figure 14-6 shows the structure of the ESCI receiver. The receiver I/O registers are summarized in Figure 14-3. Figure 14-6. ESCI Receiver Block Diagram MC68HC908GR16 Data Sheet, Rev. 5.0 #### **Enhanced Serial Communications Interface (ESCI) Module** #### 14.5.2 Stop Mode The ESCI module is inactive in stop mode. The STOP instruction does not affect ESCI register states. ESCI module operation resumes after the MCU exits stop mode. Because the internal clock is inactive during stop mode, entering stop mode during an ESCI transmission or reception results in invalid data. ## 14.6 ESCI During Break Module Interrupts The BCFE bit in the break flag control register (SBFCR) enables software to clear status bits during the break state. See 19.2 Break Module (BRK). To allow software to clear status bits during a break interrupt, write a 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 0 to the BCFE bit. With BCFE at 0 (its default state), software can read and write I/O registers during the break state without affecting status bits. Some status bits have a two-step read/write clearing procedure. If software does the first step on such a bit before the break, the bit cannot change during the break state as long as BCFE is at logic 0. After the break, doing the second step clears the status bit. ## 14.7 I/O Signals Port E shares two of its pins with the ESCI module. The two ESCI I/O pins are: - PTE0/TxD transmit data - PTE1/RxD receive data ## 14.7.1 PTE0/TxD (Transmit Data) The PTE0/TxD pin is the serial data output from the ESCI transmitter. The ESCI shares the PTE0/TxD pin with port E. When the ESCI is enabled, the PTE0/TxD pin is an output regardless of the state of the DDRE0 bit in data direction register E (DDRE). #### 14.7.2 PTE1/RxD (Receive Data) The PTE1/RxD pin is the serial data input to the ESCI receiver. The ESCI shares the PTE1/RxD pin with port E. When the ESCI is enabled, the PTE1/RxD pin is an input regardless of the state of the DDRE1 bit in data direction register E (DDRE). ## 14.8 I/O Registers These I/O registers control and monitor ESCI operation: - ESCI control register 1, SCC1 - ESCI control register 2, SCC2 - ESCI control register 3, SCC3 - ESCI status register 1, SCS1 - ESCI status register 2, SCS2 - ESCI data register, SCDR - ESCI baud rate register, SCBR MC68HC908GR16 Data Sheet, Rev. 5.0 #### **Enhanced Serial Communications Interface (ESCI) Module** **Table 14-5. Character Format Selection** | Co | ontrol Bits | Character Format | | | | | | | | | |----|-------------|------------------|-----------|--------|-----------|------------------|--|--|--|--| | M | PEN:PTY | Start Bits | Data Bits | Parity | Stop Bits | Character Length | | | | | | 0 | 0 X | 1 | 8 | None | 1 | 10 bits | | | | | | 1 | 0 X | 1 | 9 | None | 1 | 11 bits | | | | | | 0 | 1 0 | 1 | 7 | Even | 1 | 10 bits | | | | | | 0 | 1 1 | 1 | 7 | Odd | 1 | 10 bits | | | | | | 1 | 1 0 | 1 | 8 | Even | 1 | 11 bits | | | | | | 1 | 1 1 | 1 | 8 | Odd | 1 | 11 bits | | | | | #### WAKE — Wakeup Condition Bit This read/write bit determines which condition wakes up the ESCI: a 1 (address mark) in the MSB position of a received character or an idle condition on the RxD pin. Reset clears the WAKE bit. - 1 = Address mark wakeup - 0 = Idle line wakeup #### ILTY — Idle Line Type Bit This read/write bit determines when the ESCI starts counting 1s as idle character bits. The counting begins either after the start bit or after the stop bit. If the count begins after the start bit, then a string of 1s preceding the stop bit may cause false recognition of an idle character. Beginning the count after the stop bit avoids false idle character recognition, but requires properly synchronized transmissions. Reset clears the ILTY bit. - 1 = Idle character bit count begins after stop bit - 0 = Idle character bit count begins after start bit #### PEN — Parity Enable Bit This read/write bit enables the ESCI parity function (see Table 14-5). When enabled, the parity function inserts a parity bit in the MSB position (see Table 14-3). Reset clears the PEN bit. - 1 = Parity function enabled - 0 = Parity function disabled #### PTY — Parity Bit This read/write bit determines whether the ESCI generates and checks for odd parity or even parity (see Table 14-5). Reset clears the PTY bit. - 1 = Odd parity - 0 = Even parity #### NOTE Changing the PTY bit in the middle of a transmission or reception can generate a parity error. #### 14.8.2 ESCI Control Register 2 ESCI control register 2 (SCC2): - Enables these CPU interrupt requests: - SCTE bit to generate transmitter CPU interrupt requests - TC bit to generate transmitter CPU interrupt requests - SCRF bit to generate receiver CPU interrupt requests - IDLE bit to generate receiver CPU interrupt requests MC68HC908GR16 Data Sheet, Rev. 5.0 - Enables the transmitter - Enables the receiver - Enables ESCI wakeup - Transmits ESCI break characters Figure 14-11. ESCI Control Register 2 (SCC2) #### **SCTIE** — **ESCI** Transmit Interrupt Enable Bit This read/write bit enables the SCTE bit to generate ESCI transmitter CPU interrupt requests. Setting the SCTIE bit in SCC2 enables the SCTE bit to generate CPU interrupt requests. Reset clears the SCTIE bit. - 1 = SCTE enabled to generate CPU interrupt - 0 = SCTE not enabled to generate CPU interrupt #### TCIE — Transmission Complete Interrupt Enable Bit This read/write bit enables the TC bit to generate ESCI transmitter CPU interrupt requests. Reset clears the TCIE bit. - 1 = TC enabled to generate CPU interrupt requests - 0 = TC not enabled to generate CPU interrupt requests ## SCRIE — ESCI Receive Interrupt Enable Bit This read/write bit enables the SCRF bit to generate ESCI receiver CPU interrupt requests. Setting the SCRIE bit in SCC2 enables the SCRF bit to generate CPU interrupt requests. Reset clears the SCRIE bit. - 1 = SCRF enabled to generate CPU interrupt - 0 = SCRF not enabled to generate CPU interrupt #### ILIE — Idle Line Interrupt Enable Bit This read/write bit enables the IDLE bit to generate ESCI receiver CPU interrupt requests. Reset clears the ILIE bit. - 1 = IDLE enabled to generate CPU interrupt requests - 0 = IDLE not enabled to generate CPU interrupt requests #### TE — Transmitter Enable Bit Setting this read/write bit begins the transmission by sending a preamble of 10 or 11 1s from the transmit shift register to the TxD pin. If software clears the TE bit, the transmitter completes any transmission in progress before the TxD returns to the idle condition (1). Clearing and then setting TE during a transmission queues an idle character to be sent after the character currently being transmitted. Reset clears the TE bit. - 1 = Transmitter enabled - 0 = Transmitter disabled #### NOTE Writing to the TE bit is not allowed when the enable ESCI bit (ENSCI) is clear. ENSCI is in ESCI control register 1. MC68HC908GR16 Data Sheet, Rev. 5.0 When the ESCI is receiving 8-bit characters, R8 is a copy of the eighth bit (bit 7). Reset has no effect on the R8 bit. #### T8 — Transmitted Bit 8 When the ESCI is transmitting 9-bit characters, T8 is the read/write ninth bit (bit 8) of the transmitted character. T8 is loaded into the transmit shift register at the same time that the SCDR is loaded into the transmit shift register. Reset clears the T8 bit. #### **ORIE** — Receiver Overrun Interrupt Enable Bit This read/write bit enables ESCI error CPU interrupt requests generated by the receiver overrun bit, OR. Reset clears ORIE. - 1 = ESCI error CPU interrupt requests from OR bit enabled - 0 = ESCI error CPU interrupt requests from OR bit disabled #### **NEIE** — Receiver Noise Error Interrupt Enable Bit This read/write bit enables ESCI error CPU interrupt requests generated by the noise error bit, NE. Reset clears NEIE. - 1 = ESCI error CPU interrupt requests from NE bit enabled - 0 = ESCI error CPU interrupt requests from NE bit disabled #### FEIE — Receiver Framing Error Interrupt Enable Bit This read/write bit enables ESCI error CPU interrupt requests generated by the framing error bit, FE. Reset clears FEIE. - 1 = ESCI error CPU interrupt requests from FE bit enabled - 0 = ESCI error CPU interrupt requests from FE bit disabled #### PEIE — Receiver Parity Error Interrupt Enable Bit This read/write bit enables ESCI receiver CPU interrupt requests generated by the parity error bit, PE. Reset clears PEIE. - 1 = ESCI error CPU interrupt requests from PE bit enabled - 0 = ESCI error CPU interrupt requests from PE bit disabled #### 14.8.4 ESCI Status Register 1 ESCI status register 1 (SCS1) contains flags to signal these conditions: - Transfer of SCDR data to transmit shift register complete - Transmission complete - Transfer of receive shift register data to SCDR complete - Receiver input idle - Receiver overrun - Noisy data - Framing error - Parity error Figure 14-13. ESCI Status Register 1 (SCS1) MC68HC908GR16 Data Sheet, Rev. 5.0 #### **System Integration Module (SIM)** - 1. Ports are software configurable with pullup device if input port. - 2. Higher current drive port pins - 3. Pin contains integrated pullup device Figure 15-1. Block Diagram Highlight SIM Block and Pins Serial Peripheral Interface (SPI) Module MC68HC908GR16 Data Sheet, Rev. 5.0 #### 19.2.1.2 CPU During Break Interrupts The CPU starts a break interrupt by: - Loading the instruction register with the SWI instruction - Loading the program counter with \$FFFC:\$FFFD (\$FEFC:\$FEFD in monitor mode) The break interrupt begins after completion of the CPU instruction in progress. If the break address register match occurs on the last cycle of a CPU instruction, the break interrupt begins immediately. #### 19.2.1.3 TIM During Break Interrupts A break interrupt stops the timer counter. #### 19.2.1.4 COP During Break Interrupts The COP is disabled during a break interrupt with monitor mode when BDCOP bit is set in break auxiliary register (BRKAR). #### 19.2.2 Break Module Registers These registers control and monitor operation of the break module: - Break status and control register (BRKSCR) - Break address register high (BRKH) - Break address register low (BRKL) - Break status register (BSR) - Break flag control register (BFCR) ## 19.2.2.1 Break Status and Control Register The break status and control register (BRKSCR) contains break module enable and status bits. Figure 19-3. Break Status and Control Register (BRKSCR) #### **BRKE** — Break Enable Bit This read/write bit enables breaks on break address register matches. Clear BRKE by writing a 0 to bit 7. Reset clears the BRKE bit. - 1 = Breaks enabled on 16-bit address match - 0 = Breaks disabled #### **BRKA** — Break Active Bit This read/write status and control bit is set when a break address match occurs. Writing a 1 to BRKA generates a break interrupt. Clear BRKA by writing a 0 to it before exiting the break routine. Reset clears the BRKA bit. - 1 = Break address match - 0 = No break address match MC68HC908GR16 Data Sheet, Rev. 5.0 | © FREESCALE SEMICONDUCTOR, INC. ALL RIGHTS RESERVED. | MECHANICA | L OUTLINE | PRINT VERSION NOT TO SCAL | | | | |------------------------------------------------------|---------------------------------|--------------|---------------------------|-------------|--|--| | TITLE: | DOCUMENT NO: 98ASH70029A REV: C | | | | | | | LOW PROFILE QUAD FLAT PA | , | CASE NUMBER | 2: 873A-04 | 01 APR 2005 | | | | 32 LEAD, 0.8 PITCH (7 X | 7 X 1.4) | STANDARD: JE | DEC MS-026 BBA | | | | #### How to Reach Us: #### Home Page: www.freescale.com #### E-mail: support@freescale.com #### **USA/Europe or Locations Not Listed:** Freescale Semiconductor Technical Information Center, CH370 1300 N. Alma School Road Chandler, Arizona 85224 +1-800-521-6274 or +1-480-768-2130 support@freescale.com #### Europe, Middle East, and Africa: Freescale Halbleiter Deutschland GmbH Technical Information Center Schatzbogen 7 81829 Muenchen, Germany +44 1296 380 456 (English) +46 8 52200080 (English) +49 89 92103 559 (German) +33 1 69 35 48 48 (French) support@freescale.com #### Japan: Freescale Semiconductor Japan Ltd. Headquarters ARCO Tower 15F 1-8-1, Shimo-Meguro, Meguro-ku, Tokyo 153-0064 Japan 0120 191014 or +81 3 5437 9125 support.japan@freescale.com #### Asia/Pacific: Freescale Semiconductor Hong Kong Ltd. Technical Information Center 2 Dai King Street Tai Po Industrial Estate Tai Po, N.T., Hong Kong +800 2666 8080 support.asia@freescale.com #### For Literature Requests Only: Freescale Semiconductor Literature Distribution Center P.O. Box 5405 Denver, Colorado 80217 1-800-441-2447 or 303-675-2140 Fax: 303-675-2150 LDCForFreescaleSemiconductor@hibbertgroup.com RoHS-compliant and/or Pb-free versions of Freescale products have the functionality and electrical characteristics of their non-RoHS-compliant and/or non-Pb-free counterparts. For further information, see http://www.freescale.com or contact your Freescale sales representative. For information on Freescale's Environmental Products program, go to http://www.freescale.com/epp. Information in this document is provided solely to enable system and software implementers to use Freescale Semiconductor products. There are no express or implied copyright licenses granted hereunder to design or fabricate any integrated circuits or integrated circuits based on the information in this document. Freescale Semiconductor reserves the right to make changes without further notice to any products herein. Freescale Semiconductor makes no warranty, representation or guarantee regarding the suitability of its products for any particular purpose, nor does Freescale Semiconductor 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 that may be provided in Freescale Semiconductor 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. Freescale Semiconductor does not convey any license under its patent rights nor the rights of others. Freescale Semiconductor 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 Freescale Semiconductor product could create a situation where personal injury or death may occur. Should Buyer purchase or use Freescale Semiconductor products for any such unintended or unauthorized application, Buyer shall indemnify and hold Freescale Semiconductor 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 Freescale Semiconductor was negligent regarding the design or manufacture of the part. Freescale<sup>™</sup> and the Freescale logo are trademarks of Freescale Semiconductor, Inc. All other product or service names are the property of their respective owners. © Freescale Semiconductor, Inc. 2004, 2007. All rights reserved.