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 | 4KB (4K x 8) | | Program Memory Type | FLASH | | EEPROM Size | - | | RAM Size | 128 x 8 | | Voltage - Supply (Vcc/Vdd) | 2.7V ~ 5.5V | | Data Converters | A/D 4x8b | | Oscillator Type | Internal | | Operating Temperature | -40°C ~ 85°C (TA) | | Mounting Type | Surface Mount | | Package / Case | 16-SOIC (0.295", 7.50mm Width) | | Supplier Device Package | 16-SOIC | | Purchase URL | https://www.e-xfl.com/product-detail/nxp-semiconductors/mc68hc908qy4cdw | | Addr. | Register Name | | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | | |-----------------------|---------------------------------------------------------|-----------------|---------------------------|------------|---------------------------|-------------|----------------|----------|--------|--------|--| | | TIM Counter Register Low | Read: | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | | \$0022 | (TCNTL) | Write: | | | | | | | | | | | | See page 128. | Reset: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | \$0023 | TIM Counter Modulo<br>Register High (TMODH) | Read:<br>Write: | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | | | | See page 129. | Reset: | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | \$0024 | TIM Counter Modulo<br>Register Low (TMODL) | Read:<br>Write: | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | | | See page 129. | Reset: | 1 | 1 | 1 | 1 | 1 | 1 | 1 | 1 | | | \$0025 | TIM Channel 0 Status and<br>Control Register (TSC0) | Read:<br>Write: | CH0F<br>0 | CH0IE | MS0B | MS0A | ELS0B | ELS0A | TOV0 | CH0MAX | | | , | See page 130. | Reset: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | \$0026 | TIM Channel 0<br>Register High (TCH0H) | Read:<br>Write: | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | | | | See page 132. | Reset: | | | | Indetermina | te after reset | | | | | | ¢0027 | TIM Channel 0 Register Low (TCH0L) See page 132. | Read:<br>Write: | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | | \$0027 | | Reset: | | | | Indetermina | to ofter reset | | | | | | | | Read: | CH1F | | 0 | Inueternina | le allei lesel | | 1 | | | | \$0028 | TIM Channel 1 Status and Control Register (TSC1) | Write: | 0 | CH1IE | U | MS1A | ELS1B | ELS1A | TOV1 | CH1MAX | | | | See page 130. | Reset: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | \$0029 | TIM Channel 1<br>Register High (TCH1H)<br>See page 132. | Read:<br>Write: | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 | | | | | Reset: | Indeterminate after reset | | | | | | | | | | \$002A | TIM Channel 1<br>Register Low (TCH1L) | Read:<br>Write: | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 | | | | See page 132. | Reset: | | | Indeterminate after reset | | | | | | | | \$002B<br>↓<br>\$0035 | Unimplemented | | | | | | | | | | | | | | _ | | | | | | | | | | | \$0036 | Oscillator Status Register (OSCSTAT) | Read:<br>Write: | R | R | R | R | R | R | ECGON | ECGST | | | | See page 96. | Reset: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | \$0037 | Unimplemented | Read: | | | | | | | | | | | | | | | | | | | | | | | | \$0038 | Oscillator Trim Register<br>(OSCTRIM) | Read:<br>Write: | TRIM7 | TRIM6 | TRIM5 | TRIM4 | TRIM3 | TRIM2 | TRIM1 | TRIM0 | | | | See page 96. | Reset: | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | ſ | | = Unimplem | ented | R | = Reserved | U = Unaf | fected | | | | | | | | - | | | - | | | | | Figure 2-2. Control, Status, and Data Registers (Sheet 3 of 5) MC68HC908QY/QT Family Data Sheet, Rev. 6 ### Memory # **ERASE** — Erase Control Bit This read/write bit configures the memory for erase operation. ERASE 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. PGM 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 # 2.6.2 FLASH Page Erase Operation Use the following procedure to erase a page of FLASH memory. A page consists of 64 consecutive bytes starting from addresses \$XX00, \$XX40, \$XX80, or \$XXC0. The 48-byte user interrupt vectors area also forms a page. Any FLASH memory page can be erased alone. - 1. Set the ERASE bit and clear the MASS bit in the FLASH control register. - 2. Read the FLASH block protect register. - 3. Write any data to any FLASH location within the address range of the block to be erased. - 4. Wait for a time, $t_{NVS}$ (minimum 10 $\mu$ s). - 5. Set the HVEN bit. - 6. Wait for a time, t<sub>Erase</sub> (minimum 1 ms or 4 ms). - 7. Clear the ERASE bit. - 8. Wait for a time, $t_{NVH}$ (minimum 5 $\mu$ s). - 9. Clear the HVEN bit. - 10. After time, $t_{RCV}$ (typical 1 $\mu$ s), the memory can be accessed in read mode again. ### NOTE Programming and erasing of FLASH locations cannot be performed by code being executed from the FLASH memory. While these operations must be performed in the order as shown, but other unrelated operations may occur between the steps. # **CAUTION** A page erase of the vector page will erase the internal oscillator trim values at \$FFC0 and \$FFC1. In applications that require more than 1000 program/erase cycles, use the 4 ms page erase specification to get improved long-term reliability. Any application can use this 4 ms page erase specification. However, in applications where a FLASH location will be erased and reprogrammed less than 1000 times, and speed is important, use the 1 ms page erase specification to get a shorter cycle time. Figure 3-2. ADC Block Diagram ### **Auto Wakeup Module (AWU)** # Bits 7-4 — Not used These read-only bits always read as 0s. # **KEYF** — Keyboard Flag Bit This read-only bit is set when a keyboard interrupt is pending on port A or auto wakeup. Reset clears the KEYF bit. - 1 = Keyboard/auto wakeup interrupt pending - 0 = No keyboard/auto wakeup interrupt pending # ACKK — Keyboard Acknowledge Bit Writing a 1 to this write-only bit clears the keyboard/auto wakeup interrupt request on port A and auto wakeup logic. ACKK always reads as 0.Reset clears ACKK. # **IMASKK**— Keyboard Interrupt Mask Bit Writing a 1 to this read/write bit prevents the output of the keyboard interrupt mask from generating interrupt requests on port A or auto wakeup. Reset clears the IMASKK bit. - 1 = Keyboard/auto wakeup interrupt requests masked - 0 = Keyboard/auto wakeup interrupt requests not masked ### NOTE MODEK is not used in conjuction with the auto wakeup feature. To see a description of this bit, see 9.7.1 Keyboard Status and Control Register. # 4.6.3 Keyboard Interrupt Enable Register The keyboard interrupt enable register (KBIER) enables or disables the auto wakeup to operate as a keyboard/auto wakeup interrupt input. Figure 4-4. Keyboard Interrupt Enable Register (KBIER) # **AWUIE** — Auto Wakeup Interrupt Enable Bit This read/write bit enables the auto wakeup interrupt input to latch interrupt requests. Reset clears AWUIE. - 1 = Auto wakeup enabled as interrupt input - 0 = Auto wakeup not enabled as interrupt input ### NOTE KBIE5–KBIE0 bits are not used in conjuction with the auto wakeup feature. To see a description of these bits, see 9.7.2 Keyboard Interrupt Enable Register. # **Computer Operating Properly (COP)** The COP counter is a free-running 6-bit counter preceded by the 12-bit system integration module (SIM) counter. If not cleared by software, the COP counter overflows and generates an asynchronous reset after 262,128 or 8176 BUSCLKX4 cycles; depending on the state of the COP rate select bit, COPRS, in configuration register 1. With a 262,128 BUSCLKX4 cycle overflow option, the internal 12.8-MHz oscillator gives a COP timeout period of 20.48 ms. Writing any value to location \$FFFF before an overflow occurs prevents a COP reset by clearing the COP counter and stages 12–5 of the SIM counter. ## 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 $\overline{RST}$ pin low (if the RSTEN bit is set in the CONFIG1 register) for $32 \times BUSCLKX4$ cycles and sets the COP bit in the reset status register (RSR). See 13.8.1 SIM Reset Status Register. ### 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. # 6.3 I/O Signals The following paragraphs describe the signals shown in Figure 6-1. # 6.3.1 BUSCLKX4 BUSCLKX4 is the oscillator output signal. BUSCLKX4 frequency is equal to the internal oscillator frequency, the crystal frequency, or the RC-oscillator frequency. # 6.3.2 STOP Instruction The STOP instruction clears the SIM counter. # 6.3.3 COPCTL Write Writing any value to the COP control register (COPCTL) (see 6.4 COP Control Register) clears the COP counter and clears stages 12–5 of the SIM counter. Reading the COP control register returns the low byte of the reset vector. # 6.3.4 Power-On Reset The power-on reset (POR) circuit in the SIM clears the SIM counter $4096 \times BUSCLKX4$ cycles after power up. # 6.3.5 Internal Reset An internal reset clears the SIM counter and the COP counter. # 6.3.6 COPD (COP Disable) The COPD signal reflects the state of the COP disable bit (COPD) in the configuration register 1 (CONFIG1). See Chapter 5 Configuration Register (CONFIG). MC68HC908QY/QT Family Data Sheet, Rev. 6 # **Chapter 7 Central Processor Unit (CPU)** # 7.1 Introduction The M68HC08 CPU (central processor unit) is an enhanced and fully object-code-compatible version of the M68HC05 CPU. The *CPU08 Reference Manual* (document order number CPU08RM/AD) contains a description of the CPU instruction set, addressing modes, and architecture. # 7.2 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 # 7.3 CPU Registers Figure 7-1 shows the five CPU registers. CPU registers are not part of the memory map. **Central Processor Unit (CPU)** # 7.3.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 1. The following paragraphs describe the functions of the condition code register. Figure 7-6. Condition Code Register (CCR) # V — Overflow Flag The CPU sets the overflow flag when a two's complement overflow occurs. The signed branch instructions BGT, BGE, BLE, and BLT use the overflow flag. - 1 = Overflow - 0 = No overflow # H — Half-Carry Flag The CPU sets the half-carry flag when a carry occurs between accumulator bits 3 and 4 during an 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 Family 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 # MC68HC908QY/QT Family Data Sheet, Rev. 6 8HC908QY/QT Family Da Table 7-2. Opcode Map | | Bit Mani | Bit Manipulation Branch Read-Modify-Write | | | | Control Register/Mem | | | /Memory | - | | | | | | | | | | |------------|----------------------|-----------------------------------------------|--------------------|--------------------|--------------------|----------------------|---------------------|--------------------|--------------------|--------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|-------------------|------------------| | | DIR | DIR | REL | DIR | INH | INH | IX1 | SP1 | IX | INH | INH | IMM | DIR | EXT | IX2 | SP2 | IX1 | SP1 | IX | | MSB<br>LSB | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 9E6 | 7 | 8 | 9 | Α | В | С | D | 9ED | E | 9EE | F | | 0 | - | BSET0<br>2 DIR | | | 1<br>NEGA<br>1 INH | | 4<br>NEG<br>2 IX1 | | 3<br>NEG<br>1 IX | 7<br>RTI<br>1 INH | | SUB<br>2 IMM | | | SUB<br>3 IX2 | 5<br>SUB<br>4 SP2 | 3<br>SUB<br>2 IX1 | 4<br>SUB<br>3 SP1 | 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 | 3 IMM | CBEQX<br>3 IMM | 5<br>CBEQ<br>3 IX1+ | 6<br>CBEQ<br>4 SP1 | | 4<br>RTS<br>1 INH | 3<br>BLT<br>2 REL | | 3<br>CMP<br>2 DIR | 4<br>CMP<br>3 EXT | 4<br>CMP<br>3 IX2 | 5<br>CMP<br>4 SP2 | 3<br>CMP<br>2 IX1 | 4<br>CMP<br>3 SP1 | 2<br>CMP<br>1 IX | | 2 | - | BSET1<br>2 DIR | | | 5<br>MUL<br>1 INH | 7<br>DIV<br>1 INH | 3<br>NSA<br>1 INH | | 2<br>DAA<br>1 INH | | 3<br>BGT<br>2 REL | | 3<br>SBC<br>2 DIR | 4<br>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 | - | 4<br>BCLR1<br>2 DIR | | COM<br>2 DIR | 1<br>COMA<br>1 INH | | 4<br>COM<br>2 IX1 | 5<br>COM<br>3 SP1 | | 9<br>SWI<br>1 INH | | | | | | 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 | 3<br>BCC<br>2 REL | 4<br>LSR<br>2 DIR | 1<br>LSRA<br>1 INH | 1<br>LSRX<br>1 INH | 4<br>LSR<br>2 IX1 | 5<br>LSR<br>3 SP1 | | 2<br>TAP<br>1 INH | | 2<br>AND<br>2 IMM | | | | 5<br>AND<br>4 SP2 | | 4<br>AND<br>3 SP1 | 2<br>AND<br>1 IX | | 5 | 5<br>BRCLR2<br>3 DIR | 4<br>BCLR2<br>2 DIR | 3<br>BCS<br>2 REL | 4<br>STHX<br>2 DIR | 3<br>LDHX<br>3 IMM | 4<br>LDHX<br>2 DIR | CPHX<br>3 IMM | | 4<br>CPHX<br>2 DIR | 1<br>TPA<br>1 INH | 2<br>TSX<br>1 INH | | | 4<br>BIT<br>3 EXT | | | 3<br>BIT<br>2 IX1 | 4<br>BIT<br>3 SP1 | 2<br>BIT<br>1 IX | | 6 | 5<br>BRSET3<br>3 DIR | BSET3<br>2 DIR | 3<br>BNE<br>2 REL | 4<br>ROR<br>2 DIR | 1<br>RORA<br>1 INH | 1<br>RORX<br>1 INH | 4<br>ROR<br>2 IX1 | 5<br>ROR<br>3 SP1 | 3<br>ROR<br>1 IX | 2<br>PULA<br>1 INH | | 2<br>LDA<br>2 IMM | 3<br>LDA<br>2 DIR | 4<br>LDA<br>3 EXT | 4<br>LDA<br>3 IX2 | 5<br>LDA<br>4 SP2 | 3<br>LDA<br>2 IX1 | 4<br>LDA<br>3 SP1 | 2<br>LDA<br>1 IX | | 7 | 5<br>BRCLR3<br>3 DIR | 4<br>BCLR3<br>2 DIR | 3<br>BEQ<br>2 REL | 4<br>ASR<br>2 DIR | 1<br>ASRA<br>1 INH | 1<br>ASRX<br>1 INH | 4<br>ASR<br>2 IX1 | 5<br>ASR<br>3 SP1 | 3<br>ASR<br>1 IX | 2<br>PSHA<br>1 INH | 1<br>TAX<br>1 INH | 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 | 4<br>LSL<br>2 IX1 | 5<br>LSL<br>3 SP1 | 3<br>LSL<br>1 IX | 2<br>PULX<br>1 INH | 1<br>CLC<br>1 INH | EOR<br>2 IMM | 3<br>EOR<br>2 DIR | 4<br>EOR<br>3 EXT | 4<br>EOR<br>3 IX2 | 5<br>EOR<br>4 SP2 | 3<br>EOR<br>2 IX1 | 4<br>EOR<br>3 SP1 | EOR<br>1 IX | | 9 | 5<br>BRCLR4<br>3 DIR | 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 | SEC<br>1 INH | | 3<br>ADC<br>2 DIR | 4<br>ADC<br>3 EXT | ADC<br>3 IX2 | 5<br>ADC<br>4 SP2 | 3<br>ADC<br>2 IX1 | 4<br>ADC<br>3 SP1 | 2<br>ADC<br>1 IX | | A | 5<br>BRSET5<br>3 DIR | 4<br>BSET5<br>2 DIR | 3<br>BPL<br>2 REL | 4<br>DEC<br>2 DIR | 1<br>DECA<br>1 INH | 1<br>DECX<br>1 INH | 4<br>DEC<br>2 IX1 | 5<br>DEC<br>3 SP1 | 3<br>DEC<br>1 IX | 2<br>PULH<br>1 INH | 2<br>CLI<br>1 INH | ORA<br>2 IMM | 3<br>ORA<br>2 DIR | 4<br>ORA<br>3 EXT | 4<br>ORA<br>3 IX2 | 5<br>ORA<br>4 SP2 | 3<br>ORA<br>2 IX1 | 4<br>ORA<br>3 SP1 | 2<br>ORA<br>1 IX | | В | 5<br>BRCLR5<br>3 DIR | BCLR5<br>2 DIR | 3<br>BMI<br>2 REL | 5<br>DBNZ<br>3 DIR | | 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 | 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 | 4<br>BSET6<br>2 DIR | | 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 | 3<br>INC<br>1 IX | 1<br>CLRH<br>1 INH | 1<br>RSP<br>1 INH | | 2<br>JMP<br>2 DIR | 3<br>JMP<br>3 EXT | | | 3<br>JMP<br>2 IX1 | | 2<br>JMP<br>1 IX | | D | 5<br>BRCLR6<br>3 DIR | 4<br>BCLR6<br>2 DIR | | 3<br>TST<br>2 DIR | 1<br>TSTA<br>1 INH | | 3<br>TST<br>2 IX1 | 4<br>TST<br>3 SP1 | | | 1<br>NOP<br>1 INH | | 4<br>JSR<br>2 DIR | 5<br>JSR<br>3 EXT | | | 5<br>JSR<br>2 IX1 | | JSR<br>1 IX | | E | | 4<br>BSET7<br>2 DIR | | | 5<br>MOV<br>3 DD | 4<br>MOV<br>2 DIX+ | 4<br>MOV<br>3 IMD | | 4<br>MOV<br>2 IX+D | 1<br>STOP<br>1 INH | * | | 3<br>LDX<br>2 DIR | | | 5<br>LDX<br>4 SP2 | | 4<br>LDX<br>3 SP1 | 2<br>LDX<br>1 IX | | 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 | 2<br>CLR<br>1 IX | 1<br>WAIT<br>1 INH | 1<br>TXA<br>1 INH | 2<br>AIX<br>2 IMM | 3<br>STX<br>2 DIR | 4<br>STX<br>3 EXT | 4<br>STX<br>3 IX2 | 5<br>STX<br>4 SP2 | 3<br>STX<br>2 IX1 | 4<br>STX<br>3 SP1 | STX<br>1 IX | INH Inherent REL Relative IMM Immediate IX Indexed, No Offset DIR Direct IX1 Indexed, 8-Bit Offset EXT Extended IX2 Indexed, 16-Bit Offset IX+D Indexed-Direct IMD Immediate-Direct IX+D Indexed-Direct DIX+ Direct-Indexed \*Pre-byte for stack pointer indexed instructions Indexed, 1-Byte Offset with Low Byte of Opcode in Hexadecimal Post Increment | | MSB | 0 | High Byte of Opcode in Hexadecimal | |---|-----|----------------------|----------------------------------------------------------------| | ı | 0 | 5<br>BRSET0<br>3 DIR | Cycles<br>Opcode Mnemonic<br>Number of Bytes / Addressing Mode | 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 ### External Interrupt (IRQ) # 8.4 Interrupts The following IRQ source can generate interrupt requests: Interrupt flag (IRQF) — The IRQF bit is set when the IRQ pin is asserted based on the IRQ mode. The IRQ interrupt mask bit, IMASK, is used to enable or disable IRQ interrupt requests. # 8.5 Low-Power Modes The WAIT and STOP instructions put the MCU in low power-consumption standby modes. # 8.5.1 Wait Mode The IRQ module remains active in wait mode. Clearing IMASK in INTSCR enables IRQ interrupt requests to bring the MCU out of wait mode. # 8.5.2 Stop Mode The IRQ module remains active in stop mode. Clearing IMASK in INTSCR enables IRQ interrupt requests to bring the MCU out of stop mode. # 8.6 IRQ Module During Break Interrupts The system integration module (SIM) controls whether status bits in other modules can be cleared during the break state. The BCFE bit in the break flag control register (BFCR) enables software to clear status bits during the break state. See Chapter 13 System Integration Module (SIM). 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 BCFE. With BCFE cleared (its default state), software can read and write 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 cleared. After the break, doing the second step clears the status bit. # 8.7 I/O Signals The IRQ module shares its pin with the keyboard interrupt, input/output ports, and timer interface modules. # NOTE When the $\overline{IRQ}$ function is enabled in the CONFIG2 register, the BIH and BIL instructions can be used to read the logic level on the $\overline{IRQ}$ pin. If the $\overline{IRQ}$ function is disabled, these instructions will behave as if the $\overline{IRQ}$ pin is a logic 1, regardless of the actual level on the pin. Conversely, when the $\overline{IRQ}$ function is enabled, bit 2 of the port A data register will always read a 0. When using the level-sensitive interrupt trigger, avoid false interrupts by masking interrupt requests in the interrupt routine. An internal pullup resistor to $V_{DD}$ is connected to the $\overline{IRQ}$ pin; this can be disabled by setting the IRQPUD bit in the CONFIG2 register (\$001E). MC68HC908QY/QT Family Data Sheet, Rev. 6 ### **Keyboard Interrupt Module (KBI)** To determine the logic level on a keyboard interrupt pin, use the data direction register to configure the pin as an input and then 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 0 for software to read the pin. # 9.3.2 Keyboard Initialization When a keyboard interrupt pin is enabled, it takes time for the internal pullup to reach a logic 1. Therefore a false interrupt can occur as soon as the pin is enabled. To prevent a false interrupt on keyboard initialization: - 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. An interrupt signal on an edge-triggered pin can be acknowledged immediately after enabling the pin. An interrupt signal on an edge- and level-triggered interrupt pin must be acknowledged after a delay that depends on the external load. Another way to avoid a false interrupt: - Configure the keyboard pins as outputs by setting the appropriate DDRA bits in the data direction register A. - 2. Write 1s to the appropriate port A data register bits. - 3. Enable the KBI pins by setting the appropriate KBIEx bits in the keyboard interrupt enable register. # 9.4 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. # 9.5 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. # 9.6 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 1 to the BCFE bit. If a latch is cleared during the break state, it remains cleared when the MCU exits the break state. # 11.3.1.1 Internal Oscillator Trimming The 8-bit trimming register, OSCTRIM, allows a clock period adjust of $\pm 127$ and $\pm 128$ steps. Increasing OSCTRIM value increases the clock period. Trimming allows the internal clock frequency to be set to $\pm 12.8$ MHz $\pm 5\%$ . All devices are factory programmed with trim values in reserved FLASH memory locations \$FFC0 and \$FFC1. The trim value is not automatically loaded into the OSCTRIM register. User software must copy the trim value from \$FFC0 or \$FFC1 into OSCTRIM if needed. The factory trim value provides the accuracy required for communication using forced monitor mode. Some production programmers erase the factory trim values, so confirm with your programmer vendor that the trim values at \$FFC0 and \$FFC1 are preserved, or are re-trimmed. Trimming the device in the user application board will provide the most accurate trim value. # 11.3.1.2 Internal to External Clock Switching When external clock source (external OSC, RC, or XTAL) is desired, the user must perform the following steps: - 1. For external crystal circuits only, OSCOPT[1:0] = 1:1: To help precharge an external crystal oscillator, set PTA4 (OSC2) as an output and drive high for several cycles. This may help the crystal circuit start more robustly. - 2. Set CONFIG2 bits OSCOPT[1:0] according to . The oscillator module control logic will then set OSC1 as an external clock input and, if the external crystal option is selected, OSC2 will also be set as the clock output. - Create a software delay to wait the stabilization time needed for the selected clock source (crystal, resonator, RC) as recommended by the component manufacturer. A good rule of thumb for crystal oscillators is to wait 4096 cycles of the crystal frequency, i.e., for a 4-MHz crystal, wait approximately 1 msec. - 4. After the manufacturer's recommended delay has elapsed, the ECGON bit in the OSC status register (OSCSTAT) needs to be set by the user software. - 5. After ECGON set is detected, the OSC module checks for oscillator activity by waiting two external clock rising edges. - 6. The OSC module then switches to the external clock. Logic provides a glitch free transition. - 7. The OSC module first sets the ECGST bit in the OSCSTAT register and then stops the internal oscillator. # NOTE Once transition to the external clock is done, the internal oscillator will only be reactivated with reset. No post-switch clock monitor feature is implemented (clock does not switch back to internal if external clock dies). # 11.3.2 External Oscillator The external clock option is designed for use when a clock signal is available in the application to provide a clock source to the microcontroller. The OSC1 pin is enabled as an input by the oscillator module. The clock signal is used directly to create BUSCLKX4 and also divided by two to create BUSCLKX2. In this configuration, the OSC2 pin cannot output BUSCLKX4.So the OSC2EN bit in the port A pullup enable register will be clear to enable PTA4 I/O functions on the pin # 13.6.2.1 Interrupt Status Register 1 Address: \$FE04 Bit 7 5 2 Bit 0 Read: 0 IF5 IF4 IF3 0 IF1 0 0 R R R R R R Write: R R 0 0 0 0 0 Reset: 0 0 0 R = Reserved Figure 13-11. Interrupt Status Register 1 (INT1) # IF1 and IF3-IF5 — Interrupt Flags These flags indicate the presence of interrupt requests from the sources shown in Table 13-3. - 1 = Interrupt request present - 0 = No interrupt request present # Bit 0, 1, 3, and 7 — Always read 0 # 13.6.2.2 Interrupt Status Register 2 Figure 13-12. Interrupt Status Register 2 (INT2) # IF14 — Interrupt Flags This flag indicates the presence of interrupt requests from the sources shown in Table 13-3. - 1 = Interrupt request present - 0 = No interrupt request present # Bit 0-6 — Always read 0 # 13.6.2.3 Interrupt Status Register 3 Figure 13-13. Interrupt Status Register 3 (INT3) # IF15 — Interrupt Flags These flags indicate the presence of interrupt requests from the sources shown in Table 13-3. - 1 = Interrupt request present - 0 = No interrupt request present # Bit 1–7 — Always read 0 MC68HC908QY/QT Family Data Sheet, Rev. 6 **System Integration Module (SIM)** # 13.6.3 Reset All reset sources always have equal and highest priority and cannot be arbitrated. # 13.6.4 Break Interrupts The break module can stop normal program flow at a software programmable break point by asserting its break interrupt output. (See Chapter 15 Development Support.) The SIM puts the CPU into the break state by forcing it to the SWI vector location. Refer to the break interrupt subsection of each module to see how each module is affected by the break state. # 13.6.5 Status Flag Protection in Break Mode The SIM controls whether status flags contained in other modules can be cleared during break mode. The user can select whether flags are protected from being cleared by properly initializing the break clear flag enable bit (BCFE) in the break flag control register (BFCR). Protecting flags in break mode ensures that set flags will not be cleared while in break mode. This protection allows registers to be freely read and written during break mode without losing status flag information. Setting the BCFE bit enables the clearing mechanisms. Once cleared in break mode, a flag remains cleared even when break mode is exited. Status flags with a two-step clearing mechanism — for example, a read of one register followed by the read or write of another — are protected, even when the first step is accomplished prior to entering break mode. Upon leaving break mode, execution of the second step will clear the flag as normal. # 13.7 Low-Power Modes Executing the WAIT or STOP instruction puts the MCU in a low power- consumption mode for standby situations. The SIM holds the CPU in a non-clocked state. The operation of each of these modes is described below. Both STOP and WAIT clear the interrupt mask (I) in the condition code register, allowing interrupts to occur. # 13.7.1 Wait Mode In wait mode, the CPU clocks are inactive while the peripheral clocks continue to run. Figure 13-14 shows the timing for wait mode entry. NOTE: Previous data can be operand data or the WAIT opcode, depending on the last instruction. Figure 13-14. Wait Mode Entry Timing MC68HC908QY/QT Family Data Sheet, Rev. 6 **Timer Interface Module (TIM)** # 14.4.1 TIM Counter Prescaler The TIM clock source is one of the seven prescaler outputs or the TIM clock pin, TCLK. The prescaler generates seven clock rates from the internal bus clock. The prescaler select bits, PS[2:0], in the TIM status and control register (TSC) select the TIM clock source. # 14.4.2 Input Capture With the input capture function, the TIM can capture the time at which an external event occurs. When an active edge occurs on the pin of an input capture channel, the TIM latches the contents of the TIM counter into the TIM channel registers, TCHxH:TCHxL. The polarity of the active edge is programmable. Input captures can generate TIM central processor unit (CPU) interrupt requests. # 14.4.3 Output Compare With the output compare function, the TIM can generate a periodic pulse with a programmable polarity, duration, and frequency. When the counter reaches the value in the registers of an output compare channel, the TIM can set, clear, or toggle the channel pin. Output compares can generate TIM CPU interrupt requests. # 14.4.3.1 Unbuffered Output Compare Any output compare channel can generate unbuffered output compare pulses as described in 14.4.3 Output Compare. The pulses are unbuffered because changing the output compare value requires writing the new value over the old value currently in the TIM channel registers. An unsynchronized write to the TIM channel registers to change an output compare value could cause incorrect operation for up to two counter overflow periods. For example, writing a new value before the counter reaches the old value but after the counter reaches the new value prevents any compare during that counter overflow period. Also, using a TIM overflow interrupt routine to write a new, smaller output compare 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 output compare value on channel x: - When changing to a smaller value, enable channel x output compare interrupts and write the new value in the output compare interrupt routine. The output compare interrupt occurs at the end of the current output compare pulse. The interrupt routine has until the end of the counter overflow period to write the new value. - When changing to a larger output compare value, enable 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 counter overflow period. Writing a larger value in an output compare interrupt routine (at the end of the current pulse) could cause two output compares to occur in the same counter overflow period. # 14.4.3.2 Buffered Output Compare Channels 0 and 1 can be linked to form a buffered output compare channel whose output appears on the TCH0 pin. The TIM channel registers of the linked pair alternately control the output. Setting the MS0B bit in TIM channel 0 status and control register (TSC0) links channel 0 and channel 1. The output compare value in the TIM channel 0 registers initially controls the output on the TCH0 pin. Writing to the TIM channel 1 registers enables the TIM channel 1 registers to synchronously control the output after the TIM overflows. At each subsequent overflow, the TIM channel registers (0 or 1) that MC68HC908QY/QT Family Data Sheet, Rev. 6 # **Development Support** Figure 15-10. Monitor Mode Circuit (External Clock, with High Voltage) Figure 15-11. Monitor Mode Circuit (External Clock, No High Voltage) MC68HC908QY/QT Family Data Sheet, Rev. 6 Table 15-7. READSP (Read Stack Pointer) Command | Description | Reads stack pointer | | | | | | | | |------------------|------------------------------------------------------------------------------|--|--|--|--|--|--|--| | Operand | None | | | | | | | | | Data Returned | Returns incremented stack pointer value (SP + 1) in high-byte:low-byte order | | | | | | | | | Opcode | \$0C | | | | | | | | | Command Sequence | | | | | | | | | | , | FROM HOST READSP READSP READSP RETURN | | | | | | | | Table 15-8. RUN (Run User Program) Command | Description | executes PULH and RTI instructions | | | | | | | |------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--| | Operand | None | | | | | | | | Data Returned | None | | | | | | | | Opcode | \$28 | | | | | | | | Command Sequence | | | | | | | | | | FROM HOST V RUN RUN ECHO ECHO PROPERTIES PR | | | | | | | 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 15-17. Stack Pointer at Monitor Mode Entry MC68HC908QY/QT Family Data Sheet, Rev. 6 # 16.5 5-V DC Electrical Characteristics | Characteristic <sup>(1)</sup> | Symbol | Min | Typ <sup>(2)</sup> | Max | Unit | |----------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------|----------------------------------------------------------------------|--------------------|-----------------------|------| | Output high voltage I <sub>Load</sub> = -2.0 mA, all I/O pins I <sub>Load</sub> = -10.0 mA, all I/O pins I <sub>Load</sub> = -15.0 mA, PTA0, PTA1, PTA3-PTA5 only | V <sub>ОН</sub> | V <sub>DD</sub> -0.4<br>V <sub>DD</sub> -1.5<br>V <sub>DD</sub> -0.8 | _<br>_<br>_ | _<br>_<br>_ | V | | Maximum combined I <sub>OH</sub> (all I/O pins) | I <sub>OHT</sub> | _ | _ | 50 | mA | | Output low voltage I <sub>Load</sub> = 1.6 mA, all I/O pins I <sub>Load</sub> = 10.0 mA, all I/O pins I <sub>Load</sub> = 15.0 mA, PTA0, PTA1, PTA3-PTA5 only | V <sub>OL</sub> | _<br>_<br>_ | _<br>_<br>_ | 0.4<br>1.5<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 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 | _ | 9.1 | 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> | 3.90 | 4.20 | 4.50 | V | | Low-voltage inhibit reset, trip rising voltage | V <sub>TRIPR</sub> | 4.00 | 4.30 | 4.60 | V | | Low-voltage inhibit reset/recover hysteresis | V <sub>HYS</sub> | _ | 100 | _ | mV | <sup>1.</sup> $V_{DD}$ = 4.5 to 5.5 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. <sup>3.</sup> Maximum is highest voltage that POR is guaranteed. <sup>4.</sup> 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}$ is measured at $V_{DD}$ = 5.0 V. # **Electrical Specifications** # **16.10 Typical 3.0-V Output Drive Characteristics** Figure 16-5. Typical 3-Volt Output High Voltage versus Output High Current (25•C) Figure 16-6. Typical 3-Volt Output Low Voltage versus Output Low Current (25•C) 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 DUTLINES DICTIONARY DO NOT SCALE THIS DRAWING | DOCUMENT | N□: | 98ASH70247A | |----------|-----|-------------| | PAGE: | | 948F | В REV: | TITLE: | CASE NUMBER: 948F-01 | | | | | | |---------------------------|----------------------------------|--|--|--|--|--| | 16 LD TSSOP, PITCH 0.65MM | STANDARD: JEDEC | | | | | | | | PACKAGE CODE: 6117 SHEET: 1 OF 4 | | | | | |