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 | S08 | | Core Size | 8-Bit | | Speed | 20MHz | | Connectivity | I <sup>2</sup> C, SCI, SPI | | Peripherals | LVD, POR, PWM, WDT | | Number of I/O | 4 | | Program Memory Size | 8KB (8K x 8) | | Program Memory Type | FLASH | | EEPROM Size | - | | RAM Size | 512 x 8 | | Voltage - Supply (Vcc/Vdd) | 1.8V ~ 3.6V | | Data Converters | A/D 4x10b | | Oscillator Type | Internal | | Operating Temperature | -40°C ~ 85°C (TA) | | Mounting Type | Surface Mount | | Package / Case | 8-SOIC (0.154", 3.90mm Width) | | Supplier Device Package | 8-SOIC | | Purchase URL | https://www.e-xfl.com/product-detail/nxp-semiconductors/mc9s08qg84cdne | ## **Chapter 4 Memory Map and Register Definition** Table 4-2. Direct-Page Register Summary (continued) | Address | Register Name | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | |------------------------------------|---------------|-------|---------|-------|--------|---------------|-------|---------|----------| | 0x00 <b>14</b> | ADCCVH | 0 | 0 | 0 | 0 | 0 | 0 | ADCV9 | ADCV8 | | 0x00 <b>15</b> | ADCCVL | ADCV7 | ADCV6 | ADCV5 | ADCV4 | ADCV3 | ADCV2 | ADCV1 | ADCV0 | | 0x00 <b>16</b> | ADCCFG | ADLPC | AD | ΝV | ADLSMP | MODE | | ADI | CLK | | 0x00 <b>17</b> | APCTL1 | ADPC7 | ADPC6 | ADPC5 | ADPC4 | ADPC3 | ADPC2 | ADPC1 | ADPC0 | | 0x00 <b>18</b> | Reserved | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x00 <b>19</b> | Reserved | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x00 <b>1A</b> | ACMPSC | ACME | ACBGS | ACF | ACIE | ACO | ACOPE | ACI | MOD | | 0x00 <b>1B</b> -<br>0x00 <b>1F</b> | Reserved | | 1 1 | | _ | | _ | _ | _ | | 0x00 <b>20</b> | SCIBDH | 0 | 0 | 0 | SBR12 | SBR11 | SBR10 | SBR9 | SBR8 | | 0x00 <b>21</b> | SCIBDL | SBR7 | SBR6 | SBR5 | SBR4 | SBR3 | SBR2 | SBR1 | SBR0 | | 0x00 <b>22</b> | SCIC1 | LOOPS | SCISWAI | RSRC | М | WAKE | ILT | PE | PT | | 0x00 <b>23</b> | SCIC2 | TIE | TCIE | RIE | ILIE | TE | RE | RWU | SBK | | 0x00 <b>24</b> | SCIS1 | TDRE | TC | RDRF | IDLE | OR | NF | FE | PF | | 0x00 <b>25</b> | SCIS2 | 0 | 0 | 0 | 0 | 0 | BRK13 | 0 | RAF | | 0x00 <b>26</b> | SCIC3 | R8 | T8 | TXDIR | TXINV | ORIE | NEIE | FEIE | PEIE | | 0x00 <b>27</b> | SCID | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | | 0x00 <b>28</b> | SPIC1 | SPIE | SPE | SPTIE | MSTR | CPOL | CPHA | SSOE | LSBFE | | 0x00 <b>29</b> | SPIC2 | 0 | 0 | 0 | MODFEN | BIDIROE | 0 | SPISWAI | SPC0 | | 0x00 <b>2A</b> | SPIBR | 0 | SPPR2 | SPPR1 | SPPR0 | 0 | SPR2 | SPR1 | SPR0 | | 0x00 <b>2B</b> | SPIS | SPRF | 0 | SPTEF | MODF | 0 | 0 | 0 | 0 | | 0x00 <b>2C</b> | Reserved | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | 0x00 <b>2D</b> | SPID | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 | | 0x00 <b>2E</b> | Reserved | 1 | 1 | _ | _ | _ | _ | _ | _ | | 0x00 <b>2F</b> | Reserved | 1 | - | 1 | _ | 1 | _ | _ | _ | | 0x00 <b>30</b> | IICA | | | | ADDR | | | | 0 | | 0x00 <b>31</b> | IICF | MU | ILT | | | IC | R | | | | 0x00 <b>32</b> | IICC | IICEN | IICIE | MST | TX | TXAK | RSTA | 0 | 0 | | 0x00 <b>33</b> | IICS | TCF | IAAS | BUSY | ARBL | 0 | SRW | IICIF | RXAK | | 0x00 <b>34</b> | IICD | | | | DA | TA | | | | | 0x00 <b>35</b> | Reserved | | _ | - | _ | - | _ | _ | _ | | 0x00 <b>36</b> | Reserved | | _ | - | _ | - | _ | _ | _ | | 0x00 <b>37</b> | Reserved | ı | 1 | 1 | _ | 1 | _ | _ | _ | | 0x00 <b>38</b> | ICSC1 | CL | KS | | RDIV | | IREFS | IRCLKEN | IREFSTEN | | 0x00 <b>39</b> | ICSC2 | BD | VIV | RANGE | HGO | LP EREFS ERCL | | ERCLKEN | EREFSTEN | | 0x00 <b>3A</b> | ICSTRM | | | | TP | FRIM | | | | | 0x00 <b>3B</b> | ICSSC | 0 | 0 | 0 | 0 | CLI | KST | OSCINIT | FTRIM | | 0x00 <b>3C</b> | MTIMSC | TOF | TOIE | TRST | TSTP | 0 | 0 | 0 | 0 | | 0x00 <b>3D</b> | MTIMCLK | 0 | 0 | CL | .KS | | P | S | | | 0x00 <b>3E</b> | MTIMCNT | | | | COL | JNT | | | | MC9S08QG8 and MC9S08QG4 Data Sheet, Rev. 5 #### **Chapter 4 Memory Map and Register Definition** must be programmed to logic 0 to enable block protection. Therefore the value 0xF8 must be programmed into NVPROT to protect addresses 0xFA00 through 0xFFFF. Figure 4-4. Block Protection Mechanism One use for block protection is to block protect an area of FLASH memory for a bootloader program. This bootloader program then can be used to erase the rest of the FLASH memory and reprogram it. Because the bootloader is protected, it remains intact even if MCU power is lost in the middle of an erase and reprogram operation. ## 4.5.7 Vector Redirection Whenever any block protection is enabled, the reset and interrupt vectors will be protected. Vector redirection allows users to modify interrupt vector information without unprotecting bootloader and reset vector space. Vector redirection is enabled by programming the FNORED bit in the NVOPT register located at address 0xFFBF to zero. For redirection to occur, at least some portion but not all of the FLASH memory must be block protected by programming the NVPROT register located at address 0xFFBD. All of the interrupt vectors (memory locations 0xFFC0–0xFFFD) are redirected, though the reset vector (0xFFFE:FFFF) is not. For example, if 512 bytes of FLASH are protected, the protected address region is from 0xFE00 through 0xFFFF. The interrupt vectors (0xFFC0–0xFFFD) are redirected to the locations 0xFDC0–0xFDFD. Now, if an SPI interrupt is taken for instance, the values in the locations 0xFDE0:FDE1 are used for the vector instead of the values in the locations 0xFFE0:FFE1. This allows the user to reprogram the unprotected portion of the FLASH with new program code including new interrupt vector values while leaving the protected area, which includes the default vector locations, unchanged. # 4.6 Security The MC9S08QG8/4 includes circuitry to prevent unauthorized access to the contents of FLASH and RAM memory. When security is engaged, FLASH and RAM are considered secure resources. Direct-page registers, high-page registers, and the background debug controller are considered unsecured resources. Programs executing within secure memory have normal access to any MCU memory locations and resources. Attempts to access a secure memory location with a program executing from an unsecured memory space or through the background debug interface are blocked (writes are ignored and reads return all 0s). Security is engaged or disengaged based on the state of two nonvolatile register bits (SEC01:SEC00) in the FOPT register. During reset, the contents of the nonvolatile location NVOPT are copied from FLASH into the working FOPT register in high-page register space. A user engages security by programming the NVOPT location which can be done at the same time the FLASH memory is programmed. The 1:0 state disengages security and the other three combinations engage security. Notice the erased state (1:1) makes # 5.8.7 System Real-Time Interrupt Status and Control Register (SRTISC) This high page register contains status and control bits for the RTI. Figure 5-9. System RTI Status and Control Register (SRTISC) **Table 5-10. SRTISC Register Field Descriptions** | Field | Description | |--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7<br>RTIF | Real-Time Interrupt Flag — This read-only status bit indicates the periodic wakeup timer has timed out. O Periodic wakeup timer not timed out. Periodic wakeup timer timed out. | | 6<br>RTIACK | Real-Time Interrupt Acknowledge — This write-only bit is used to acknowledge real-time interrupt request (write 1 to clear RTIF). Writing 0 has no meaning or effect. Reads always return 0. | | 5<br>RTICLKS | Real-Time Interrupt Clock Select — This read/write bit selects the clock source for the real-time interrupt. O Real-time interrupt request clock source is internal 1-kHz oscillator. Real-time interrupt request clock source is external clock. | | 4<br>RTIE | Real-Time Interrupt Enable — This read-write bit enables real-time interrupts. O Real-time interrupts disabled. 1 Real-time interrupts enabled. | | 2:0<br>RTIS | Real-Time Interrupt Delay Selects — These read/write bits select the period for the RTI. See Table 5-11. | Table 5-11. Real-Time Interrupt Period | RTIS2:RTIS1:RTIS0 | Using Internal 1-kHz Clock Source <sup>1 2</sup> | Using External Clock Source<br>Period = t <sub>ext</sub> <sup>3</sup> | |-------------------|--------------------------------------------------|-----------------------------------------------------------------------| | 0:0:0 | Disable RTI | Disable RTI | | 0:0:1 | 8 ms | t <sub>ext</sub> x 256 | | 0:1:0 | 32 ms | t <sub>ext</sub> x 1024 | | 0:1:1 | 64 ms | t <sub>ext</sub> x 2048 | | 1:0:0 | 128 ms | t <sub>ext</sub> x 4096 | | 1:0:1 | 256 ms | t <sub>ext</sub> x 8192 | | 1:1:0 | 512 ms | t <sub>ext</sub> x 16384 | | 1:1:1 | 1.024 s | t <sub>ext</sub> x 32768 | Values are shown in this column based on t<sub>RTI</sub> = 1 ms. See t<sub>RTI</sub> in the appendix Section A.8.1, "Control Timing," for the tolerance of this value. MC9S08QG8 and MC9S08QG4 Data Sheet, Rev. 5 $<sup>^{2}\,</sup>$ The initial RTI timeout period will be up to one 1-kHz clock period less than the time specified. <sup>&</sup>lt;sup>3</sup> t<sub>ext</sub> is the period of the external crystal frequency. **Chapter 6 Parallel Input/Output Control** ## Chapter 7 Central Processor Unit (S08CPUV2) Table 7-2. . Instruction Set Summary (Sheet 3 of 9) | Source<br>Form | Operation | Address<br>Mode | Object Code | Cycles | Cyc-by-Cyc<br>Details | | Affect<br>n CCR | |------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------|----------------------------------------------------------------------------------------------|--------------------------------------|-------------------------------------------------------------------------------|-----|-----------------| | 1 01111 | | ¥ğ⊠ | | ઇ | Details | VH | INZC | | BRA rel | Branch Always (if I = 1) | REL | 20 rr | 3 | ppp | | | | BRCLR n,opr8a,rel | Branch if Bit <i>n</i> in Memory Clear (if (Mn) = 0) | DIR (b0) DIR (b1) DIR (b2) DIR (b3) DIR (b4) DIR (b5) DIR (b6) DIR (b7) | 01 dd rr<br>03 dd rr<br>05 dd rr<br>07 dd rr<br>09 dd rr<br>0B dd rr<br>0D dd rr | 5<br>5<br>5<br>5<br>5<br>5<br>5<br>5 | rpppp<br>rpppp<br>rpppp<br>rpppp<br>rpppp<br>rpppp<br>rpppp<br>rpppp | | \$ | | BRN rel | Branch Never (if I = 0) | REL | 21 rr | 3 | ppp | | | | BRSET n,opr8a,rel | Branch if Bit <i>n</i> in Memory Set (if (Mn) = 1) | DIR (b0) DIR (b1) DIR (b2) DIR (b3) DIR (b4) DIR (b5) DIR (b6) DIR (b7) | 00 dd rr<br>02 dd rr<br>04 dd rr<br>06 dd rr<br>08 dd rr<br>0A dd rr<br>0C dd rr<br>0E dd rr | 5<br>5<br>5<br>5<br>5<br>5<br>5<br>5 | rpppp<br>rpppp<br>rpppp<br>rpppp<br>rpppp<br>rpppp<br>rpppp | | <b></b> | | BSET n,opr8a | Set Bit <i>n</i> in Memory (Mn ← 1) | DIR (b0) DIR (b1) DIR (b2) DIR (b3) DIR (b4) DIR (b5) DIR (b6) DIR (b7) | 10 dd<br>12 dd<br>14 dd<br>16 dd<br>18 dd<br>1A dd<br>1C dd<br>1E dd | 5<br>5<br>5<br>5<br>5<br>5<br>5 | rfwpp<br>rfwpp<br>rfwpp<br>rfwpp<br>rfwpp<br>rfwpp<br>rfwpp<br>rfwpp<br>rfwpp | | | | BSR rel | Branch to Subroutine $ \begin{array}{c} PC \leftarrow (PC) + \$0002 \\ push \ (PCL); \ SP \leftarrow (SP) - \$0001 \\ push \ (PCH); \ SP \leftarrow (SP) - \$0001 \\ PC \leftarrow (PC) + \mathit{rel} \end{array} $ | REL | AD rr | 5 | ssppp | | | | CBEQ opr8a,rel<br>CBEQA #opr8i,rel<br>CBEQX #opr8i,rel<br>CBEQ oprx8,X+,rel<br>CBEQ ,X+,rel<br>CBEQ oprx8,SP,rel | Compare and Branch if (A) = (M) Branch if (A) = (M) Branch if (X) = (M) Branch if (A) = (M) Branch if (A) = (M) Branch if (A) = (M) | DIR<br>IMM<br>IMM<br>IX1+<br>IX+<br>SP1 | 31 dd rr<br>41 ii rr<br>51 ii rr<br>61 ff rr<br>71 rr<br>9E 61 ff rr | 5<br>4<br>5<br>5 | rpppp<br>pppp<br>rpppp<br>rfppp<br>prpppp | | | | CLC | Clear Carry Bit (C ← 0) | INH | 98 | 1 | р | | 0 | | CLI | Clear Interrupt Mask Bit (I ← 0) | INH | 9A | 1 | р | | 0 | | CLR opr8a CLRA CLRX CLRH CLR oprx8,X CLR ,X CLR oprx8,SP | Clear M ← \$00<br>A ← \$00<br>X ← \$00<br>H ← \$00<br>M ← \$00<br>M ← \$00<br>M ← \$00 | DIR<br>INH<br>INH<br>INH<br>IX1<br>IX<br>SP1 | 3F dd<br>4F<br>5F<br>8C<br>6F ff<br>7F<br>9E 6F ff | 5<br>1<br>1<br>5<br>4<br>6 | rfwpp p p rfwpp rfwpp prfwpp | 0 – | - 0 1 - | # **Chapter 9 Analog-to-Digital Converter (S08ADC10V1)** ## 9.1 Introduction The 10-bit analog-to-digital converter (ADC) is a successive approximation ADC designed for operation within an integrated microcontroller system-on-chip. Figure 9-1 shows the MC9S08QG8/4 with the ADC module and pins highlighted. #### Chapter 9 Analog-to-Digital Converter (S08ADC10V1) #### NOTES: - 1 Not all pins or pin functions are available on all devices, see Table 1-1 for available functions on each device. - <sup>2</sup> Port pins are software configurable with pullup device if input port. - <sup>3</sup> Port pins are software configurable for output drive strength. - <sup>4</sup> Port pins are software configurable for output slew rate control. - <sup>5</sup> IRQ contains a software configurable (IRQPDD) pullup device if PTA5 enabled as IRQ pin function (IRQPE = 1). - <sup>6</sup> RESET contains integrated pullup device if PTA5 enabled as reset pin function (RSTPE = 1). - $^{7}$ PTA4 contains integrated pullup device if BKGD enabled (BKGDPE = 1). - 8 SDA and SCL pin locations can be repositioned under software control (IICPS), defaults on PTA2 and PTA3. - When pin functions as KBI (KBIPEn = 1) and associated pin is configured to enable the pullup device, KBEDGn can be used to reconfigure the pullup as a pulldown device. Figure 9-1. MC9S08QG8/4 Block Diagram Highlighting ADC Block and Pins MC9S08QG8 and MC9S08QG4 Data Sheet, Rev. 5 Analog-to-Digital Converter (S08ADC10V1) ## 9.4.4.2 Completing Conversions A conversion is completed when the result of the conversion is transferred into the data result registers, ADCRH and ADCRL. This is indicated by the setting of COCO. An interrupt is generated if AIEN is high at the time that COCO is set. A blocking mechanism prevents a new result from overwriting previous data in ADCRH and ADCRL if the previous data is in the process of being read while in 10-bit MODE (the ADCRH register has been read but the ADCRL register has not). When blocking is active, the data transfer is blocked, COCO is not set, and the new result is lost. In the case of single conversions with the compare function enabled and the compare condition false, blocking has no effect and ADC operation is terminated. In all other cases of operation, when a data transfer is blocked, another conversion is initiated regardless of the state of ADCO (single or continuous conversions enabled). If single conversions are enabled, the blocking mechanism could result in several discarded conversions and excess power consumption. To avoid this issue, the data registers must not be read after initiating a single conversion until the conversion completes. ## 9.4.4.3 Aborting Conversions Any conversion in progress will be aborted when: - A write to ADCSC1 occurs (the current conversion will be aborted and a new conversion will be initiated, if ADCH are not all 1s). - A write to ADCSC2, ADCCFG, ADCCVH, or ADCCVL occurs. This indicates a mode of operation change has occurred and the current conversion is therefore invalid. - The MCU is reset. - The MCU enters stop mode with ADACK not enabled. When a conversion is aborted, the contents of the data registers, ADCRH and ADCRL, are not altered but continue to be the values transferred after the completion of the last successful conversion. In the case that the conversion was aborted by a reset, ADCRH and ADCRL return to their reset states. ### 9.4.4.4 Power Control The ADC module remains in its idle state until a conversion is initiated. If ADACK is selected as the conversion clock source, the ADACK clock generator is also enabled. Power consumption when active can be reduced by setting ADLPC. This results in a lower maximum value for $f_{ADCK}$ (see the electrical specifications). ## 9.4.4.5 Total Conversion Time The total conversion time depends on the sample time (as determined by ADLSMP), the MCU bus frequency, the conversion mode (8-bit or 10-bit), and the frequency of the conversion clock ( $f_{ADCK}$ ). After the module becomes active, sampling of the input begins. ADLSMP is used to select between short and long sample times. When sampling is complete, the converter is isolated from the input channel and a successive approximation algorithm is performed to determine the digital value of the analog signal. The MC9S08QG8 and MC9S08QG4 Data Sheet, Rev. 5 Modulo Timer (S08MTIMV1) ## 13.1.4 Block Diagram The block diagram for the modulo timer module is shown Figure 13-2. Figure 13-2. Modulo Timer (MTIM) Block Diagram # 13.2 External Signal Description The MTIM includes one external signal, TCLK, used to input an external clock when selected as the MTIM clock source. The signal properties of TCLK are shown in Table 13-1. **Table 13-1. Signal Properties** | Signal | Function | I/O | |--------|---------------------------------------|-----| | TCLK | External clock source input into MTIM | I | The TCLK input must be synchronized by the bus clock. Also, variations in duty cycle and clock jitter must be accommodated. Therefore, the TCLK signal must be limited to one-fourth of the bus frequency. The TCLK pin can be muxed with a general-purpose port pin. See the Pins and Connections chapter for the pin location and priority of this function. # 13.3 Register Definition Figure 13-3 is a summary of MTIM registers. Modulo Timer (S08MTIMV1) #### **MTIM Counter Register (MTIMCNT)** 13.3.3 MTIMCNT is the read-only value of the current MTIM count of the 8-bit counter. Figure 13-6. MTIM Counter Register **Table 13-4. MTIM Counter Register Field Description** | Field | Description | |--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7:0<br>COUNT | MTIM Count — These eight read-only bits contain the current value of the 8-bit counter. Writes have no effect to this register. Reset clears the count to \$00. | #### **MTIM Modulo Register (MTIMMOD)** 13.3.4 Figure 13-7. MTIM Modulo Register Table 13-5. MTIM Modulo Register Field Descriptions | Field | Description | |------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7:0<br>MOD | MTIM Modulo — These eight read/write bits contain the modulo value used to reset the count and set TOF. A value of \$00 puts the MTIM in free-running mode. Writing to MTIMMOD resets the COUNT to \$00 and clears TOF. Reset sets the modulo to \$00. | # **Chapter 14 Serial Communications Interface (S08SCIV3)** # 14.1 Introduction Figure 14-1 shows the MC9S08QG8/4 block diagram with the SCI highlighted. Figure 15-3. SPI Module Block Diagram ## 15.1.3 SPI Baud Rate Generation As shown in Figure 15-4, the clock source for the SPI baud rate generator is the bus clock. The three prescale bits (SPPR2:SPPR1:SPPR0) choose a prescale divisor of 1, 2, 3, 4, 5, 6, 7, or 8. The three rate select bits (SPR2:SPR1:SPR0) divide the output of the prescaler stage by 2, 4, 8, 16, 32, 64, 128, or 256 to get the internal SPI master mode bit-rate clock. Serial Peripheral Interface (S08SPIV3) # 15.5 Functional Description An SPI transfer is initiated by checking for the SPI transmit buffer empty flag (SPTEF = 1) and then writing a byte of data to the SPI data register (SPID) in the master SPI device. When the SPI shift register is available, this byte of data is moved from the transmit data buffer to the shifter, SPTEF is set to indicate there is room in the buffer to queue another transmit character if desired, and the SPI serial transfer starts. During the SPI transfer, data is sampled (read) on the MISO pin at one SPSCK edge and shifted, changing the bit value on the MOSI pin, one-half SPSCK cycle later. After eight SPSCK cycles, the data that was in the shift register of the master has been shifted out the MOSI pin to the slave while eight bits of data were shifted in the MISO pin into the master's shift register. At the end of this transfer, the received data byte is moved from the shifter into the receive data buffer and SPRF is set to indicate the data can be read by reading SPID. If another byte of data is waiting in the transmit buffer at the end of a transfer, it is moved into the shifter, SPTEF is set, and a new transfer is started. Normally, SPI data is transferred most significant bit (MSB) first. If the least significant bit first enable (LSBFE) bit is set, SPI data is shifted LSB first. When the SPI is configured as a slave, its $\overline{SS}$ pin must be driven low before a transfer starts and $\overline{SS}$ must stay low throughout the transfer. If a clock format where CPHA = 0 is selected, $\overline{SS}$ must be driven to a logic 1 between successive transfers. If CPHA = 1, $\overline{SS}$ may remain low between successive transfers. See Section 15.5.1, "SPI Clock Formats" for more details. Because the transmitter and receiver are double buffered, a second byte, in addition to the byte currently being shifted out, can be queued into the transmit data buffer, and a previously received character can be in the receive data buffer while a new character is being shifted in. The SPTEF flag indicates when the transmit buffer has room for a new character. The SPRF flag indicates when a received character is available in the receive data buffer. The received character must be read out of the receive buffer (read SPID) before the next transfer is finished or a receive overrun error results. In the case of a receive overrun, the new data is lost because the receive buffer still held the previous character and was not ready to accept the new data. There is no indication for such an overrun condition so the application system designer must ensure that previous data has been read from the receive buffer before a new transfer is initiated. ### 15.5.1 SPI Clock Formats To accommodate a wide variety of synchronous serial peripherals from different manufacturers, the SPI system has a clock polarity (CPOL) bit and a clock phase (CPHA) control bit to select one of four clock formats for data transfers. CPOL selectively inserts an inverter in series with the clock. CPHA chooses between two different clock phase relationships between the clock and data. Figure 15-10 shows the clock formats when CPHA = 1. At the top of the figure, the eight bit times are shown for reference with bit 1 starting at the first SPSCK edge and bit 8 ending one-half SPSCK cycle after the sixteenth SPSCK edge. The MSB first and LSB first lines show the order of SPI data bits depending on the setting in LSBFE. Both variations of SPSCK polarity are shown, but only one of these waveforms applies for a specific transfer, depending on the value in CPOL. The SAMPLE IN waveform applies to the MOSI input of a slave or the MISO input of a master. The MOSI waveform applies to the transferred to the corresponding timer channel registers only after both 8-bit bytes of a 16-bit register have been written and the timer counter overflows (reverses direction from up-counting to down-counting at the end of the terminal count in the modulus register). This TPMCNT overflow requirement only applies to PWM channels, not output compares. Optionally, when TPMCNTH:TPMCNTL = TPMMODH:TPMMODL, the TPM can generate a TOF interrupt at the end of this count. The user can choose to reload any number of the PWM buffers, and they will all update simultaneously at the start of a new period. Writing to TPMSC cancels any values written to TPMMODH and/or TPMMODL and resets the coherency mechanism for the modulo registers. Writing to TPMCnSC cancels any values written to the channel value registers and resets the coherency mechanism for TPMCnVH:TPMCnVL. ## 16.5 TPM Interrupts The TPM generates an optional interrupt for the main counter overflow and an interrupt for each channel. The meaning of channel interrupts depends on the mode of operation for each channel. If the channel is configured for input capture, the interrupt flag is set each time the selected input capture edge is recognized. If the channel is configured for output compare or PWM modes, the interrupt flag is set each time the main timer counter matches the value in the 16-bit channel value register. See the Resets, Interrupts, and System Configuration chapter for absolute interrupt vector addresses, priority, and local interrupt mask control bits. For each interrupt source in the TPM, a flag bit is set on recognition of the interrupt condition such as timer overflow, channel input capture, or output compare events. This flag may be read (polled) by software to verify that the action has occurred, or an associated enable bit (TOIE or CHnIE) can be set to enable hardware interrupt generation. While the interrupt enable bit is set, a static interrupt will be generated whenever the associated interrupt flag equals 1. It is the responsibility of user software to perform a sequence of steps to clear the interrupt flag before returning from the interrupt service routine. # 16.5.1 Clearing Timer Interrupt Flags TPM interrupt flags are cleared by a 2-step process that includes a read of the flag bit while it is set (1) followed by a write of 0 to the bit. If a new event is detected between these two steps, the sequence is reset and the interrupt flag remains set after the second step to avoid the possibility of missing the new event. # 16.5.2 Timer Overflow Interrupt Description The conditions that cause TOF to become set depend on the counting mode (up or up/down). In up-counting mode, the 16-bit timer counter counts from 0x0000 through 0xFFFF and overflows to 0x0000 on the next counting clock. TOF becomes set at the transition from 0xFFFF to 0x0000. When a modulus limit is set, TOF becomes set at the transition from the value set in the modulus register to 0x0000. When the counter is operating in up-/down-counting mode, the TOF flag gets set as the counter changes direction at the transition from the value set in the modulus register and the next lower count value. This corresponds to the end of a PWM period. (The 0x0000 count value corresponds to the center of a period.) **Development Support** # 17.3 On-Chip Debug System (DBG) Because HCS08 devices do not have external address and data buses, the most important functions of an in-circuit emulator have been built onto the chip with the MCU. The debug system consists of an 8-stage FIFO that can store address or data bus information, and a flexible trigger system to decide when to capture bus information and what information to capture. The system relies on the single-wire background debug system to access debug control registers and to read results out of the eight stage FIFO. The debug module includes control and status registers that are accessible in the user's memory map. These registers are located in the high register space to avoid using valuable direct page memory space. Most of the debug module's functions are used during development, and user programs rarely access any of the control and status registers for the debug module. The one exception is that the debug system can provide the means to implement a form of ROM patching. This topic is discussed in greater detail in Section 17.3.6, "Hardware Breakpoints." ## 17.3.1 Comparators A and B Two 16-bit comparators (A and B) can optionally be qualified with the R/W signal and an opcode tracking circuit. Separate control bits allow you to ignore R/W for each comparator. The opcode tracking circuitry optionally allows you to specify that a trigger will occur only if the opcode at the specified address is actually executed as opposed to only being read from memory into the instruction queue. The comparators are also capable of magnitude comparisons to support the inside range and outside range trigger modes. Comparators are disabled temporarily during all BDC accesses. The A comparator is always associated with the 16-bit CPU address. The B comparator compares to the CPU address or the 8-bit CPU data bus, depending on the trigger mode selected. Because the CPU data bus is separated into a read data bus and a write data bus, the RWAEN and RWA control bits have an additional purpose, in full address plus data comparisons they are used to decide which of these buses to use in the comparator B data bus comparisons. If RWAEN = 1 (enabled) and RWA = 0 (write), the CPU's write data bus is used. Otherwise, the CPU's read data bus is used. The currently selected trigger mode determines what the debugger logic does when a comparator detects a qualified match condition. A match can cause: - Generation of a breakpoint to the CPU - Storage of data bus values into the FIFO - Starting to store change-of-flow addresses into the FIFO (begin type trace) - Stopping the storage of change-of-flow addresses into the FIFO (end type trace) # 17.3.2 Bus Capture Information and FIFO Operation The usual way to use the FIFO is to setup the trigger mode and other control options, then arm the debugger. When the FIFO has filled or the debugger has stopped storing data into the FIFO, you would read the information out of it in the order it was stored into the FIFO. Status bits indicate the number of words of valid information that are in the FIFO as data is stored into it. If a trace run is manually halted by writing 0 to ARM before the FIFO is full (CNT = 1:0:0:0), the information is shifted by one position and **Appendix A Electrical Characteristics** ## **Appendix B Ordering Information and Mechanical Drawings** Table B-2. Package Information (continued) | Pin Count | Туре | Designator | Document No. | |-----------|---------|------------|--------------| | 8 | DFN | FQ | 98ARL10557D | | 8 | PDIP | PA | 98ASB42420B | | 8 | NB SOIC | DN | 98ASB42564B | | © FREESCALE SEMICONDUCTOR, INC. ALL RIGHTS RESERVED. MECHANICA | | L OUTLINE | PRINT VERSION NO | T TO SCALE | |-----------------------------------------------------------------|---------------------------------|--------------|-------------------|------------| | TITLE: THERMALLY ENHANCED | QUAD | DOCUMENT NO | ): 98ARL10605D | REV: 0 | | FLAT NON-LEADED PACKA | CASE NUMBER: 1897-01 08 SEP 200 | | | | | 24 TERMINAL, 0.5 PITCH (4 X 4 X 1) | | STANDARD: JE | DEC M0-220 VGGD-8 | | | © FREESCALE SEMICONDUCTOR, INC.<br>ALL RIGHTS RESERVED. | MECHANICA | L OUTLINE | PRINT VERSION NO | T TO SCALE | |---------------------------------------------------------|-------------|--------------|------------------|------------| | TITLE: THERMALLY ENHANCED | DUAL | DOCUMENT NO | ): 98ARL10557D | REV: B | | FLAT NO LEAD PACKAGE | CASE NUMBER | R: 1452–02 | 28 DEC 2005 | | | 8 TERMINAL, 0.8 PITCH (4 X 4 X 1) | | STANDARD: NO | N-JEDEC | | ## NOTES: - 1. DIMENSIONING AND TOLERANCING PER ASME Y14.5M 1994. - 2. ALL DIMENSIONS ARE IN INCHES. - 3. 626-03 TO 626-06 OBSOLETE. NEW STANDARD 626-07. - A DIMENSION TO CENTER OF LEAD WHEN FORMED PARALLEL. - A PACKAGE CONTOUR OPTIONAL (ROUND OR SQUARE CONERS). ## STYLE 1: PIN 1. AC IN 5. GROUND 2. DC + IN 6. OUTPUT 3. DC - IN 7. AUXILIARY 4. AC IN 8. VCC | © FREESCALE SEMICONDUCTOR, INC. ALL RIGHTS RESERVED. | MECHANICA | L OUTLINE | PRINT VERSION NO | OT TO SCALE | |------------------------------------------------------|-----------|--------------|------------------|-------------| | TITLE: | | DOCUMENT NO | ): 98ASB42420B | REV: N | | 8 LD PDIP | | CASE NUMBER | R: 626–06 | 19 MAY 2005 | | | | STANDARD: NO | N-JEDEC | |