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 | CANbus, SCI, SPI | | Peripherals | LVD, POR, PWM | | Number of I/O | 53 | | Program Memory Size | 60KB (60K x 8) | | Program Memory Type | FLASH | | EEPROM Size | - | | RAM Size | 2K x 8 | | Voltage - Supply (Vcc/Vdd) | 3V ~ 5.5V | | Data Converters | A/D 24x10b | | Oscillator Type | Internal | | Operating Temperature | -40°C ~ 105°C (TA) | | Mounting Type | Surface Mount | | Package / Case | 64-QFP | | Supplier Device Package | 64-QFP (14x14) | | Purchase URL | https://www.e-xfl.com/product-detail/nxp-semiconductors/mc68hc908gz60vfu | Email: info@E-XFL.COM Address: Room A, 16/F, Full Win Commercial Centre, 573 Nathan Road, Mongkok, Hong Kong **General Description** # Memory | Addr. | Register Name | | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | |--------|-------------------------------------------------|-----------------|---------|---------------------|---------|---------|---------|----------|---------|---------| | | Data Direction Register E | Read: | 0 | 0 | DDRE5 | DDRE4 | DDRE3 | DDRE2 | DDRE1 | DDRE0 | | \$000C | (DDRE) | Write: | | | DUNES | DDNE4 | DDNES | DDNEZ | DUNEI | DUNEO | | | See page 184. | | 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 175. | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Port C Input Pullup Enable | Read: | 0 | PTOPUE | DTODUES | DTODUE. | PTOPUE | DTOBLIES | PTOPUE | DTODUE | | \$000E | Register (PTCPUE) | Write: | | PTCPUE6 | PTCPUE5 | PTCPUE4 | PTCPUE3 | PTCPUE2 | PTCPUE1 | PTCPUE0 | | | See page 180. | 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 182. | Reset: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | \$0010 | SPI Control Register<br>(SPCR) | Read:<br>Write: | SPRIE | R | SPMSTR | CPOL | СРНА | SPWOM | SPE | SPTIE | | | See page 255. | Reset: | 0 | 0 | 1 | 0 | 1 | 0 | 0 | 0 | | | SPI Status and Control | Read: | SPRF | ERRIE | OVRF | MODF | SPTE | MODFEN | SPR1 | SPR0 | | | Register (SPSCR) | Write: | | LITTLE | | | | MODEN | SPRI | SPRU | | | Reset: | 0 | 0 | 0 | 0 | 1 | 0 | 0 | 0 | | | | \$0012 SPI Data Register (SPDR) | Read: | R7 | R6 | R5 | R4 | R3 | R2 | R1 | R0 | | \$0012 | | Write: | T7 | T6 | T5 | T4 | T3 | T2 | T1 | T0 | | | See page 258. | Reset: | | Unaffected by reset | | | | | | | | \$0013 | ESCI Control Register 1<br>(SCC1) | Read:<br>Write: | LOOPS | ENSCI | TXINV | М | WAKE | ILTY | PEN | PTY | | | See page 204. | Reset: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | \$0014 | ESCI Control Register 2<br>(SCC2) | Read:<br>Write: | SCTIE | TCIE | SCRIE | ILIE | TE | RE | RWU | SBK | | | See page 206. | Reset: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | \$0015 | ESCI Control Register 3<br>(SCC3) | Read:<br>Write: | R8 | T8 | R | R | ORIE | NEIE | FEIE | PEIE | | | See page 208. | Reset: | U | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | ESCI Status Register 1 | Read: | SCTE | TC | SCRF | IDLE | OR | NF | FE | PE | | \$0016 | (SCS1) | Write: | | | | | | | | | | | See page 209. | Reset: | 1 | 1 | 0 | 0 | 0 | 0 | 0 | 0 | | | ESCI Status Register 2 | Read: | 0 | 0 | 0 | 0 | 0 | 0 | BKF | RPF | | \$0017 | (SCS2) | Write: | | | | | | | | | | | See page 211. | Reset: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | = Unimplemented R = Reserved U = Unaffected | | | | | | ed | | | | Figure 2-2. Control, Status, and Data Registers (Sheet 2 of 9) MC68HC908GZ60 • MC68HC908GZ48 • MC68HC908GZ32 Data Sheet, Rev. 6 **Analog-to-Digital Converter (ADC)** # 3.8.2 ADC Data Register High and Data Register Low #### 3.8.2.1 Left Justified Mode In left justified mode, the ADRH register holds the eight MSBs of the 10-bit result. The ADRL register holds the two LSBs of the 10-bit result. All other bits read as 0. ADRH and ADRL are updated each time an ADC single channel conversion completes. Reading ADRH latches the contents of ADRL until ADRL is read. All subsequent results will be lost until the ADRH and ADRL reads are completed. Figure 3-5. ADC Data Register High (ADRH) and Low (ADRL) ## 3.8.2.2 Right Justified Mode In right justified mode, the ADRH register holds the two MSBs of the 10-bit result. All other bits read as 0. The ADRL register holds the eight LSBs of the 10-bit result. ADRH and ADRL are updated each time an ADC single channel conversion completes. Reading ADRH latches the contents of ADRL until ADRL is read. All subsequent results will be lost until the ADRH and ADRL reads are completed. Figure 3-6. ADC Data Register High (ADRH) and Low (ADRL) MC68HC908GZ60 • MC68HC908GZ48 • MC68HC908GZ32 Data Sheet, Rev. 6 #### **Clock Generator Module (CGM)** #### NOTE Do not inadvertently clear the PLLF bit. Any read or read-modify-write operation on the PLL control register clears the PLLF bit. #### PLLON — PLL On Bit This read/write bit activates the PLL and enables the VCO clock, CGMVCLK. PLLON cannot be cleared if the VCO clock is driving the base clock, CGMOUT (BCS = 1). (See 4.3.8 Base Clock Selector Circuit.) Reset sets this bit so that the loop can stabilize as the MCU is powering up. 1 = PLL on 0 = PLL off #### BCS — Base Clock Select Bit This read/write bit selects either the crystal oscillator output, CGMXCLK, or the VCO clock, CGMVCLK, as the source of the CGM output, CGMOUT. CGMOUT frequency is one-half the frequency of the selected clock. BCS cannot be set while the PLLON bit is clear. After toggling BCS, it may take up to three CGMXCLK and three CGMVCLK cycles to complete the transition from one source clock to the other. During the transition, CGMOUT is held in stasis. (See 4.3.8 Base Clock Selector Circuit.) Reset clears the BCS bit. 1 = CGMVCLK divided by two drives CGMOUT 0 = CGMXCLK divided by two drives CGMOUT #### NOTE PLLON and BCS have built-in protection that prevents the base clock selector circuit from selecting the VCO clock as the source of the base clock if the PLL is off. Therefore, PLLON cannot be cleared when BCS is set, and BCS cannot be set when PLLON is clear. If the PLL is off (PLLON = 0), selecting CGMVCLK requires two writes to the PLL control register. (See 4.3.8 Base Clock Selector Circuit.). ### **VPR1** and **VPR0** — **VCO** Power-of-Two Range Select Bits These read/write bits control the VCO's hardware power-of-two range multiplier E that, in conjunction with L controls the hardware center-of-range frequency, f<sub>VRS</sub>. VPR1:VPR0 cannot be written when the PLLON bit is set. Reset clears these bits. (See 4.3.3 PLL Circuits, 4.3.6 Programming the PLL, and 4.5.5 PLL VCO Range Select Register.) | VPR1 and VPR0 | E | VCO Power-of-Two<br>Range Multiplier | |---------------|------------------|--------------------------------------| | 00 | 0 | 1 | | 01 | 1 | 2 | | 10 | 2 <sup>(1)</sup> | 4 | Table 4-4. VPR1 and VPR0 Programming ### NOTE Verify that the value of the VPR1 and VPR0 bits in the PCTL register are appropriate for the given reference and VCO clock frequencies before enabling the PLL. See 4.3.6 Programming the PLL for detailed instructions on selecting the proper value for these control bits. MC68HC908GZ60 • MC68HC908GZ48 • MC68HC908GZ32 Data Sheet, Rev. 6 <sup>1.</sup> Do not program E to a value of 3. 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: - 1. Configure the keyboard pins as outputs by setting the appropriate DDRA bits in data direction register A. - 2. Write 1s (or 0s) to the appropriate port A data register bits. - 3. Enable the KBI pins and polarity by setting the appropriate KBIEx bits in the keyboard interrupt enable register and the KBIPx bits in the keyboard interrupt polarity register. # 9.5 Low-Power Modes The WAIT and STOP instructions put the microcontroller unit (MCU) in low power-consumption standby modes. ### 9.5.1 Wait Mode The keyboard module remains active in wait mode. Clearing the IMASKK bit in the keyboard status and control register enables keyboard interrupt requests to bring the MCU out of wait mode. # 9.5.2 Stop Mode The keyboard module remains active in stop mode. Clearing the IMASKK bit in the keyboard status and control register enables keyboard interrupt requests to bring the MCU out of stop mode. # 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. To protect the latch during the break state, write a 0 to the BCFE bit. With BCFE at 0 (its default state), writing to the keyboard acknowledge bit (ACKK) in the keyboard status and control register during the break state has no effect. See 9.7.1 Keyboard Status and Control Register. # 9.7 I/O Registers These registers control and monitor operation of the keyboard module: - Keyboard status and control register (INTKBSCR) - Keyboard interrupt enable register (INTKBIER) - Keyboard interrupt polarity register (INTKBIPR) ### **MSCAN08 Controller (MSCAN08)** # 12.12.1 Message Buffer Outline Figure 12-12 shows the common 13-byte data structure of receive and transmit buffers for extended identifiers. The mapping of standard identifiers into the IDR registers is shown in Figure 12-13. All bits of the 13-byte data structure are undefined out of reset. **NOTE**The foreground receive buffer can be read anytime but cannot be written. The transmit buffers can be read or written anytime. | | THO trai | ionnic be | more ear | 7 50 7044 | or witter | r arry arrio. | | | | | |--------|----------|-----------------|----------|------------|-----------|---------------|----------|------|------|-------| | Addr. | Register | _ | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | | \$05b0 | IDR0 | Read:<br>Write: | ID28 | ID27 | ID26 | ID25 | ID24 | ID23 | ID22 | ID21 | | \$05b1 | IDR1 | Read:<br>Write: | ID20 | ID19 | ID18 | SRR (=1) | IDE (=1) | ID17 | ID16 | ID15 | | \$05b2 | IDR2 | Read:<br>Write: | ID14 | ID13 | ID12 | ID11 | ID10 | ID9 | ID8 | ID7 | | \$05b3 | IDR3 | Read:<br>Write: | ID6 | ID5 | ID4 | ID3 | ID2 | ID1 | ID0 | RTR | | \$05b4 | DSR0 | Read: Write: | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | | \$05b5 | DSR1 | Read:<br>Write: | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | | \$05b6 | DSR2 | Read:<br>Write: | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | | \$05b7 | DSR3 | Read:<br>Write: | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | | \$05b8 | DSR4 | Read:<br>Write: | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | | \$05b9 | DSR5 | Read:<br>Write: | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | | \$05bA | DSR6 | Read:<br>Write: | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | | \$05bB | DSR7 | Read:<br>Write: | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 | | \$05bC | DLR | Read:<br>Write: | | | | | DLC3 | DLC2 | DLC1 | DLC0 | | | | | | = Unimplen | nented | | | | | | Figure 12-12. Receive/Transmit Message Buffer Extended Identifier (IDRn) **MSCAN08 Controller (MSCAN08)** # 12.12.3 Data Length Register (DLR) This register keeps the data length field of the CAN frame. ## DLC3-DLC0 — Data Length Code Bits The data length code contains the number of bytes (data byte count) of the respective message. At transmission of a remote frame, the data length code is transmitted as programmed while the number of transmitted bytes is always 0. The data byte count ranges from 0 to 8 for a data frame. Table 12-5 shows the effect of setting the DLC bits. | | Data Length Code | | | | | | | | | | |------|------------------|------|------|-------|--|--|--|--|--|--| | DLC3 | DLC2 | DLC1 | DLC0 | Count | | | | | | | | 0 | 0 | 0 | 0 | 0 | | | | | | | | 0 | 0 | 0 | 1 | 1 | | | | | | | | 0 | 0 | 1 | 0 | 2 | | | | | | | | 0 | 0 | 1 | 1 | 3 | | | | | | | | 0 | 1 | 0 | 0 | 4 | | | | | | | | 0 | 1 | 0 | 1 | 5 | | | | | | | | 0 | 1 | 1 | 0 | 6 | | | | | | | | 0 | 1 | 1 | 1 | 7 | | | | | | | | 1 | 0 | 0 | 0 | 8 | | | | | | | **Table 12-5. Data Length Codes** # 12.12.4 Data Segment Registers (DSRn) The eight data segment registers contain the data to be transmitted or received. The number of bytes to be transmitted or being received is determined by the data length code in the corresponding DLR. # 12.12.5 Transmit Buffer Priority Registers Figure 12-14. Transmit Buffer Priority Register (TBPR) ### PRIO7-PRIO0 — Local Priority This field defines the local priority of the associated message buffer. The local priority is used for the internal prioritization process of the MSCAN08 and is defined to be highest for the smallest binary number. The MSCAN08 implements the following internal prioritization mechanism: - All transmission buffers with a cleared TXE flag participate in the prioritization right before the SOF is sent. - The transmission buffer with the lowest local priority field wins the prioritization. - In case more than one buffer has the same lowest priority, the message buffer with the lower index number wins. MC68HC908GZ60 • MC68HC908GZ48 • MC68HC908GZ32 Data Sheet, Rev. 6 #### **MSCAN08 Controller (MSCAN08)** # 12.13.8 MSCAN08 Transmitter Control Register Figure 12-23. Transmitter Control Register (CTCR) # ABTRQ2-ABTRQ0 — Abort Request The CPU sets an ABTRQx bit to request that an already scheduled message buffer (TXE = 0) be aborted. The MSCAN08 will grant the request if the message has not already started transmission, or if the transmission is not successful (lost arbitration or error). When a message is aborted the associated TXE and the abort acknowledge flag (ABTAK) (see 12.13.7 MSCAN08 Transmitter Flag Register) will be set and an TXE interrupt is generated if enabled. The CPU cannot reset ABTRQx. ABTRQx is cleared implicitly whenever the associated TXE flag is set. - 1 = Abort request pending - 0 = No abort request #### NOTE The software must not clear one or more of the TXE flags in CTFLG and simultaneously set the respective ABTRQ bit(s). # TXEIE2-TXEIE0 — Transmitter Empty Interrupt Enable - 1 = A transmitter empty (transmit buffer available for transmission) event results in a transmitter empty interrupt. - 0 = No interrupt is generated from this event. #### NOTE The CTCR register is held in the reset state when the SFTRES bit in CMCR0 is set. # 12.13.9 MSCAN08 Identifier Acceptance Control Register Figure 12-24. Identifier Acceptance Control Register (CIDAC) MC68HC908GZ60 • MC68HC908GZ48 • MC68HC908GZ32 Data Sheet, Rev. 6 # Input/Output (I/O) Ports Figure 13-25. Port G I/O Circuit **Table 13-8. Port G Pin Functions** | DDRG | PTG | I/O Pin | Accesses to DDRG | Access | ses to PTG | |------|------------------|----------------------------|------------------|-----------|--------------------------| | Bit | Bit | Mode | Read/Write | Read | Write | | 0 | X <sup>(1)</sup> | Input, Hi-Z <sup>(2)</sup> | DDRG7-DDRG0 | Pin | PTG7-PTG0 <sup>(3)</sup> | | 1 | Х | Output | DDRG7-DDRG0 | PTG7-PTG0 | PTG7-PTG0 | - 1. X = Don't care - 2. Hi-Z = High impedance - 3. Writing affects data register, but does not affect input. Figure 14-6. ESCI Receiver Block Diagram # 14.4.3.1 Character Length The receiver can accommodate either 8-bit or 9-bit data. The state of the M bit in ESCI control register 1 (SCC1) determines character length. When receiving 9-bit data, bit R8 in ESCI control register 3 (SCC3) is the ninth bit (bit 8). When receiving 8-bit data, bit R8 is a copy of the eighth bit (bit 7). MC68HC908GZ60 • MC68HC908GZ48 • MC68HC908GZ32 Data Sheet, Rev. 6 #### **Enhanced Serial Communications Interface (ESCI) Module** does not set the receiver idle bit, IDLE, or the ESCI receiver full bit, SCRF. The idle line type bit, ILTY, determines whether the receiver begins counting 1s as idle character bits after the start bit or after the stop bit. #### NOTE With the WAKE bit clear, setting the RWU bit after the RxD pin has been idle will cause the receiver to wake up. #### 14.4.3.7 Receiver Interrupts These sources can generate CPU interrupt requests from the ESCI receiver: - ESCI receiver full (SCRF) The SCRF bit in SCS1 indicates that the receive shift register has transferred a character to the SCDR. SCRF can generate a receiver CPU interrupt request. Setting the ESCI receive interrupt enable bit, SCRIE, in SCC2 enables the SCRF bit to generate receiver CPU interrupts. - Idle input (IDLE) The IDLE bit in SCS1 indicates that 10 or 11 consecutive 1s shifted in from the RxD pin. The idle line interrupt enable bit, ILIE, in SCC2 enables the IDLE bit to generate CPU interrupt requests. # 14.4.3.8 Error Interrupts These receiver error flags in SCS1 can generate CPU interrupt requests: - Receiver overrun (OR) The OR bit indicates that the receive shift register shifted in a new character before the previous character was read from the SCDR. The previous character remains in the SCDR, and the new character is lost. The overrun interrupt enable bit, ORIE, in SCC3 enables OR to generate ESCI error CPU interrupt requests. - Noise flag (NF) The NF bit is set when the ESCI detects noise on incoming data or break characters, including start, data, and stop bits. The noise error interrupt enable bit, NEIE, in SCC3 enables NF to generate ESCI error CPU interrupt requests. - Framing error (FE) The FE bit in SCS1 is set when a 0 occurs where the receiver expects a stop bit. The framing error interrupt enable bit, FEIE, in SCC3 enables FE to generate ESCI error CPU interrupt requests. - Parity error (PE) The PE bit in SCS1 is set when the ESCI detects a parity error in incoming data. The parity error interrupt enable bit, PEIE, in SCC3 enables PE to generate ESCI error CPU interrupt requests. ### 14.5 Low-Power Modes The WAIT and STOP instructions put the MCU in low power-consumption standby modes. ### **14.5.1 Wait Mode** The ESCI module remains active in wait mode. Any enabled CPU interrupt request from the ESCI module can bring the MCU out of wait mode. If ESCI module functions are not required during wait mode, reduce power consumption by disabling the module before executing the WAIT instruction. MC68HC908GZ60 • MC68HC908GZ48 • MC68HC908GZ32 Data Sheet, Rev. 6 ### LINR — LIN Receiver Bits 1 1 1 This read/write bit selects the enhanced ESCI features for the local interconnect network (LIN) protocol as shown in Table 14-6. Reset clears LINR. LINT LINR М **Functionality** Χ Normal ESCI functionality 0 0 1 0 11-bit break detect enabled for LIN receiver 0 12-bit break detect enabled for LIN receiver. 1 1 1 0 0 13-bit generation enabled for LIN transmitter 1 0 14-bit generation enabled for LIN transmitter 1 11-bit break detect/13-bit generation enabled for LIN 1 1 0 Table 14-6. ESCI LIN Control Bits In LIN (version 1.2) systems, the master node transmits a break character which will appear as 11.05-14.95 dominant bits to the slave node. A data character of 0x00 sent from the master might appear as 7.65-10.35 dominant bit times. This is due to the oscillator tolerance requirement that the slave node must be within $\pm 15\%$ of the master node's oscillator. Since a slave node cannot know if it is running faster or slower than the master node (prior to synchronization), the LINR bit allows the slave node to differentiate between a 0x00 character of 10.35 bits and a break character of 11.05 bits. The break symbol length must be verified in software in any case, but the LINR bit serves as a filter, preventing false detections of break characters that are really 0x00 data characters. 12-bit break detect/14-bit generation enabled for LIN ## SCP1 and SCP0 — ESCI Baud Rate Register Prescaler Bits These read/write bits select the baud rate register prescaler divisor as shown in Table 14-7. Reset clears SCP1 and SCP0. | | _ | |----------|-----------------------------------------------| | SCP[1:0] | Baud Rate Register<br>Prescaler Divisor (BPD) | | 0 0 | 1 | | 0 1 | 3 | | 1 0 | 4 | | 1 1 | 13 | Table 14-7. ESCI Baud Rate Prescaling ### SCR2-SCR0 — ESCI Baud Rate Select Bits These read/write bits select the ESCI baud rate divisor as shown in Table 14-8. Reset clears SCR2–SCR0. **Table 14-8. ESCI Baud Rate Selection** | SCR[2:1:0] | Baud Rate Divisor (BD) | |------------|------------------------| | 0 0 0 | 1 | | 0 0 1 | 2 | | 0 1 0 | 4 | | 0 1 1 | 8 | | 1 0 0 | 16 | | 1 0 1 | 32 | | 1 1 0 | 64 | | 1 1 1 | 128 | MC68HC908GZ60 • MC68HC908GZ48 • MC68HC908GZ32 Data Sheet, Rev. 6 | Addr. | Register Name | | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | |--------|---------------------------------------------------------------|-----------------|----------------|-----------------|------|------|------------|--------|-----------------------------|-------| | \$FE00 | Break Status Register<br>(BSR) | Read:<br>Write: | R | R | R | R | R | R | SBSW<br>Note <sup>(1)</sup> | R | | | See page 237. | | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | 1. Writing a ( | Clears SBS\ | N. | | | | | | | | SIM Reset Status Register | Read: | POR | PIN | COP | ILOP | ILAD | MODRST | LVI | 0 | | \$FE01 | SFE01 (SRSR) | | | | | | | | | | | | See page 237. | POR: | 1 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | \$FE03 | Break Flag Control Register<br>(BFCR) | Read:<br>Write: | BCFE | R | R | R | R | R | R | R | | | See page 238. | | 0 | | | | | | | | | | Interrupt Status Register 1<br>\$FE04 (INT1)<br>See page 231. | Read: | IF6 | IF5 | IF4 | IF3 | IF2 | IF1 | 0 | 0 | | \$FE04 | | Write: | R | R | R | R | R | R | R | R | | | | Reset: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Interrupt Status Register 2 | Read: | IF14 | IF13 | IF12 | IF11 | IF10 | IF9 | IF8 | IF7 | | \$FE05 | (INT2) | Write: | R | R | R | R | R | R | R | R | | | See page 233. | Reset: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Interrupt Status Register 3 | Read: | IF22 | IF32 | IF20 | IF19 | IF18 | IF17 | IF16 | IF15 | | \$FE06 | (INT3) | Write: | R | R | R | R | R | R | R | R | | | See page 233. | Reset: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | Interrupt Status Register 4 | Read: | 0 | 0 | 0 | 0 | 0 | 0 | IF24 | IF23 | | \$FE07 | (INT4) | Write: | R | R | R | R | R | R | R | R | | | See page 233. | Reset: | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | | | | = Unimplemented | | R | = Reserved | | | | Figure 15-2. SIM I/O Register Summary **System Integration Module (SIM)** # 15.2 SIM Bus Clock Control and Generation The bus clock generator provides system clock signals for the CPU and peripherals on the MCU. The system clocks are generated from an incoming clock, CGMOUT, as shown in Figure 15-3. This clock originates from either an external oscillator or from the on-chip PLL. Figure 15-3. System Clock Signals ### 15.2.1 Bus Timing In user mode, the internal bus frequency is either the crystal oscillator output (CGMXCLK) divided by four or the PLL output (CGMVCLK) divided by four. ## 15.2.2 Clock Startup from POR or LVI Reset When the power-on reset module or the low-voltage inhibit module generates a reset, the clocks to the CPU and peripherals are inactive and held in an inactive phase until after the 4096 CGMXCLK cycle POR timeout has completed. The RST pin is driven low by the SIM during this entire period. The bus clocks start upon completion of the timeout. # 15.2.3 Clocks in Stop Mode and Wait Mode Upon exit from stop mode by an interrupt or reset, the SIM allows CGMXCLK to clock the SIM counter. The CPU and peripheral clocks do not become active until after the stop delay timeout. This timeout is selectable as 4096 or 32 CGMXCLK cycles. See 15.6.2 Stop Mode. In wait mode, the CPU clocks are inactive. The SIM also produces two sets of clocks for other modules. Refer to the wait mode subsection of each module to see if the module is active or inactive in wait mode. Some modules can be programmed to be active in wait mode. MC68HC908GZ60 • MC68HC908GZ48 • MC68HC908GZ32 Data Sheet, Rev. 6 Figure 15-9. Interrupt Recovery Timing ### 15.5.1.1 Hardware Interrupts A hardware interrupt does not stop the current instruction. Processing of a hardware interrupt begins after completion of the current instruction. When the current instruction is complete, the SIM checks all pending hardware interrupts. If interrupts are not masked (I bit clear in the condition code register) and if the corresponding interrupt enable bit is set, the SIM proceeds with interrupt processing; otherwise, the next instruction is fetched and executed. If more than one interrupt is pending at the end of an instruction execution, the highest priority interrupt is serviced first. Figure 15-11 demonstrates what happens when two interrupts are pending. If an interrupt is pending upon exit from the original interrupt service routine, the pending interrupt is serviced before the LDA instruction is executed. The LDA opcode is prefetched by both the INT1 and INT2 RTI instructions. However, in the case of the INT1 RTI prefetch, this is a redundant operation. ## NOTE To maintain compatibility with the M6805 Family, the H register is not pushed on the stack during interrupt entry. If the interrupt service routine modifies the H register or uses the indexed addressing mode, software should save the H register and then restore it prior to exiting the routine. #### Serial Peripheral Interface (SPI) Module - 1. Pin contains integrated pullup device. - 2. Ports are software configurable with pullup device if input port or pullup/pulldown device for keyboard input. - 3. Higher current drive port pins Figure 16-1. Block Diagram Highlighting SPI Block and Pins #### **Timer Interface Module (TIM2)** - 1. Pin contains integrated pullup device. - 2. Ports are software configurable with pullup device if input port or pullup/pulldown device for keyboard input. - 3. Higher current drive port pins Figure 19-1. Block Diagram Highlighting TIM2 Block and Pins #### **Timer Interface Module (TIM2)** function, and TIM2 channel 3 status and control register (T2SC3) is unused. While the MS2B bit is set, the channel 3 pin, T2CH3, is available as a general-purpose I/O pin. Channels 4 and 5 can be linked to form a buffered PWM channel whose output appears on the T2CH4 pin. The TIM2 channel registers of the linked pair alternately control the pulse width of the output. Setting the MS4B bit in TIM2 channel 4 status and control register (T2SC4) links channel 4 and channel 5. The TIM2 channel 4 registers initially control the pulse width on the T2CH4 pin. Writing to the TIM2 channel 5 registers enables the TIM2 channel 5 registers to synchronously control the pulse width at the beginning of the next PWM period. At each subsequent overflow, the TIM2 channel registers (4 or 5) that control the pulse width are the ones written to last. T2SC4 controls and monitors the buffered PWM function, and TIM2 channel 5 status and control register (T2SC5) is unused. While the MS4B bit is set, the channel 5 pin, T2CH5, is available as a general-purpose I/O pin. #### NOTE In buffered PWM signal generation, do not write 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. #### 19.3.4.3 PWM Initialization To ensure correct operation when generating unbuffered or buffered PWM signals, use the following initialization procedure: - 1. In the TIM2 status and control register (T2SC): - a. Stop the TIM2 counter by setting the TIM2 stop bit, TSTOP. - Reset the TIM2 counter and prescaler by setting the TIM2 reset bit, TRST. - 2. In the TIM2 counter modulo registers (T2MODH:T2MODL), write the value for the required PWM period. - 3. In the TIM2 channel x registers (T2CHxH:T2CHxL), write the value for the required pulse width. - 4. In TIM2 channel x status and control register (T2SCx): - a. Write 0:1 (for unbuffered output compare or PWM signals) or 1:0 (for buffered output compare or PWM signals) to the mode select bits, MSxB:MSxA. (See Table 19-2.) - b. Write 1 to the toggle-on-overflow bit, TOVx. - c. Write 1:0 (polarity 1 to clear output on compare) or 1:1 (polarity 0 to set output on compare) to the edge/level select bits, ELSxB:ELSxA. The output action on compare must force the output to the complement of the pulse width level. (See Table 19-2.) #### NOTE In PWM signal generation, do not program the PWM channel to toggle on output compare. Toggling on output compare prevents reliable 0% duty cycle generation and removes the ability of the channel to self-correct in the event of software error or noise. Toggling on output compare can also cause incorrect PWM signal generation when changing the PWM pulse width to a new, much larger value. 5. In the TIM2 status control register (T2SC), clear the TIM2 stop bit, TSTOP. Setting MS0B links channels 0 and 1 and configures them for buffered PWM operation. The TIM2 channel 0 registers (T2CH0H:T2CH0L) initially control the buffered PWM output. TIM2 status control register 0 (T2SC0) controls and monitors the PWM signal from the linked channels. MS0B takes priority over MS0A. Setting MS2B links channels 2 and 3 and configures them for buffered PWM operation. The TIM2 channel 2 registers (T2CH2H:T2CH2L) initially control the buffered PWM output. TIM2 status control register 2 (T2SC2) controls and monitors the PWM signal from the linked channels. MS2B takes priority over MS2A. Setting MS4B links channels 4 and 5 and configures them for buffered PWM operation. The TIM2 channel 4 registers (T2CH4H:T2CH4L) initially control the buffered PWM output. TIM2 status control register 4 (T2SC4) controls and monitors the PWM signal from the linked channels. MS4B takes priority over MS4A. Clearing the toggle-on-overflow bit, TOVx, inhibits output toggles on TIM2 overflows. Subsequent output compares try to force the output to a state it is already in and have no effect. The result is a 0% duty cycle output. Setting the channel x maximum duty cycle bit (CHxMAX) and setting the TOVx bit generates a 100% duty cycle output. (See 19.8.4 TIM2 Channel Status and Control Registers.) # 19.4 Interrupts The following TIM2 sources can generate interrupt requests: - TIM2 overflow flag (TOF) The TOF bit is set when the TIM2 counter reaches the modulo value programmed in the TIM2 counter modulo registers. The TIM2 overflow interrupt enable bit, TOIE, enables TIM2 overflow interrupt requests. TOF and TOIE are in the TIM2 status and control register. - TIM2 channel flags (CH5F:CH0F) The CHxF bit is set when an input capture or output compare occurs on channel x. Channel x TIM2 CPU interrupt requests are controlled by the channel x interrupt enable bit, CHxIE. ## 19.5 Low-Power Modes The WAIT and STOP instructions put the MCU in low-power standby modes. ## 19.5.1 Wait Mode The TIM2 remains active after the execution of a WAIT instruction. In wait mode, the TIM2 registers are not accessible by the CPU. Any enabled CPU interrupt request from the TIM2 can bring the MCU out of wait mode. If TIM2 functions are not required during wait mode, reduce power consumption by stopping the TIM2 before executing the WAIT instruction. # **19.5.2 Stop Mode** The TIM2 is inactive after the execution of a STOP instruction. The STOP instruction does not affect register conditions or the state of the TIM2 counter. TIM2 operation resumes when the MCU exits stop mode. MC68HC908GZ60 • MC68HC908GZ48 • MC68HC908GZ32 Data Sheet, Rev. 6 # 21.13 3.3-Volt SPI Characteristics | Diagram<br>Number <sup>(1)</sup> | Characteristic <sup>(2)</sup> | Symbol | Min | Max | Unit | |----------------------------------|----------------------------------------------------------------------|------------------------------------------|--------------------------------------------------|---------------------------------------|------------------| | | Operating frequency Master Slave | f <sub>OP(M)</sub><br>f <sub>OP(S)</sub> | f <sub>OP</sub> /128<br>DC | f <sub>OP</sub> /2<br>f <sub>OP</sub> | MHz<br>MHz | | 1 | Cycle time<br>Master<br>Slave | t <sub>CYC(M)</sub> | 2<br>1 | 128<br>— | t <sub>cyc</sub> | | 2 | Enable lead time | t <sub>Lead(S)</sub> | 1 | _ | t <sub>cyc</sub> | | 3 | Enable lag time | t <sub>Lag(S)</sub> | 1 | _ | t <sub>cyc</sub> | | 4 | Clock (SPSCK) high time<br>Master<br>Slave | t <sub>SCKH(M)</sub> | t <sub>cyc</sub> –35<br>1/2 t <sub>cyc</sub> –35 | 64 t <sub>cyc</sub> | ns<br>ns | | 5 | Clock (SPSCK) low time<br>Master<br>Slave | t <sub>SCKL(M)</sub> | t <sub>cyc</sub> –35<br>1/2 t <sub>cyc</sub> –35 | 64 t <sub>cyc</sub> | ns<br>ns | | 6 | Data setup time (inputs) Master Slave | t <sub>SU(M)</sub> | 40<br>40 | | ns<br>ns | | 7 | Data hold time (inputs) Master Slave | t <sub>H(M)</sub> | 40<br>40 | _<br>_ | ns<br>ns | | 8 | Access time, slave <sup>(3)</sup> CPHA = 0 CPHA = 1 | t <sub>A(CP0)</sub> | 0<br>0 | 50<br>50 | ns<br>ns | | 9 | Disable time, slave <sup>(4)</sup> | t <sub>DIS(S)</sub> | _ | 50 | ns | | 10 | Data valid time, after enable edge<br>Master<br>Slave <sup>(5)</sup> | t <sub>V(M)</sub> t <sub>V(S)</sub> | _ | 60<br>60 | ns<br>ns | | 11 | Data hold time, outputs, after enable edge<br>Master<br>Slave | t <sub>HO(M)</sub> | 0<br>0 | _ | ns<br>ns | - Numbers refer to dimensions in Figure 21-2 and Figure 21-3. All timing is shown with respect to 20% V<sub>DD</sub> and 70% V<sub>DD</sub>, unless noted; 100 pF load on all SPI pins. Time to data active from high-impedance state - 4. Hold time to high-impedance state - 5. With 100 pF on all SPI pins