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>" | Details | | |----------------------------|-------------------------------------------------------------------------| | Product Status | Obsolete | | Core Processor | HC08 | | Core Size | 8-Bit | | Speed | 8MHz | | Connectivity | - | | Peripherals | LVD, POR, PWM | | Number of I/O | 13 | | Program Memory Size | 1.5KB (1.5K x 8) | | Program Memory Type | FLASH | | EEPROM Size | - | | RAM Size | 128 x 8 | | Voltage - Supply (Vcc/Vdd) | 2.7V ~ 5.5V | | Data Converters | - | | Oscillator Type | Internal | | Operating Temperature | -40°C ~ 85°C (TA) | | Mounting Type | Through Hole | | Package / Case | 16-DIP (0.300", 7.62mm) | | Supplier Device Package | 16-PDIP | | Purchase URL | https://www.e-xfl.com/product-detail/nxp-semiconductors/mc68hc908qy1cpe | ## **Revision History (Sheet 2 of 3)** | Date | Revision Description | | | | | |------------------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------|--|--| | | | Reformatted to meet latest M68HC08 documentation standards | N/A | | | | | | Figure 1-1. Block Diagram — Diagram redrawn to include keyboard interrupt module and TCLK pin designator. | 20 | | | | | | Figure 1-2. MCU Pin Assignments — Added TCLK pin designator. | 21 | | | | | | Table 1-2. Pin Functions — Added TCLK pin description. | 22 | | | | | | Table 1-3. Function Priority in Shared Pins — Revised table for clarity and to add TCLK. | 23 | | | | August, | | Figure 2-1. Memory Map — Corrected names for the IRQ status and control register (INTSCR) bits 3–0. | 26 | | | | 2003 | 1.0 | 3.7.3 ADC Input Clock Register — Clarified bit description for the ADC clock prescaler bits. | 47 | | | | | | 4.3 Functional Description — Updated periodic wakeup request values. | 51 | | | | | | Figure 6-1. COP Block Diagram — Reworked for clarity | 59 | | | | | | Chapter 8 External Interrupt (IRQ) — Corrected bit names for MODE, IRQF, ACK, and IMASK | 77–79 | | | | | | Chapter 14 Timer Interface Module (TIM) — Added TCLK function. | 131–139 | | | | | | 15.3 Monitor Module (MON) — Updated with additional data. | 147 | | | | | | Chapter 16 Electrical Specifications — Updated with additional data. | 169–173 | | | | | | Figure 2-2. Control, Status, and Data Registers — Deleted unimplemented areas from \$FFB0_\$FFBD and \$FFC2_\$FFCF as they are actually available. Also corrected \$FFBF designation from unimplemented to reserved. | 27 | | | | | | Figure 6-1. COP Block Diagram — Reworked for clarity | 59 | | | | | | 6.3.2 STOP Instruction — Added subsection | 60 | | | | | | 13.4.2 Active Resets from Internal Sources — Reworked notes for clarity. | 111 | | | | October,<br>2003 | 2.0 | Table 13-2. Reset Recovery Timing — Replaced previous table with new information. | 112 | | | | | | Chapter 14 Timer Interface Module (TIM) — Updated with additional data. | 131 | | | | | | Figure 15-3. Break I/O Register Summary — Corrected bit designators for the BRKAR register | 143 | | | | | | 15.3 Monitor Module (MON) — Clarified seventh bullet. | 147 | | | | | | Table 17-1. MC Order Numbers — Corrected temperature and package designators. | 175 | | | | January, | 3.0 | Figure 2-2. Control, Status, and Data Registers — Corrected reset state for the FLASH Block Protect Register at address location \$FFBE and the Internal Oscillator Trim Value at \$FFC0. | 32 | | | | 2004 | | Figure 2-5. FLASH Block Protect Register (FLBPR) — Restated reset state for clarity. | 38 | | | #### **General Description** ## 1.5 Pin Functions Table 1-2 provides a description of the pin functions. **Table 1-2. Pin Functions** | Pin<br>Name | Description | Input/Output | |-------------------------|------------------------------------------------------------------------------------------------------------------|------------------| | $V_{DD}$ | Power supply | Power | | V <sub>SS</sub> | Power supply ground | Power | | | PTA0 — General purpose I/O port | Input/Output | | PTA0 | AD0 — A/D channel 0 input | Input | | PIAU | TCH0 — Timer Channel 0 I/O | Input/Output | | | KBI0 — Keyboard interrupt input 0 | Input | | | PTA1 — General purpose I/O port | Input/Output | | PTA1 | AD1 — A/D channel 1 input | Input | | FIAI | TCH1 — Timer Channel 1 I/O | Input/Output | | | KBI1 — Keyboard interrupt input 1 | Input | | | PTA2 — General purpose input-only port | Input | | PTA2 | IRQ — External interrupt with programmable pullup and Schmitt trigger input | Input | | FIAZ | KBI2 — Keyboard interrupt input 2 | Input | | | TCLK — Timer clock input | Input | | | PTA3 — General purpose I/O port | Input/Output | | PTA3 | RST — Reset input, active low with internal pullup and Schmitt trigger | Input | | | KBI3 — Keyboard interrupt input 3 | Input | | | PTA4 — General purpose I/O port | Input/Output | | PTA4 | OSC2 —XTAL oscillator output (XTAL option only) RC or internal oscillator output (OSC2EN = 1 in PTAPUE register) | Output<br>Output | | | AD2 — A/D channel 2 input | Input | | | KBI4 — Keyboard interrupt input 4 | Input | | | PTA5 — General purpose I/O port | Input/Output | | PTA5 | OSC1 — XTAL, RC, or external oscillator input | Input | | r IAO | AD3 — A/D channel 3 input | Input | | | KBI5 — Keyboard interrupt input 5 | Input | | PTB[0:7] <sup>(1)</sup> | 8 general-purpose I/O ports | Input/Output | | | | | <sup>1.</sup> The PTB pins are not available on the 8-pin packages (see note in 12.1 Introduction). MC68HC908QY/QT Family Data Sheet, Rev. 6 #### Memory | \$0000<br>↓ | I/O REGISTERS | | | | | | | | | |------------------|------------------------------------------------------------------------------|-------------------------------------------------|--------------------------------|--|--|--|--|--|--| | \$003F | 64 BYTES | | | | | | | | | | \$0040 | RESERVED <sup>(1)</sup> | | | | | | | | | | ↓<br>\$007F | 64 BYTES | Note 1. | | | | | | | | | \$0071 | | Attempts to execute code from addresses in this | | | | | | | | | $\downarrow$ | RAM<br>128 BYTES | range will generate an illegal address reset. | | | | | | | | | \$00FF | 120 81 120 | | | | | | | | | | \$0100 | UNIMPLEMENTED <sup>(1)</sup> | | | | | | | | | | \$27FF | 9984 BYTES | | | | | | | | | | \$2800 | AUXILIARY ROM | | | | | | | | | | ↓<br>\$2DFF | 1536 BYTES | | | | | | | | | | \$2E00 | | | \$2E00 | | | | | | | | , <b>\</b> | UNIMPLEMENTED <sup>(1)</sup><br>49152 BYTES | | UNIMPLEMENTED | | | | | | | | \$EDFF | 40 102 BT 1E0 | | 51712 BYTES | | | | | | | | \$EE00 | FLASH MEMORY | | \$F7FF | | | | | | | | ↓<br>↓ | MC68HC908QT4 AND MC68HC908QY4 | | FLASH MEMORY \$F800 | | | | | | | | \$FDFF | 4096 BYTES | | 1536 BYTES \$FDFF | | | | | | | | \$FE00 | BREAK STATUS REGISTER (BSR) | 1 | MC68HC908QT1, MC68HC908QT2, | | | | | | | | \$FE01 | RESET STATUS REGISTER (SRSR) | 1 | MC68HC908QY1, and MC68HC908QY2 | | | | | | | | \$FE02 | BREAK AUXILIARY REGISTER (BRKAR) | | Memory Map | | | | | | | | \$FE03 | BREAK FLAG CONTROL REGISTER (BFCR) | | | | | | | | | | \$FE04 | INTERRUPT STATUS REGISTER 1 (INT1) | | | | | | | | | | \$FE05 | INTERRUPT STATUS REGISTER 2 (INT2) | | | | | | | | | | \$FE06 | INTERRUPT STATUS REGISTER 3 (INT3) | | | | | | | | | | \$FE07 | RESERVED FOR FLASH TEST CONTROL REGISTER (FLTCR) | | | | | | | | | | \$FE08 | FLASH CONTROL REGISTER (FLCR) | | | | | | | | | | \$FE09<br>\$FE0A | BREAK ADDRESS HIGH REGISTER (BRKH) | _ | | | | | | | | | \$FE0B | BREAK ADDRESS LOW REGISTER (BRKL) BREAK STATUS AND CONTROL REGISTER (BRKSCR) | | | | | | | | | | \$FE0C | LVISR | | | | | | | | | | \$FE0D | · | | | | | | | | | | · ↓ | RESERVED FOR FLASH TEST<br>3 BYTES | | | | | | | | | | \$FE0F | 0.81120 | | | | | | | | | | \$FE10 | MONITOR ROM 416 BYTES | | | | | | | | | | \$FFAF | MONTO ITTO MATO BITES | | | | | | | | | | \$FFB0 | FLASH | | | | | | | | | | ↓<br>\$FFBD | 14 BYTES | | | | | | | | | | \$FFBE | FLASH BLOCK PROTECT REGISTER (FLBPR) | _ | | | | | | | | | \$FFBF | RESERVED FLASH | | | | | | | | | | \$FFC0 | INTERNAL OSCILLATOR TRIM VALUE (VDD = 5.0 V) | | | | | | | | | | \$FFC1 | INTERNAL OSCILLATOR TRIM VALUE (VDD = 3.0 V) | 1 | | | | | | | | | \$FFC2 | , , | † | | | | | | | | | $\downarrow$ | FLASH<br>14 BYTES | | | | | | | | | | \$FFCF | | _ | | | | | | | | | \$FFD0<br>↓ | USER VECTORS | | | | | | | | | | \$FFFF | 48 BYTES | | | | | | | | | Figure 2-1. Memory Map MC68HC908QY/QT Family Data Sheet, Rev. 6 Figure 2-4. FLASH Programming Flowchart MC68HC908QY/QT Family Data Sheet, Rev. 6 ## Chapter 3 Analog-to-Digital Converter (ADC) #### 3.1 Introduction This section describes the analog-to-digital converter (ADC). The ADC is an 8-bit, 4-channel analog-to-digital converter. The ADC module is only available on the MC68HC908QY2, MC68HC908QT2, MC68HC908QY4, and MC68HC908QT4. #### 3.2 Features Features of the ADC module include: - · 4 channels with multiplexed input - Linear successive approximation with monotonicity - 8-bit resolution - Single or continuous conversion - Conversion complete flag or conversion complete interrupt - Selectable ADC clock frequency ## 3.3 Functional Description Four ADC channels are available for sampling external sources at pins PTA0, PTA1, PTA4, and PTA5. An analog multiplexer allows the single ADC converter to select one of the four ADC channels as an ADC voltage input (ADCVIN). ADCVIN is converted by the successive approximation register-based counters. The ADC resolution is eight bits. When the conversion is completed, ADC puts the result in the ADC data register and sets a flag or generates an interrupt. Figure 3-2 shows a block diagram of the ADC. #### 3.3.1 ADC Port I/O Pins PTA0, PTA1, PTA4, and PTA5 are general-purpose I/O pins that are shared with the ADC channels. The channel select bits (ADC status and control register (ADSCR), \$003C), define which ADC channel/port pin will be used as the input signal. The ADC overrides the port I/O logic by forcing that pin as input to the ADC. The remaining ADC channels/port pins are controlled by the port I/O logic and can be used as general-purpose I/O. Writes to the port register or data direction register (DDR) will not have any affect on the port pin that is selected by the ADC. Read of a port pin which is in use by the ADC will return a 0 if the corresponding DDR bit is at 0. If the DDR bit is at 1, the value in the port data latch is read. ## **Central Processor Unit (CPU)** ## Table 7-1. Instruction Set Summary (Sheet 3 of 6) | Source | Operation | Operation Description | | Effect on CCR | | | | | Address<br>Mode | Opcode | Operand | les | |------------------------------------------------------------------------------------------------|----------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|---------------|---|---|----------|----------|-----------------------------------------------------|--------------------------------------------------|-------------------------------------------------|--------------------------------------| | Form | • poration | 2000 i piloti | ٧ | Н | I | N | Z | С | Add<br>Mod | Орс | Ope | Cycles | | CLI | Clear Interrupt Mask | I ← 0 | _ | - | 0 | - | - | - | INH | 9A | | 2 | | CLR opr<br>CLRA<br>CLRX<br>CLRH<br>CLR opr,X<br>CLR ,X<br>CLR opr,SP | Clear | $\begin{array}{l} M \leftarrow \$00 \\ A \leftarrow \$00 \\ X \leftarrow \$00 \\ H \leftarrow \$00 \\ M \leftarrow \$00 \\ M \leftarrow \$00 \\ M \leftarrow \$00 \\ M \leftarrow \$00 \end{array}$ | 0 | - | _ | 0 | 1 | _ | DIR<br>INH<br>INH<br>INH<br>IX1<br>IX<br>SP1 | 3F<br>4F<br>5F<br>8C<br>6F<br>7F<br>9E6F | ff<br>ff | 3<br>1<br>1<br>3<br>2<br>4 | | CMP #opr<br>CMP opr<br>CMP opr,<br>CMP opr,X<br>CMP opr,X<br>CMP,X<br>CMP opr,SP<br>CMP opr,SP | Compare A with M | (A) – (M) | ţ | 1 | | ‡ | 1 | <b>‡</b> | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP1<br>SP2 | A1<br>B1<br>C1<br>D1<br>E1<br>F1<br>9EE1<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 (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<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) | ţ | - | _ | ‡ | 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 | | 23443245 | | DAA | Decimal Adjust A | (A) <sub>10</sub> | U | - | - | ‡ | 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) + 2 + rel? \text{ (result)} \neq 0 \\ PC \leftarrow (PC) + 4 + 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}{l} 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 | - | 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 | _ | _ | _ | - | 1 | 1 | 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 | _ | _ | 1 | 1 | _ | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP1<br>SP2 | A8<br>B8<br>C8<br>D8<br>E8<br>F8<br>9EE8<br>9ED8 | ii<br>dd<br>hh II<br>ee ff<br>ff<br>ee ff | 2<br>3<br>4<br>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 | _ | _ | ‡ | <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 4 of 6) | Source | Operation Description | | | Effect on CCR | | | | | | | | Address<br>Mode | Opcode | Operand | les | |-----------------------------------------------------------------------------------------------------|-------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------|---------------|---|-----------|---|------------|-----------------------------------------------------|--------------------------------------------------|-------------------------------------------------|--------------------------------------|--------|---------|-----| | Form | орегинен | 2000p | ٧ | Н | I | N | Z | С | Add | Opc | Ope | Cycles | | | | | JMP opr<br>JMP opr<br>JMP opr,X<br>JMP opr,X<br>JMP ,X | Jump | PC ← Jump Address | _ | _ | - | - | - | - | DIR<br>EXT<br>IX2<br>IX1<br>IX | BC<br>CC<br>DC<br>EC<br>FC | dd<br>hh II<br>ee ff<br>ff | 2<br>3<br>4<br>3<br>2 | | | | | JSR opr<br>JSR opr<br>JSR opr,X<br>JSR opr,X<br>JSR ,X | Jump to Subroutine | $PC \leftarrow (PC) + n (n = 1, 2, \text{ or } 3)$<br>$Push (PCL); SP \leftarrow (SP) - 1$<br>$Push (PCH); SP \leftarrow (SP) - 1$<br>$PC \leftarrow Unconditional Address$ | _ | _ | _ | _ | _ | _ | DIR<br>EXT<br>IX2<br>IX1<br>IX | BD<br>CD<br>DD<br>ED<br>FD | dd<br>hh II<br>ee ff<br>ff | 4<br>5<br>6<br>5<br>4 | | | | | LDA #opr<br>LDA opr<br>LDA opr,<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 | _ | _ | Î | ţ | _ | 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 | | 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 | - | - | 1 | 1 | _ | IMM<br>DIR | 45<br>55 | ii jj<br>dd | 3 | | | | | LDX #opr<br>LDX opr<br>LDX opr<br>LDX opr,X<br>LDX opr,X<br>LDX,X<br>LDX opr,SP<br>LDX opr,SP | Load X from M | X ← (M) | 0 | _ | _ | 1 | 1 | _ | 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>ff<br>ee ff | 2<br>3<br>4<br>4<br>3<br>2<br>4<br>5 | | | | | 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 b0 b0 | t | _ | - | 1 | 1 | ‡ | 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<br>b7 b0 | t | - | _ | 0 | ţ | ‡ | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1 | 34<br>44<br>54<br>64<br>74<br>9E64 | dd<br>ff<br>ff | 4<br>1<br>1<br>4<br>3<br>5 | | | | | MOV opr,opr<br>MOV opr,X+<br>MOV #opr,opr<br>MOV X+,opr | Move | $(M)_{Destination} \leftarrow (M)_{Source}$ $H:X \leftarrow (H:X) + 1 (IX+D, DIX+)$ | 0 | - | - | ‡ | ţ | - | DD<br>DIX+<br>IMD<br>IX+D | 4E<br>5E<br>6E<br>7E | dd dd<br>dd<br>ii dd<br>dd | 5<br>4<br>4<br>4 | | | | | MUL | Unsigned multiply | $X:A \leftarrow (X) \times (A)$ | _ | 0 | - | - | - | 0 | INH | 42 | | 5 | | | | | NEG opr<br>NEGA<br>NEGX<br>NEG opr,X<br>NEG ,X<br>NEG opr,SP | Negate (Two's Complement) | $\begin{array}{l} M \leftarrow -(M) = \$00 - (M) \\ A \leftarrow -(A) = \$00 - (A) \\ X \leftarrow -(X) = \$00 - (X) \\ M \leftarrow -(M) = \$00 - (M) \\ M \leftarrow -(M) = \$00 - (M) \end{array}$ | 1 | _ | _ | 1 | 1 | ‡ | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1 | 30<br>40<br>50<br>60<br>70<br>9E60 | dd<br>ff<br>ff | 4<br>1<br>1<br>4<br>3<br>5 | | | | | NOP | No Operation | None | - | - | - | - | - | - | INH | 9D | | 1 | | | | | NSA | Nibble Swap A | A ← (A[3:0]:A[7:4]) | <u> -</u> | <u> -</u> | _ | <u> -</u> | _ | <u> -</u> | INH | 62 | | 3 | | | | | ORA #opr<br>ORA opr<br>ORA opr<br>ORA opr,X<br>ORA opr,X<br>ORA,X<br>ORA opr,SP<br>ORA opr,SP | Inclusive OR A and M | A ← (A) (M) | 0 | _ | _ | 1 | 1 | _ | 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 | <u> </u> | _ | _ | _ | _ | - | INH | 87 | | 2 | | | | | PSHH | Push H onto Stack | Push (H); SP ← (SP) – 1 | Ŀ | _ | _ | <u> </u> | - | Ŀ | INH | 8B | | 2 | | | | | PSHX | Push X onto Stack | Push (X); SP $\leftarrow$ (SP) – 1 | <u> </u> - | <u> </u> – | _ | [- | _ | <u> </u> – | INH | 89 | | 2 | | | | # Chapter 9 Keyboard Interrupt Module (KBI) #### 9.1 Introduction The keyboard interrupt module (KBI) provides six independently maskable external interrupts, which are accessible via the PTA0–PTA5 pins. #### 9.2 Features Features of the keyboard interrupt module include: - Six keyboard interrupt pins with separate keyboard interrupt enable bits and one keyboard interrupt mask - Software configurable pullup device if input pin is configured as input port bit - Programmable edge-only or edge and level interrupt sensitivity - Exit from low-power modes ### 9.3 Functional Description The keyboard interrupt module controls the enabling/disabling of interrupt functions on the six port A pins. These six pins can be enabled/disabled independently of each other. Refer to Figure 9-2. #### 9.3.1 Keyboard Operation Writing to the KBIE0–KBIE5 bits in the keyboard interrupt enable register (KBIER) independently enables or disables each port A pin as a keyboard interrupt pin. Enabling a keyboard interrupt pin in port A also enables its internal pullup device irrespective of PTAPUEx bits in the port A input pullup enable register (see 12.2.3 Port A Input Pullup Enable Register). 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 interrupt inputs 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 interrupt input does not latch an interrupt request if another keyboard pin is already low. To prevent losing an interrupt request on one input because another input is still low, software can disable the latter input 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 interrupt input is low. **Oscillator Module (OSC)** #### 11.4.2 Crystal Amplifier Output Pin (OSC2/PTA4/BUSCLKX4) For the XTAL oscillator device, the OSC2 pin is the crystal oscillator inverting amplifier output. For the external clock option, the OSC2 pin is dedicated to the PTA4 I/O function. The OSC2EN bit has no effect. For the internal oscillator or RC oscillator options, the OSC2 pin can assume other functions according to Table 1-3. Function Priority in Shared Pins, or the output of the oscillator clock (BUSCLKX4). Option XTAL oscillator External clock Internal oscillator or RC oscillator OSC2 Pin Function Inverting OSC1 PTA4 I/O Controlled by OSC2EN bit in PTAPUE register OSC2EN = 0: PTA4 I/O OSC2EN = 1: BUSCLKX4 output **Table 11-1. OSC2 Pin Function** #### 11.4.3 Oscillator Enable Signal (SIMOSCEN) The SIMOSCEN signal comes from the system integration module (SIM) and enables/disables either the XTAL oscillator circuit, the RC oscillator, or the internal oscillator. #### 11.4.4 XTAL Oscillator Clock (XTALCLK) XTALCLK is the XTAL oscillator output signal. It runs at the full speed of the crystal ( $f_{XCLK}$ ) and comes directly from the crystal oscillator circuit. Figure 11-2 shows only the logical relation of XTALCLK to OSC1 and OSC2 and may not represent the actual circuitry. The duty cycle of XTALCLK is unknown and may depend on the crystal and other external factors. Also, the frequency and amplitude of XTALCLK can be unstable at start up. ## 11.4.5 RC Oscillator Clock (RCCLK) RCCLK is the RC oscillator output signal. Its frequency is directly proportional to the time constant of external R and internal C. Figure 11-3 shows only the logical relation of RCCLK to OSC1 and may not represent the actual circuitry. #### 11.4.6 Internal Oscillator Clock (INTCLK) INTCLK is the internal oscillator output signal. Its nominal frequency is fixed to 12.8 MHz, but it can be also trimmed using the oscillator trimming feature of the OSCTRIM register (see 11.3.1.1 Internal Oscillator Trimming). #### 11.4.7 Oscillator Out 2 (BUSCLKX4) BUSCLKX4 is the same as the input clock (XTALCLK, RCCLK, or INTCLK). This signal is driven to the SIM module and is used to determine the COP cycles. #### 11.4.8 Oscillator Out (BUSCLKX2) The frequency of this signal is equal to half of the BUSCLKX4, this signal is driven to the SIM for generation of the bus clocks used by the CPU and other modules on the MCU. BUSCLKX2 will be divided MC68HC908QY/QT Family Data Sheet, Rev. 6 A module that is active during wait mode can wake up the CPU with an interrupt if the interrupt is enabled. Stacking for the interrupt begins one cycle after the WAIT instruction during which the interrupt occurred. In wait mode, the CPU clocks are inactive. Refer to the wait mode subsection of each module to see if the module is active or inactive in wait mode. Some modules can be programmed to be active in wait mode. Wait mode can also be exited by a reset (or break in emulation mode). A break interrupt during wait mode sets the SIM break stop/wait bit, SBSW, in the break status register (BSR). If the COP disable bit, COPD, in the configuration register is 0, then the computer operating properly module (COP) is enabled and remains active in wait mode. Figure 13-15 and Figure 13-16 show the timing for wait recovery. NOTE: EXITSTOPWAIT = RST pin OR CPU interrupt OR break interrupt Figure 13-15. Wait Recovery from Interrupt Figure 13-16. Wait Recovery from Internal Reset #### **13.7.2 Stop Mode** In stop mode, the SIM counter is reset and the system clocks are disabled. An interrupt request from a module can cause an exit from stop mode. Stacking for interrupts begins after the selected stop recovery time has elapsed. Reset or break also causes an exit from stop mode. The SIM disables the oscillator signals (BUSCLKX2 and BUSCLKX4) in stop mode, stopping the CPU and peripherals. Stop recovery time is selectable using the SSREC bit in the configuration register 1 (CONFIG1). If SSREC is set, stop recovery is reduced from the normal delay of 4096 BUSCLKX4 cycles down to 32. This is ideal for the internal oscillator, RC oscillator, and external oscillator options which do not require long start-up times from stop mode. #### NOTE External crystal applications should use the full stop recovery time by clearing the SSREC bit. MC68HC908QY/QT Family Data Sheet, Rev. 6 #### **Timer Interface Module (TIM)** RST, IRQ: Pins have internal (about 30K Ohms) pull up PTA[0:5]: High current sink and source capability PTA[0:5]: Pins have programmable keyboard interrupt and pull up PTB[0:7]: Not available on 8-pin devices – MC68HC908QT1, MC68HC908QT2, and MC68HC908QT4 (see note in 12.1 Introduction) ADC: Not available on the MC68HC908QY1 and MC68HC908QT1 Figure 14-1. Block Diagram Highlighting TIM Block and Pins #### Timer Interface Module (TIM) #### 14.4.4.1 Unbuffered PWM Signal Generation Any output compare channel can generate unbuffered PWM pulses as described in 14.4.4 Pulse Width Modulation (PWM). The pulses are unbuffered because changing the pulse width requires writing the new pulse width value over the old value currently in the TIM channel registers. An unsynchronized write to the TIM channel registers to change a pulse width value could cause incorrect operation for up to two PWM periods. For example, writing a new value before the counter reaches the old value but after the counter reaches the new value prevents any compare during that PWM period. Also, using a TIM overflow interrupt routine to write a new, smaller pulse width value may cause the compare to be missed. The TIM may pass the new value before it is written. Use the following methods to synchronize unbuffered changes in the PWM pulse width on channel x: - When changing to a shorter pulse width, enable channel x output compare interrupts and write the new value in the output compare interrupt routine. The output compare interrupt occurs at the end of the current pulse. The interrupt routine has until the end of the PWM period to write the new value. - When changing to a longer pulse width, enable TIM overflow interrupts and write the new value in the TIM overflow interrupt routine. The TIM overflow interrupt occurs at the end of the current PWM period. Writing a larger value in an output compare interrupt routine (at the end of the current pulse) could cause two output compares to occur in the same PWM period. #### NOTE In PWM signal generation, do not program the PWM channel to toggle on output compare. Toggling on output compare prevents reliable 0% duty cycle generation and removes the ability of the channel to self-correct in the event of software error or noise. Toggling on output compare also can cause incorrect PWM signal generation when changing the PWM pulse width to a new, much larger value. #### 14.4.4.2 Buffered PWM Signal Generation Channels 0 and 1 can be linked to form a buffered PWM channel whose output appears on the TCH0 pin. The TIM channel registers of the linked pair alternately control the pulse width of the output. Setting the MS0B bit in TIM channel 0 status and control register (TSC0) links channel 0 and channel 1. The TIM channel 0 registers initially control the pulse width on the TCH0 pin. Writing to the TIM channel 1 registers enables the TIM channel 1 registers to synchronously control the pulse width at the beginning of the next PWM period. At each subsequent overflow, the TIM channel registers (0 or 1) that control the pulse width are the ones written to last. TSC0 controls and monitors the buffered PWM function, and TIM channel 1 status and control register (TSC1) is unused. While the MS0B bit is set, the channel 1 pin, TCH1, is available as a general-purpose I/O pin. #### NOTE In buffered PWM signal generation, do not write new pulse width values to the currently active channel registers. User software should track the currently active channel to prevent writing a new value to the active channel. Writing to the active channel registers is the same as generating unbuffered PWM signals. #### **Development Support** #### 15.2.2.1 Break Status and Control Register The break status and control register (BRKSCR) contains break module enable and status bits. Figure 15-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 #### 15.2.2.2 Break Address Registers The break address registers (BRKH and BRKL) contain the high and low bytes of the desired breakpoint address. Reset clears the break address registers. Figure 15-4. Break Address Register High (BRKH) Figure 15-5. Break Address Register Low (BRKL) #### Table 15-4. WRITE (Write Memory) Command Table 15-5. IREAD (Indexed Read) Command Table 15-6. IWRITE (Indexed Write) Command A sequence of IREAD or IWRITE commands can access a block of memory sequentially over the full 64-Kbyte memory map. MC68HC908QY/QT Family Data Sheet, Rev. 6 #### **Electrical Specifications** ## 16.6 Typical 5-V Output Drive Characteristics Figure 16-1. Typical 5-Volt Output High Voltage versus Output High Current (25•C) Figure 16-2. Typical 5-Volt Output Low Voltage versus Output Low Current (25•C) ## 16.9 3-V DC Electrical Characteristics | Characteristic <sup>(1)</sup> | Symbol | Min | Typ <sup>(2)</sup> | Max | Unit | |---------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|----------------------------------------------------------------------|--------------------|-----------------------|------| | Output high voltage I <sub>Load</sub> = -0.6 mA, all I/O pins I <sub>Load</sub> = -4.0 mA, all I/O pins I <sub>Load</sub> = -10.0 mA, PTA0, PTA1, PTA3-PTA5 only | V <sub>ОН</sub> | V <sub>DD</sub> -0.3<br>V <sub>DD</sub> -1.0<br>V <sub>DD</sub> -0.8 | | _<br>_<br>_ | V | | Maximum combined I <sub>OH</sub> (all I/O pins) | I <sub>OHT</sub> | _ | _ | 50 | mA | | Output low voltage $I_{Load}$ = 0.5 mA, all I/O pins $I_{Load}$ = 6.0 mA, all I/O pins $I_{Load}$ = 10.0 mA, PTA0, PTA1, PTA3-PTA5 only | V <sub>OL</sub> | _<br>_<br>_ | _<br>_<br>_ | 0.3<br>1.0<br>0.8 | V | | Maximum combined I <sub>OL</sub> (all I/O pins) | l <sub>OLT</sub> | _ | _ | 50 | mA | | Input high voltage PTA0-PTA5, PTB0-PTB7 | V <sub>IH</sub> | 0.7 x V <sub>DD</sub> | _ | V <sub>DD</sub> | V | | Input low voltage<br>PTA0-PTA5, PTB0-PTB7 | V <sub>IL</sub> | V <sub>SS</sub> | _ | 0.3 x V <sub>DD</sub> | V | | Input hysteresis | V <sub>HYS</sub> | 0.06 x V <sub>DD</sub> | _ | _ | V | | DC injection current, all ports | I <sub>INJ</sub> | -2 | _ | +2 | mA | | Total dc current injection (sum of all I/O) | I <sub>INJTOT</sub> | -25 | _ | +25 | mA | | Ports Hi-Z leakage current | I <sub>IL</sub> | -1 | ±0.1 | +1 | μΑ | | Capacitance Ports (as input) Ports (as input) | C <sub>IN</sub><br>C <sub>OUT</sub> | | _ | 12<br>8 | pF | | POR rearm voltage <sup>(3)</sup> | V <sub>POR</sub> | 0 | _ | 100 | mV | | POR rise time ramp rate <sup>(4)</sup> | R <sub>POR</sub> | 0.035 | _ | _ | V/ms | | Monitor mode entry voltage | V <sub>TST</sub> | V <sub>DD</sub> + 2.5 | _ | V <sub>DD</sub> + 4.0 | V | | Pullup resistors <sup>(5)</sup><br>PTA0–PTA5, PTB0–PTB7 | R <sub>PU</sub> | 16 | 26 | 36 | kΩ | | Low-voltage inhibit reset, trip falling voltage | V <sub>TRIPF</sub> | 2.40 | 2.55 | 2.70 | V | | Low-voltage inhibit reset, trip rising voltage | V <sub>TRIPR</sub> | 2.50 | 2.65 | 2.80 | V | | Low-voltage inhibit reset/recover hysteresis | V <sub>HYS</sub> | _ | 60 | _ | mV | - 1. $V_{DD}$ = 2.7 to 3.3 Vdc, $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. - 3. Maximum is highest voltage that POR is guaranteed. - 4. If minimum V<sub>DD</sub> is not reached before the internal POR reset is released, the LVI will hold the part in reset until minimum $V_{DD}$ is reached. 5. $R_{PU}$ are measured at $V_{DD}$ = 3.0 V **Electrical Specifications** ## Chapter 17 Ordering Information and Mechanical Specifications #### 17.1 Introduction This section contains order numbers for the MC68HC908QY1, MC68HC908QY2, MC68HC908QY4, MC68HC908QT1, MC68HC908QT2, and MC69HC908QT4. Dimensions are given for: - 8-pin plastic dual in-line package (PDIP) - 8-pin small outline integrated circuit (SOIC) package - 8-pin dual flat no lead (DFN) package - 16-pin PDIP - 16-pin SOIC - 16-pin thin shrink small outline package (TSSOP) #### 17.2 MC Order Numbers **Table 17-1. MC Order Numbers** | MC Order Number | ADC | FLASH Memory | Package | |-----------------|-----|--------------|-------------| | MC908QY1 | _ | 1536 bytes | 16-pins | | MC908QY2 | Yes | 1536 bytes | PDIP, SOIC, | | MC908QY4 | Yes | 4096 bytes | and TSSOP | | MC908QT1 | _ | 1536 bytes | 8-pins | | MC908QT2 | Yes | 1536 bytes | PDIP, SOIC, | | MC908QT4 | Yes | 4096 bytes | and DFN | Temperature and package designators: $C = -40 \cdot C \text{ to } +85 \cdot C$ $V = -40 \cdot C \text{ to } +105 \cdot C$ $M = -40 \cdot C \text{ to } + 125 \cdot C$ P = Plastic dual in-line package (PDIP) DW = Small outline integrated circuit package (SOIC) DT = Thin shrink small outline package (TSSOP) FQ = Dual flat no lead (DFN) Figure 17-1. Device Numbering System ## 17.3 Package Dimensions Refer to the following pages for detailed package dimensions. MC68HC908QY/QT Family Data Sheet, Rev. 6 © FREESCALE SEMICONDUCTOR, INC. ALL RIGHTS RESERVED. ELECTRONIC VERSIONS ARE UNCONTROLLED EXCEPT WHEN ACCESSED DIRECTLY FROM THE DOCUMENT CONTROL REPOSITORY. PRINTED VERSIONS ARE UNCONTROLLED EXCEPT WHEN STAMPED "CONTROLLED COPY" IN RED. ## MECHANICAL OUTLINES DICTIONARY DO NOT SCALE THIS DRAWING DOCUMENT NO: 98ARL10557D PAGE: 1452 REV: A TITLE: THERMALLY ENHANCED DUAL FLAT NO LEAD PACKAGE (DFN) 8 TERMINAL, 0.8 PITCH (4 X 4 X 1) CASE NUMBER: 1452-01 STANDARD: NON-JEDEC PACKAGE CODE: 6165 | SHEET: 1 OF 5