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 | Active | | Core Processor | 508 | | Core Size | 8-Bit | | Speed | 40MHz | | Connectivity | I <sup>2</sup> C, LINbus, SCI, SPI | | Peripherals | LVD, POR, PWM, WDT | | Number of I/O | 17 | | Program Memory Size | 8KB (8K x 8) | | Program Memory Type | FLASH | | EEPROM Size | - | | RAM Size | 512 x 8 | | Voltage - Supply (Vcc/Vdd) | 2.7V ~ 5.5V | | Data Converters | A/D 12x10b | | Oscillator Type | Internal | | Operating Temperature | -40°C ~ 125°C (TA) | | Mounting Type | Surface Mount | | Package / Case | 20-TSSOP (0.173", 4.40mm Width) | | Supplier Device Package | 20-TSSOP | | Purchase URL | https://www.e-xfl.com/product-detail/nxp-semiconductors/mc9s08sh8mtj | Email: info@E-XFL.COM Address: Room A, 16/F, Full Win Commercial Centre, 573 Nathan Road, Mongkok, Hong Kong # MC9S08SH8 Data Sheet Covers MC9S08SH8 MC9S08SH4 > MC9S08SH8 Rev. 3 6/2008 Freescale™ and the Freescale logo are trademarks of Freescale Semiconductor, Inc. © Freescale Semiconductor, Inc., 2007-2008. All rights reserved. #### **Chapter 2 Pins and Connections** Figure 2-2. 20-Pin PDIP, SOIC, and TSSOP Figure 2-3. 16-Pin TSSOP Figure 2-4. 8-Pin SOIC ## 2.2 Recommended System Connections Figure 2-5 shows pin connections that are common to MC9S08SH8 application systems. Figure 4-2. FLASH Program and Erase Flowchart ## 4.5.4 Burst Program Execution The burst program command is used to program sequential bytes of data in less time than would be required using the standard program command. This is possible because the high voltage to the FLASH array does not need to be disabled between program operations. Ordinarily, when a program or erase command is issued, an internal charge pump associated with the FLASH memory must be enabled to supply high voltage to the array. Upon completion of the command, the charge pump is turned off. When a burst program command is issued, the charge pump is enabled and then remains enabled after completion of the burst program operation if these two conditions are met: - The next burst program command has been queued before the current program operation has completed. - The next sequential address selects a byte on the same physical row as the current byte being programmed. A row of FLASH memory consists of 64 bytes. A byte within a row is selected by addresses A5 through A0. A new row begins when addresses A5 through A0 are all zero. | f <sub>Bus</sub> | PRDIV8<br>(Binary) | DIV<br>(Decimal) | f <sub>FCLK</sub> | Program/Erase Timing Pulse<br>(5 μs Min, 6.7 μs Max) | |------------------|--------------------|------------------|-------------------|------------------------------------------------------| | 20 MHz | 1 | 12 | 192.3 kHz | 5.2 μs | | 10 MHz | 0 | 49 | 200 kHz | 5 μs | | 8 MHz | 0 | 39 | 200 kHz | 5 μs | | 4 MHz | 0 | 19 | 200 kHz | 5 μs | | 2 MHz | 0 | 9 | 200 kHz | 5 μs | | 1 MHz | 0 | 4 | 200 kHz | 5 μs | | 200 kHz | 0 | 0 | 200 kHz | 5 μs | | 150 kHz | 0 | 0 | 150 kHz | 6.7 μs | **Table 4-7. FLASH Clock Divider Settings** ## 4.7.2 FLASH Options Register (FOPT and NVOPT) During reset, the contents of the nonvolatile location NVOPT are copied from FLASH into FOPT. To change the value in this register, erase and reprogram the NVOPT location in FLASH memory as usual and then issue a new MCU reset. = Unimplemented or Reserved Figure 4-6. FLASH Options Register (FOPT) **Table 4-8. FOPT Register Field Descriptions** | Field | Description | | |------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--| | 7<br>KEYEN | Backdoor Key Mechanism Enable — When this bit is 0, the backdoor key mechanism cannot be used to disengage security. The backdoor key mechanism is accessible only from user (secured) firmware. BDM commands cannot be used to write key comparison values that would unlock the backdoor key. For more detailed information about the backdoor key mechanism, refer to Section 4.6, "Security." O No backdoor key access allowed. If user firmware writes an 8-byte value that matches the nonvolatile backdoor key (NVBACKKEY through NVBACKKEY+7 in that order), security is temporarily disengaged until the next MCU reset. | | | 6<br>FNORED | Vector Redirection Disable — When this bit is 1, then vector redirection is disabled. 0 Vector redirection enabled. 1 Vector redirection disabled. | | | 1:0<br>SEC0[1:0] | Security State Code — This 2-bit field determines the security state of the MCU as shown in Table 4-9. When the MCU is secure, the contents of RAM and FLASH memory cannot be accessed by instructions from any unsecured source including the background debug interface. SEC01:SEC00 changes to 1:0 after successful backdoor key entry or a successful blank check of FLASH. For more detailed information about security, refer to Section 4.6, "Security." | | Table 4-9. Security States<sup>1</sup> | SEC01:SEC00 | Description | |-------------|-------------| | 0:0 | secure | | 0:1 | secure | | 1:0 | unsecured | | 1:1 | secure | SEC01:SEC00 changes to 1:0 after successful backdoor key entry or a successful blank check of FLASH. ### 4.7.3 FLASH Configuration Register (FCNFG Figure 4-7. FLASH Configuration Register (FCNFG **Table 4-10. FCNFG Register Field Descriptions** | Field | Description | |-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 5<br>KEYACC | Enable Writing of Access Key — This bit enables writing of the backdoor comparison key. For more detailed information about the backdoor key mechanism, refer to Section 4.6, "Security." 0 Writes to 0xFFB0–0xFFB7 are interpreted as the start of a FLASH programming or erase command. 1 Writes to NVBACKKEY (0xFFB0–0xFFB7) are interpreted as comparison key writes. | ## 4.7.4 FLASH Protection Register (FPROT and NVPROT) During reset, the contents of the nonvolatile location NVPROT are copied from FLASH into FPROT. This register can be read at any time. If FPDIS = 0, protection can be increased (that is, a smaller value of FPS can be written). If FPDIS = 1, writes do not change protection. <sup>1</sup> Background commands can be used to change the contents of these bits in FPROT. Figure 4-8. FLASH Protection Register (FPROT) ## 6.6.3.5 Port C Drive Strength Selection Register (PTCDS) Figure 6-23. Drive Strength Selection for Port C Register (PTCDS) **Table 6-22. PTCDS Register Field Descriptions** | Field | Description | |-------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 3:0<br>PTCDS[3:0] | Output Drive Strength Selection for Port C Bits — Each of these control bits selects between low and high output drive for the associated PTC pin. For port C pins that are configured as inputs, these bits have no effect. 1 Use the output drive strength selected for port C bit n. 2 Use the output drive strength selected for port C bit n. | ### 6.6.3.6 Ganged Output Drive Control Register (GNGC) Figure 6-24. Ganged Output Drive Control Register (GNGC) **Table 6-23. GNGC Register Field Descriptions** | Field | Description | |------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7:1<br>GNGP[7:1] | Ganged Output Pin Select Bits— These write-once control bits selects whether the associated pin (see Table 6-1for pins available) is enabled for ganged output. When GNGEN = 1, all enabled ganged output pins will be controlled by the data, drive strength and slew rate settings for PTCO. O Associated pin is not part of the ganged output drive. 1 Assoicated pin is part of the ganged output drive. Requires GNGEN = 1. | | 0<br>GNGEN | Ganged Output Drive Enable Bit— This write-once control bit selects whether the ganged output drive feature is enabled. O Ganged output drive disabled. Ganged output drive enabled. PTC0 forced to output regardless of the value of PTCDD0 in PTCDD. | #### Chapter 7 Central Processor Unit (S08CPUV2) Table 7-2. Instruction Set Summary (Sheet 7 of 9) | Source | Operation | Address<br>Mode | Object Code | Cycles | Cyc-by-Cyc | Affect on CCR | | |-----------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------|-------------------------------------------------------------------------|--------------------------------------|--------------------------------------|-----------------------|----------------| | Form | P | Ado | ., | ပ် | Details | <b>V</b> 1 1 <b>H</b> | INZC | | RSP | Reset Stack Pointer (Low Byte) SPL ← \$FF (High Byte Not Affected) | INH | 9C | 1 | р | - 1 1 - | | | RTI | Return from Interrupt SP $\leftarrow$ (SP) + \$0001; Pull (CCR) SP $\leftarrow$ (SP) + \$0001; Pull (A) SP $\leftarrow$ (SP) + \$0001; Pull (X) SP $\leftarrow$ (SP) + \$0001; Pull (PCH) SP $\leftarrow$ (SP) + \$0001; Pull (PCL) | INH | 80 | 9 | uuuuufppp | ↓ 1 1 ↓ | <b>‡</b> ‡ ‡ ‡ | | RTS | Return from Subroutine SP $\leftarrow$ SP + \$0001; Pull (PCH) SP $\leftarrow$ SP + \$0001; Pull (PCL) | INH | 81 | 5 | ufppp | - 1 1 - | | | SBC #opr8i<br>SBC opr8a<br>SBC opr16a<br>SBC oprx16,X<br>SBC oprx8,X<br>SBC ,X<br>SBC oprx16,SP<br>SBC oprx8,SP | Subtract with Carry $A \leftarrow (A) - (M) - (C)$ | IMM DIR EXT IX2 IX1 IX SP2 SP1 | A2 ii B2 dd C2 hh ll D2 ee ff E2 ff F2 9E D2 ee ff 9E E2 ff | 2<br>3<br>4<br>4<br>3<br>3<br>5<br>4 | pp rpp prpp rpp rfp pprpp prpp | ↑ 1 1 - | <b>-</b> ↑ ↑ ↑ | | SEC | Set Carry Bit $(C \leftarrow 1)$ | INH | 99 | 1 | р | - 1 1 - | 1 | | SEI | Set Interrupt Mask Bit $(I \leftarrow 1)$ | INH | 9В | 1 | р | - 1 1 - | 1 | | STA opr8a<br>STA opr16a<br>STA oprx16,X<br>STA oprx8,X<br>STA ,X<br>STA oprx16,SP<br>STA oprx8,SP | Store Accumulator in Memory $\mathbf{M} \leftarrow (\mathbf{A})$ | DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP2<br>SP1 | B7 dd<br>C7 hh ll<br>D7 ee ff<br>E7 ff<br>F7<br>9E D7 ee ff<br>9E E7 ff | 3<br>4<br>4<br>3<br>2<br>5<br>4 | bmbb<br>bbmbb<br>mbb<br>bmbb<br>bmbb | 0 1 1 - | - \$ \$ - | | STHX opr8a<br>STHX opr16a<br>STHX oprx8,SP | Store H:X (Index Reg.)<br>(M:M + \$0001) ← (H:X) | DIR<br>EXT<br>SP1 | 35 dd<br>96 hh 11<br>9E FF ff | 4<br>5<br>5 | pwwpp<br>pwwpp<br>wwpp | 0 1 1 - | - 1 1 - | | STOP | Enable Interrupts: Stop Processing Refer to MCU Documentation I bit ← 0; Stop Processing | INH | 8E | 2 | fp | - 1 1 - | 0 | | STX opr8a<br>STX opr16a<br>STX oprx16,X<br>STX oprx8,X<br>STX ,X<br>STX oprx16,SP<br>STX oprx8,SP | Store X (Low 8 Bits of Index Register) in Memory $\mathbf{M} \leftarrow (\mathbf{X})$ | DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP2<br>SP1 | BF dd<br>CF hh ll<br>DF ee ff<br>EF ff<br>FF<br>9E DF ee ff<br>9E EF ff | 3<br>4<br>4<br>3<br>2<br>5<br>4 | bmbb<br>bbmbb<br>mbb<br>bmbb<br>bmbb | 0 1 1 – | - \$ \$ - | #### 12.1.2 Features Timer system features include: - 8-bit up-counter - Free-running or 8-bit modulo limit - Software controllable interrupt on overflow - Counter reset bit (TRST) - Counter stop bit (TSTP) - Four software selectable clock sources for input to prescaler: - System bus clock rising edge - Fixed frequency clock (XCLK) rising edge - External clock source on the TCLK pin rising edge - External clock source on the TCLK pin falling edge - Nine selectable clock prescale values: - Clock source divide by 1, 2, 4, 8, 16, 32, 64, 128, or 256 #### 12.1.3 Modes of Operation This section defines the MTIM's operation in stop, wait and background debug modes. #### 12.1.3.1 MTIM in Wait Mode The MTIM continues to run in wait mode if enabled before executing the WAIT instruction. Therefore, the MTIM can be used to bring the MCU out of wait mode if the timer overflow interrupt is enabled. For lowest possible current consumption, the MTIM should be stopped by software if not needed as an interrupt source during wait mode. ## 12.1.3.2 MTIM in Stop Modes The MTIM is disabled in all stop modes, regardless of the settings before executing the STOP instruction. Therefore, the MTIM cannot be used as a wake up source from stop modes. Waking from stop1 and stop2 modes, the MTIM will be put into its reset state. If stop3 is exited with a reset, the MTIM will be put into its reset state. If stop3 is exited with an interrupt, the MTIM continues from the state it was in when stop3 was entered. If the counter was active upon entering stop3, the count will resume from the current value. # 12.1.3.3 MTIM in Active Background Mode The MTIM suspends all counting until the microcontroller returns to normal user operating mode. Counting resumes from the suspended value as long as an MTIM reset did not occur (TRST written to a 1 or MTIMMOD written). Chapter 12 Modulo Timer (S08MTIMV1) #### 12.4.1 MTIM Operation Example This section shows an example of the MTIM operation as the counter reaches a matching value from the modulo register. Figure 12-8. MTIM counter overfl w example In the example of Figure 12-8, the selected clock source could be any of the five possible choices. The prescaler is set to PS = %0010 or divide-by-4. The modulo value in the MTIMMOD register is set to \$AA. When the counter, MTIMCNT, reaches the modulo value of \$AA, the counter overflows to \$00 and continues counting. The timer overflow flag, TOF, sets when the counter value changes from \$AA to \$00. An MTIM overflow interrupt is generated when TOF is set, if TOIE = 1. #### **13.1.1** Features Features of the RTC module include: - 8-bit up-counter - 8-bit modulo match limit - Software controllable periodic interrupt on match - Three software selectable clock sources for input to prescaler with selectable binary-based and decimal-based divider values - 1-kHz internal low-power oscillator (LPO) - External clock (ERCLK) - 32-kHz internal clock (IRCLK) #### 13.1.2 Modes of Operation This section defines the operation in stop, wait and background debug modes. #### 13.1.2.1 Wait Mode The RTC continues to run in wait mode if enabled before executing the appropriate instruction. Therefore, the RTC can bring the MCU out of wait mode if the real-time interrupt is enabled. For lowest possible current consumption, the RTC should be stopped by software if not needed as an interrupt source during wait mode. ### 13.1.2.2 Stop Modes The RTC continues to run in stop2 or stop3 mode if the RTC is enabled before executing the STOP instruction. Therefore, the RTC can bring the MCU out of stop modes with no external components, if the real-time interrupt is enabled. The LPO clock can be used in stop2 and stop3 modes. ERCLK and IRCLK clocks are only available in stop3 mode. Power consumption is lower when all clock sources are disabled, but in that case, the real-time interrupt cannot wake up the MCU from stop modes. ## 13.1.2.3 Active Background Mode The RTC suspends all counting during active background mode until the microcontroller returns to normal user operating mode. Counting resumes from the suspended value as long as the RTCMOD register is not written and the RTCPS and RTCLKS bits are not altered. Chapter 13 Real-Time Counter (S08RTCV1) ### 13.3.2 RTC Counter Register (RTCCNT) RTCCNT is the read-only value of the current RTC count of the 8-bit counter. Figure 13-4. RTC Counter Register (RTCCNT) **Table 13-4. RTCCNT Field Descriptions** | Field | Description | |-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | | RTC Count. These eight read-only bits contain the current value of the 8-bit counter. Writes have no effect to this register. Reset, writing to RTCMOD, or writing different values to RTCLKS and RTCPS clear the count to 0x00. | ## 13.3.3 RTC Modulo Register (RTCMOD) Figure 13-5. RTC Modulo Register (RTCMOD) **Table 13-5. RTCMOD Field Descriptions** | Field | Description | |---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7:0<br>RTCMOD | RTC Modulo. These eight read/write bits contain the modulo value used to reset the count to 0x00 upon a compare match and set the RTIF status bit. A value of 0x00 sets the RTIF bit on each rising edge of the prescaler output. Writing to RTCMOD resets the prescaler and the RTCCNT counters to 0x00. Reset sets the modulo to 0x00. | ## 13.4 Functional Description The RTC is composed of a main 8-bit up-counter with an 8-bit modulo register, a clock source selector, and a prescaler block with binary-based and decimal-based selectable values. The module also contains software selectable interrupt logic. After any MCU reset, the counter is stopped and reset to 0x00, the modulus register is set to 0x00, and the prescaler is off. The 1-kHz internal oscillator clock is selected as the default clock source. To start the prescaler, write any value other than zero to the prescaler select bits (RTCPS). Three clock sources are software selectable: the low power oscillator clock (LPO), the external clock (ERCLK), and the internal clock (IRCLK). The RTC clock select bits (RTCLKS) select the desired clock source. If a different value is written to RTCLKS, the prescaler and RTCCNT counters are reset to 0x00. Writing 0 to TE does not immediately release the pin to be a general-purpose I/O pin. Any transmit activity that is in progress must first be completed. This includes data characters in progress, queued idle characters, and queued break characters. #### 14.3.2.1 Send Break and Queued Idle The SBK control bit in SCIxC2 is used to send break characters which were originally used to gain the attention of old teletype receivers. Break characters are a full character time of logic 0 (10 bit times including the start and stop bits). A longer break of 13 bit times can be enabled by setting BRK13 = 1. Normally, a program would wait for TDRE to become set to indicate the last character of a message has moved to the transmit shifter, then write 1 and then write 0 to the SBK bit. This action queues a break character to be sent as soon as the shifter is available. If SBK is still 1 when the queued break moves into the shifter (synchronized to the baud rate clock), an additional break character is queued. If the receiving device is another Freescale Semiconductor SCI, the break characters will be received as 0s in all eight data bits and a framing error (FE = 1) occurs. When idle-line wakeup is used, a full character time of idle (logic 1) is needed between messages to wake up any sleeping receivers. Normally, a program would wait for TDRE to become set to indicate the last character of a message has moved to the transmit shifter, then write 0 and then write 1 to the TE bit. This action queues an idle character to be sent as soon as the shifter is available. As long as the character in the shifter does not finish while TE = 0, the SCI transmitter never actually releases control of the TxD pin. If there is a possibility of the shifter finishing while TE = 0, set the general-purpose I/O controls so the pin that is shared with TxD is an output driving a logic 1. This ensures that the TxD line will look like a normal idle line even if the SCI loses control of the port pin between writing 0 and then 1 to TE. The length of the break character is affected by the BRK13 and M bits as shown below. | BRK13 | М | Break Character Length | |-------|---|------------------------| | 0 | 0 | 10 bit times | | 0 | 1 | 11 bit times | | 1 | 0 | 13 bit times | | 1 | 1 | 14 bit times | Table 14-8. Break Character Length ## 14.3.3 Receiver Functional Description In this section, the receiver block diagram (Figure 14-3) is used as a guide for the overall receiver functional description. Next, the data sampling technique used to reconstruct receiver data is described in more detail. Finally, two variations of the receiver wakeup function are explained. The receiver input is inverted by setting RXINV = 1. The receiver is enabled by setting the RE bit in SCIxC2. Character frames consist of a start bit of logic 0, eight (or nine) data bits (LSB first), and a stop bit of logic 1. For information about 9-bit data mode, refer to Section 14.3.5.1, "8- and 9-Bit Data Modes." For the remainder of this discussion, we assume the SCI is configured for normal 8-bit data mode. After receiving the stop bit into the receive shifter, and provided the receive data register is not already full, the data character is transferred to the receive data register and the receive data register full (RDRF) status Chapter 15 Serial Peripheral Interface (S08SPIV3) Table 15-5. SPI Baud Rate Prescaler Divisor | SPPR2:SPPR1:SPPR0 | Prescaler Divisor | |-------------------|-------------------| | 0:0:0 | 1 | | 0:0:1 | 2 | | 0:1:0 | 3 | | 0:1:1 | 4 | | 1:0:0 | 5 | | 1:0:1 | 6 | | 1:1:0 | 7 | | 1:1:1 | 8 | Table 15-6. SPI Baud Rate Divisor | SPR2:SPR1:SPR0 | Rate Divisor | |----------------|--------------| | 0:0:0 | 2 | | 0:0:1 | 4 | | 0:1:0 | 8 | | 0:1:1 | 16 | | 1:0:0 | 32 | | 1:0:1 | 64 | | 1:1:0 | 128 | | 1:1:1 | 256 | # 15.4.4 SPI Status Register (SPIS) This register has three read-only status bits. Bits 6, 3, 2, 1, and 0 are not implemented and always read 0. Writes have no meaning or effect. Figure 15-8. SPI Status Register (SPIS) 232 Freescale Semiconductor #### **Chapter 17 Development Support** | | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-------|-----------------------------|---|---|---|---|---|---|-------------------| | R | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | W | | | | | | | | BDFR <sup>1</sup> | | Reset | 0 | 0 | 0 | 0 | 0 | 0 | 0 | 0 | | | = Unimplemented or Reserved | | | | | | | | <sup>&</sup>lt;sup>1</sup> BDFR is writable only through serial background mode debug commands, not from user programs. Figure 17-6. System Background Debug Force Reset Register (SBDFR) Table 17-3. SBDFR Register Field Description | Field | Description | |-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 0<br>BDFR | <b>Background Debug Force Reset</b> — A serial active background mode command such as WRITE_BYTE allows an external debug host to force a target system reset. Writing 1 to this bit forces an MCU reset. This bit cannot be written from a user program. | #### 17.4.3 **DBG Registers and Control Bits** The debug module includes nine bytes of register space for three 16-bit registers and three 8-bit control and status registers. These registers are located in the high register space of the normal memory map so they are accessible to normal application programs. These registers are rarely if ever accessed by normal user application programs with the possible exception of a ROM patching mechanism that uses the breakpoint logic. #### 17.4.3.1 **Debug Comparator A High Register (DBGCAH)** This register contains compare value bits for the high-order eight bits of comparator A. This register is forced to 0x00 at reset and can be read at any time or written at any time unless ARM = 1. #### 17.4.3.2 **Debug Comparator A Low Register (DBGCAL)** This register contains compare value bits for the low-order eight bits of comparator A. This register is forced to 0x00 at reset and can be read at any time or written at any time unless ARM = 1. #### 17.4.3.3 **Debug Comparator B High Register (DBGCBH)** This register contains compare value bits for the high-order eight bits of comparator B. This register is forced to 0x00 at reset and can be read at any time or written at any time unless ARM = 1. #### 17.4.3.4 **Debug Comparator B Low Register (DBGCBL)** This register contains compare value bits for the low-order eight bits of comparator B. This register is forced to 0x00 at reset and can be read at any time or written at any time unless ARM = 1. MC9S08SH8 MCU Series Data Sheet, Rev. 3 284 Freescale Semiconductor **Chapter 17 Development Support** ## 17.4.3.9 Debug Status Register (DBGS) This is a read-only status register. Figure 17-9. Debug Status Register (DBGS) **Table 17-6. DBGS Register Field Descriptions** | Field | Description | |-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | 7<br>AF | Trigger Match A Flag — AF is cleared at the start of a debug run and indicates whether a trigger match A condition was met since arming. 0 Comparator A has not matched 1 Comparator A match | | 6<br>BF | Trigger Match B Flag — BF is cleared at the start of a debug run and indicates whether a trigger match B condition was met since arming. O Comparator B has not matched Comparator B match | | 5<br>ARMF | Arm Flag — While DBGEN = 1, this status bit is a read-only image of ARM in DBGC. This bit is set by writing 1 to the ARM control bit in DBGC (while DBGEN = 1) and is automatically cleared at the end of a debug run. A debug run is completed when the FIFO is full (begin trace) or when a trigger event is detected (end trace). A debug run can also be ended manually by writing 0 to ARM or DBGEN in DBGC. 0 Debugger not armed 1 Debugger armed | | 3:0<br>CNT[3:0] | FIFO Valid Count — These bits are cleared at the start of a debug run and indicate the number of words of valid data in the FIFO at the end of a debug run. The value in CNT does not decrement as data is read out of the FIFO. The external debug host is responsible for keeping track of the count as information is read out of the FIFO. 0000 Number of valid words in FIFO = No valid data 0001 Number of valid words in FIFO = 1 0010 Number of valid words in FIFO = 2 0011 Number of valid words in FIFO = 3 0100 Number of valid words in FIFO = 4 0101 Number of valid words in FIFO = 5 0110 Number of valid words in FIFO = 6 0111 Number of valid words in FIFO = 7 1000 Number of valid words in FIFO = 8 | # A.10 Analog Comparator (ACMP) Electricals #### **Table A-10. Analog Comparator Electrical Specification** | Num | С | Rating | Symbol | Min | Typical | Max | Unit | |-----|-----|----------------------------------------|--------------------|-----------------------|---------|----------|------| | 1 | _ | Supply voltage | V <sub>DD</sub> | 2.7 | _ | 5.5 | V | | 2 | C/T | Supply current (active) | I <sub>DDAC</sub> | _ | 20 | 35 | μΑ | | 3 | D | Analog input voltage | V <sub>AIN</sub> | V <sub>SS</sub> - 0.3 | _ | $V_{DD}$ | V | | 4 | D | Analog input offset voltage | V <sub>AIO</sub> | | 20 | 40 | mV | | 5 | D | Analog Comparator hysteresis | V <sub>H</sub> | 3.0 | 6.0 | 20.0 | mV | | 6 | D | Analog input leakage current | I <sub>ALKG</sub> | | | 1.0 | μΑ | | 7 | D | Analog Comparator initialization delay | t <sub>AINIT</sub> | _ | _ | 1.0 | μs | #### A.11 ADC Characteristics **Table A-11. ADC Operating Conditions** | Characteristic | Conditions | Symb | Min | Typ <sup>1</sup> | Max | Unit | Comment | |-----------------------------|---------------------------------------------------------------------|-------------------|-------------------|------------------|-------------------|---------|-----------------| | Supply voltage | Absolute | $V_{DDAD}$ | 2.7 | _ | 5.5 | V | | | Input Voltage | | V <sub>ADIN</sub> | V <sub>REFL</sub> | _ | V <sub>REFH</sub> | V | | | Input<br>Capacitance | | C <sub>ADIN</sub> | _ | 4.5 | 5.5 | pF | | | Input<br>Resistance | | R <sub>ADIN</sub> | _ | 3 | 5 | kΩ | | | Analog Source<br>Resistance | 10 bit mode<br>f <sub>ADCK</sub> > 4MHz<br>f <sub>ADCK</sub> < 4MHz | R <sub>AS</sub> | _ | _ | 5<br>10 | kΩ | External to MCU | | | 8 bit mode (all valid f <sub>ADCK</sub> ) | | _ | _ | 10 | | | | ADC | High Speed (ADLPC=0) | f <sub>ADCK</sub> | 0.4 | _ | 8.0 | N 41 1- | | | Conversion<br>Clock Freq. | Low Power (ADLPC=1) | | 0.4 | _ | 4.0 | MHz | | Typical values assume V<sub>DDAD</sub> = V<sub>DD</sub> = 5.0V, Temp = 25°C, fADCK=1.0MHz unless otherwise stated. Typical values are for reference only and are not tested in production. Figure A-9. ADC Input Impedance Equivalency Diagram #### NOTES: - 1. $\overline{SS}$ output mode (MODFEN = 1, SSOE = 1). - 2. LSBF = 0. For LSBF = 1, bit order is LSB, bit 1, ..., bit 6, MSB. Figure A-14. SPI Master Timing (CPHA = 0) #### NOTES: - 1. $\overline{SS}$ output mode (MODFEN = 1, SSOE = 1). - 2. LSBF = 0. For LSBF = 1, bit order is LSB, bit 1, ..., bit 6, MSB. Figure A-15. SPI Master Timing (CPHA = 1) MC9S08SH8 MCU Series Data Sheet, Rev. 3 | © FREESCALE SEMICONDUCTOR, INC.<br>ALL RIGHTS RESERVED. | MECHANICA | L OUTLINE | PRINT VERSION NO | IT TO SCALE | |---------------------------------------------------------|-----------------------------|--------------|------------------|-------------| | TITLE: | | DOCUMENT NO | ]: 98ASH70247A | REV: B | | 16 LD TSSOP, PITCH 0. | CASE NUMBER: 948F-01 19 MAY | | | | | | 0.0111111 | STANDARD: JE | DEC | |