### NXP USA Inc. - MC9S08DV32AMLH Datasheet





#### 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 -</u> <u>Microcontrollers</u>"

#### Details

| Product Status             | Active                                                                 |
|----------------------------|------------------------------------------------------------------------|
| Core Processor             | 508                                                                    |
| Core Size                  | 8-Bit                                                                  |
| Speed                      | 40MHz                                                                  |
| Connectivity               | CANbus, I <sup>2</sup> C, LINbus, SCI, SPI                             |
| Peripherals                | LVD, POR, PWM, WDT                                                     |
| Number of I/O              | 53                                                                     |
| Program Memory Size        | 32KB (32K x 8)                                                         |
| Program Memory Type        | FLASH                                                                  |
| EEPROM Size                | -                                                                      |
| RAM Size                   | 2K x 8                                                                 |
| Voltage - Supply (Vcc/Vdd) | 2.7V ~ 5.5V                                                            |
| Data Converters            | A/D 16x12b                                                             |
| Oscillator Type            | External                                                               |
| Operating Temperature      | -40°C ~ 125°C (TA)                                                     |
| Mounting Type              | Surface Mount                                                          |
| Package / Case             | 64-LQFP                                                                |
| Supplier Device Package    | 64-LQFP (10x10)                                                        |
| Purchase URL               | https://www.e-xfl.com/product-detail/nxp-semiconductors/mc9s08dv32amlh |

Email: info@E-XFL.COM

Address: Room A, 16/F, Full Win Commercial Centre, 573 Nathan Road, Mongkok, Hong Kong



### NOTE

To avoid extra current drain from floating input pins, the reset initialization routine in the application program should either enable on-chip pull-up devices or change the direction of unused or non-bonded pins to outputs so they do not float.



| Address<br>(High/Low) | Vector                 | Vector Name |
|-----------------------|------------------------|-------------|
| 0xFFCE:0xFFCF         | IIC                    | Viic        |
| 0xFFD0:0xFFD1         | ADC Conversion         | Vadc        |
| 0xFFD2:0xFFD3         | Port A, Port B, Port D | Vport       |
| 0xFFD4:0xFFD5         | SCI2 Transmit          | Vsci2tx     |
| 0xFFD6:0xFFD7         | SCI2 Receive           | Vsci2rx     |
| 0xFFD8:0xFFD9         | SCI2 Error             | Vsci2err    |
| 0xFFDA:0xFFDB         | SCI1 Transmit          | Vsci1tx     |
| 0xFFDC:0xFFDD         | SCI1 Receive           | Vsci1rx     |
| 0xFFDE:0xFFDF         | SCI1 Error             | Vsci1err    |
| 0xFFE0:0xFFE1         | SPI                    | Vspi        |
| 0xFFE2:0xFFE3         | TPM2 Overflow          | Vtpm2ovf    |
| 0xFFE4:0xFFE5         | TPM2 Channel 1         | Vtpm2ch1    |
| 0xFFE6:0xFFE7         | TPM2 Channel 0         | Vtpm2ch0    |
| 0xFFE8:0xFFE9         | TPM1 Overflow          | Vtpm1ovf    |
| 0xFFEA:0xFFEB         | TPM1 Channel 5         | Vtpm1ch5    |
| 0xFFEC:0xFFED         | TPM1 Channel 4         | Vtpm1ch4    |
| 0xFFEE:0xFFEF         | TPM1 Channel 3         | Vtpm1ch3    |
| 0xFFF0:0xFFF1         | TPM1 Channel 2         | Vtpm1ch2    |
| 0xFFF2:0xFFF3         | TPM1 Channel 1         | Vtpm1ch1    |
| 0xFFF4:0xFFF5         | TPM1 Channel 0         | Vtpm1ch0    |
| 0xFFF6:0xFFF7         | MCG Loss of lock       | Vlol        |
| 0xFFF8:0xFFF9         | Low-Voltage Detect     | Vlvd        |
| 0xFFFA:0xFFFB         | IRQ                    | Virq        |
| 0xFFFC:0xFFFD         | SWI                    | Vswi        |
| 0xFFFE:0xFFFF         | Reset                  | Vreset      |

### Table 4-1. Reset and Interrupt Vectors



Chapter 4 Memory

Table 4-2. Direct-Page Register Summary (Sheet 2 of 3)

| Address                            | Register<br>Name | Bit 7  | 6                               | 5     | 4       | 3        | 2     | 1       | Bit 0    |
|------------------------------------|------------------|--------|---------------------------------|-------|---------|----------|-------|---------|----------|
| 0x00 <b>28</b>                     | TPM1C1SC         | CH1F   | CH1IE                           | MS1B  | MS1A    | ELS1B    | ELS1A | 0       | 0        |
| 0x00 <b>29</b>                     | TPM1C1VH         | Bit 15 | 14                              | 13    | 12      | 11       | 10    | 9       | Bit 8    |
| 0x00 <b>2A</b>                     | TPM1C1VL         | Bit 7  | 6                               | 5     | 4       | 3        | 2     | 1       | Bit 0    |
| 0x00 <b>2B</b>                     | TPM1C2SC         | CH2F   | CH2IE                           | MS2B  | MS2A    | ELS2B    | ELS2A | 0       | 0        |
| 0x00 <b>2C</b>                     | TPM1C2VH         | Bit 15 | 14                              | 13    | 12      | 11       | 10    | 9       | Bit 8    |
| 0x00 <b>2D</b>                     | TPM1C2VL         | Bit 7  | 6                               | 5     | 4       | 3        | 2     | 1       | Bit 0    |
| 0x00 <b>2E</b>                     | TPM1C3SC         | CH3F   | CH3IE                           | MS3B  | MS3A    | ELS3B    | ELS3A | 0       | 0        |
| 0x00 <b>2F</b>                     | TPM1C3VH         | Bit 15 | 14                              | 13    | 12      | 11       | 10    | 9       | Bit 8    |
| 0x00 <b>30</b>                     | TPM1C3VL         | Bit 7  | 6                               | 5     | 4       | 3        | 2     | 1       | Bit 0    |
| 0x00 <b>31</b>                     | TPM1C4SC         | CH4F   | CH4IE                           | MS4B  | MS4A    | ELS4B    | ELS4A | 0       | 0        |
| 0x00 <b>32</b>                     | TPM1C4VH         | Bit 15 | 14                              | 13    | 12      | 11       | 10    | 9       | Bit 8    |
| 0x00 <b>33</b>                     | TPM1C4VL         | Bit 7  | 6                               | 5     | 4       | 3        | 2     | 1       | Bit 0    |
| 0x00 <b>34</b>                     | TPM1C5SC         | CH5F   | CH5IE                           | MS5B  | MS5A    | ELS5B    | ELS5A | 0       | 0        |
| 0x00 <b>35</b>                     | TPM1C5VH         | Bit 15 | 14                              | 13    | 12      | 11       | 10    | 9       | Bit 8    |
| 0x00 <b>36</b>                     | TPM1C5VL         | Bit 7  | 6                               | 5     | 4       | 3        | 2     | 1       | Bit 0    |
| 0x00 <b>37</b>                     | Reserved         |        | —                               | —     | _       | _        | —     | —       | —        |
| 0x00 <b>38</b>                     | SCI1BDH          | LBKDIE | RXEDGIE                         | 0     | SBR12   | SBR11    | SBR10 | SBR9    | SBR8     |
| 0x00 <b>39</b>                     | SCI1BDL          | SBR7   | SBR6                            | SBR5  | SBR4    | SBR3     | SBR2  | SBR1    | SBR0     |
| 0x00 <b>3A</b>                     | SCI1C1           | LOOPS  | SCISWAI                         | RSRC  | М       | WAKE     | ILT   | PE      | PT       |
| 0x00 <b>3B</b>                     | SCI1C2           | TIE    | TCIE                            | RIE   | ILIE    | TE       | RE    | RWU     | SBK      |
| 0x00 <b>3C</b>                     | SCI1S1           | TDRE   | TC                              | RDRF  | IDLE    | OR       | NF    | FE      | PF       |
| 0x00 <b>3D</b>                     | SCI1S2           | LBKDIF | RXEDGIF                         | 0     | RXINV   | RWUID    | BRK13 | LBKDE   | RAF      |
| 0x00 <b>3E</b>                     | SCI1C3           | R8     | Т8                              | TXDIR | TXINV   | ORIE     | NEIE  | FEIE    | PEIE     |
| 0x00 <b>3F</b>                     | SCI1D            | Bit 7  | 6                               | 5     | 4       | 3        | 2     | 1       | Bit 0    |
| 0x00 <b>40</b>                     | SCI2BDH          | LBKDIE | RXEDGIE                         | 0     | SBR12   | SBR11    | SBR10 | SBR9    | SBR8     |
| 0x00 <b>41</b>                     | SCI2BDL          | SBR7   | SBR6                            | SBR5  | SBR4    | SBR3     | SBR2  | SBR1    | SBR0     |
| 0x00 <b>42</b>                     | SCI2C1           | LOOPS  | SCISWAI                         | RSRC  | М       | WAKE     | ILT   | PE      | PT       |
| 0x00 <b>43</b>                     | SCI2C2           | TIE    | TCIE                            | RIE   | ILIE    | TE       | RE    | RWU     | SBK      |
| 0x00 <b>44</b>                     | SCI2S1           | TDRE   | TC                              | RDRF  | IDLE    | OR       | NF    | FE      | PF       |
| 0x00 <b>45</b>                     | SCI2S2           | LBKDIF | RXEDGIF                         | 0     | RXINV   | RWUID    | BRK13 | LBKDE   | RAF      |
| 0x00 <b>46</b>                     | SCI2C3           | R8     | Т8                              | TXDIR | TXINV   | ORIE     | NEIE  | FEIE    | PEIE     |
| 0x00 <b>47</b>                     | SCI2D            | Bit 7  | 6                               | 5     | 4       | 3        | 2     | 1       | Bit 0    |
| 0x00 <b>48</b>                     | MCGC1            | CL     | KS                              |       | RDIV    |          | IREFS | IRCLKEN | IREFSTEN |
| 0x00 <b>49</b>                     | MCGC2            | BC     | BDIV RANGE HGO LP EREFS ERCLKEN |       | ERCLKEN | EREFSTEN |       |         |          |
| 0x00 <b>4A</b>                     | MCGTRM           |        |                                 |       | TRIM    |          |       |         |          |
| 0x00 <b>4B</b>                     | MCGSC            | LOLS   | LOCK                            | PLLST | IREFST  | CL       | (ST   | OSCINIT | FTRIM    |
| 0x00 <b>4C</b>                     | MCGC3            | LOLIE  | PLLS                            | CME   | 0       | VDIV     |       |         |          |
| 0x004 <b>D</b> –<br>0x004 <b>F</b> | Reserved         | —      | —                               | _     | —       | —        | _     | —       | —        |



# 5.8.7 System Power Management Status and Control 1 Register (SPMSC1)

This high page register contains status and control bits to support the low-voltage detect function, and to enable the bandgap voltage reference for use by the ADC and ACMP modules. This register should be written during the user's reset initialization program to set the desired controls even if the desired settings are the same as the reset settings.



<sup>1</sup> LVWF will be set in the case when  $V_{Supply}$  transitions below the trip point or after reset and  $V_{Supply}$  is already below  $V_{LVW}$ . <sup>2</sup> This bit can be written only one time after reset. Additional writes are ignored.

#### Figure 5-9. System Power Management Status and Control 1 Register (SPMSC1)

| Field       | Description                                                                                                                                                                                                                                                                                            |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>LVWF   | <ul> <li>Low-Voltage Warning Flag — The LVWF bit indicates the low-voltage warning status.</li> <li>0 low-voltage warning is not present.</li> <li>1 low-voltage warning is present or was present.</li> </ul>                                                                                         |
| 6<br>LVWACK | <b>Low-Voltage Warning Acknowledge</b> — If LVWF = 1, a low-voltage condition has occurred. To acknowledge this low-voltage warning, write 1 to LVWACK, which will automatically clear LVWF to 0 if the low-voltage warning is no longer present.                                                      |
| 5<br>LVWIE  | <ul> <li>Low-Voltage Warning Interrupt Enable — This bit enables hardware interrupt requests for LVWF.</li> <li>0 Hardware interrupt disabled (use polling).</li> <li>1 Request a hardware interrupt when LVWF = 1.</li> </ul>                                                                         |
| 4<br>LVDRE  | <ul> <li>Low-Voltage Detect Reset Enable — This write-once bit enables LVD events to generate a hardware reset (provided LVDE = 1).</li> <li>0 LVD events do not generate hardware resets.</li> <li>1 Force an MCU reset when an enabled low-voltage detect event occurs.</li> </ul>                   |
| 3<br>LVDSE  | <ul> <li>Low-Voltage Detect Stop Enable — Provided LVDE = 1, this read/write bit determines whether the low-voltage detect function operates when the MCU is in stop mode.</li> <li>0 Low-voltage detect disabled during stop mode.</li> <li>1 Low-voltage detect enabled during stop mode.</li> </ul> |
| 2<br>LVDE   | <ul> <li>Low-Voltage Detect Enable — This write-once bit enables low-voltage detect logic and qualifies the operation of other bits in this register.</li> <li>0 LVD logic disabled.</li> <li>1 LVD logic enabled.</li> </ul>                                                                          |
| 0<br>BGBE   | <ul> <li>Bandgap Buffer Enable — This bit enables an internal buffer for the bandgap voltage reference for use by the ADC and ACMP modules on one of its internal channels.</li> <li>0 Bandgap buffer disabled.</li> <li>1 Bandgap buffer enabled.</li> </ul>                                          |

#### Table 5-10. SPMSC1 Register Field Descriptions



# Chapter 7 Central Processor Unit (S08CPUV3)

# 7.1 Introduction

This section provides summary information about the registers, addressing modes, and instruction set of the CPU of the HCS08 Family. For a more detailed discussion, refer to the *HCS08 Family Reference Manual, volume 1,* Freescale Semiconductor document order number HCS08RMV1/D.

The HCS08 CPU is fully source- and object-code-compatible with the M68HC08 CPU. Several instructions and enhanced addressing modes were added to improve C compiler efficiency and to support a new background debug system which replaces the monitor mode of earlier M68HC08 microcontrollers (MCU).

### 7.1.1 Features

Features of the HCS08 CPU include:

- Object code fully upward-compatible with M68HC05 and M68HC08 Families
- All registers and memory are mapped to a single 64-Kbyte address space
- 16-bit stack pointer (any size stack anywhere in 64-Kbyte address space)
- 16-bit index register (H:X) with powerful indexed addressing modes
- 8-bit accumulator (A)
- Many instructions treat X as a second general-purpose 8-bit register
- Seven addressing modes:
  - Inherent Operands in internal registers
  - Relative 8-bit signed offset to branch destination
  - Immediate Operand in next object code byte(s)
  - Direct Operand in memory at 0x0000–0x00FF
  - Extended Operand anywhere in 64-Kbyte address space
  - Indexed relative to H:X Five submodes including auto increment
  - Indexed relative to SP Improves C efficiency dramatically
- Memory-to-memory data move instructions with four address mode combinations
- Overflow, half-carry, negative, zero, and carry condition codes support conditional branching on the results of signed, unsigned, and binary-coded decimal (BCD) operations
- Efficient bit manipulation instructions
- Fast 8-bit by 8-bit multiply and 16-bit by 8-bit divide instructions
- STOP and WAIT instructions to invoke low-power operating modes



Chapter 8 Multi-Purpose Clock Generator (S08MCGV1)

- 4. Lastly, FBI transitions into BLPI mode.
  - a) MCGC2 = 0x08 (%00001000)
    - LP (bit 3) in MCGSC is 1







### 8.5.2.3 Example #3: Moving from BLPI to FEE Mode: External Crystal = 4 MHz, Bus Frequency = 16 MHz

In this example, the MCG will move through the proper operational modes from BLPI mode at a 16 kHz bus frequency running off of the internal reference clock (see previous example) to FEE mode using a 4 MHz crystal configured for a 16 MHz bus frequency. First, the code sequence will be described. Then a flowchart will be included which illustrates the sequence.

- 1. First, BLPI must transition to FBI mode.
  - a) MCGC2 = 0x00 (%00000000)
    - LP (bit 3) in MCGSC is 0
  - b) Optionally, loop until LOCK (bit 6) in the MCGSC is set, indicating that the FLL has acquired lock. Although the FLL is bypassed in FBI mode, it is still enabled and running.
- 2. Next, FBI will transition to FEE mode.
  - a) MCGC2 = 0x36 (%00110110)
    - RANGE (bit 5) set to 1 because the frequency of 4 MHz is within the high frequency range
    - HGO (bit 4) set to 1 to configure external oscillator for high gain operation
    - EREFS (bit 2) set to 1, because a crystal is being used
    - ERCLKEN (bit 1) set to 1 to ensure the external reference clock is active
  - b) Loop until OSCINIT (bit 1) in MCGSC is 1, indicating the crystal selected by the EREFS bit has been initialized.
  - c) MCGC1 = 0x38 (%00111000)
    - CLKS (bits 7 and 6) set to %00 in order to select the output of the FLL as system clock source
    - RDIV (bits 5-3) set to %111, or divide-by-128 because 4 MHz / 128 = 31.25 kHz which is in the 31.25 kHz to 39.0625 kHz range required by the FLL
    - IREFS (bit 1) cleared to 0, selecting the external reference clock
  - d) Loop until IREFST (bit 4) in MCGSC is 0, indicating the external reference clock is the current source for the reference clock
  - e) Optionally, loop until LOCK (bit 6) in the MCGSC is set, indicating that the FLL has reacquired lock.
  - f) Loop until CLKST (bits 3 and 2) in MCGSC are %00, indicating that the output of the FLL is selected to feed MCGOUT



#### Chapter 10 Analog-to-Digital Converter (S08ADC12V1)



### Figure 10-3. Status and Control Register (ADCSC1)

### Table 10-3. ADCSC1 Field Descriptions

| Field       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>COCO   | Conversion Complete Flag. The COCO flag is a read-only bit set each time a conversion is completed when the compare function is disabled (ACFE = 0). When the compare function is enabled (ACFE = 1), the COCO flag is set upon completion of a conversion only if the compare result is true. This bit is cleared when ADCSC1 is written or when ADCRL is read.<br>0 Conversion not completed<br>1 Conversion completed                                                                                                                                                                                                                                                                                                 |
| 6<br>AIEN   | Interrupt Enable AIEN enables conversion complete interrupts. When COCO becomes set while AIEN is high,<br>an interrupt is asserted.<br>0 Conversion complete interrupt disabled<br>1 Conversion complete interrupt enabled                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 5<br>ADCO   | <ul> <li>Continuous Conversion Enable. ADCO enables continuous conversions.</li> <li>One conversion following a write to the ADCSC1 when software triggered operation is selected, or one conversion following assertion of ADHWT when hardware triggered operation is selected.</li> <li>Continuous conversions initiated following a write to ADCSC1 when software triggered operation is selected.</li> <li>Continuous conversions are initiated by an ADHWT event when hardware triggered operation is selected.</li> </ul>                                                                                                                                                                                          |
| 4:0<br>ADCH | Input Channel Select. The ADCH bits form a 5-bit field that selects one of the input channels. The input channels are detailed in Table 10-4.<br>The successive approximation converter subsystem is turned off when the channel select bits are all set. This feature allows for explicit disabling of the ADC and isolation of the input channel from all sources. Terminating continuous conversions this way prevents an additional, single conversion from being performed. It is not necessary to set the channel select bits to all ones to place the ADC in a low-power state when continuous conversions are not enabled because the module automatically enters a low-power state when a conversion completes. |

| ADCH        | Input Select      |  |
|-------------|-------------------|--|
| 00000–01111 | AD0–15            |  |
| 10000–11011 | AD16–27           |  |
| 11100       | Reserved          |  |
| 11101       | V <sub>REFH</sub> |  |
| 11110       | V <sub>REFL</sub> |  |
| 11111       | Module disabled   |  |

#### Table 10-4. Input Channel Select



#### Chapter 10 Analog-to-Digital Converter (S08ADC12V1)

used to control the pins associated with channels 0–7 of the ADC module.



### Figure 10-10. Pin Control 1 Register (APCTL1)

### Table 10-10. APCTL1 Register Field Descriptions

| Field      | Description                                                                                                                                                           |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>ADPC7 | ADC Pin Control 7. ADPC7 controls the pin associated with channel AD7.<br>0 AD7 pin I/O control enabled<br>1 AD7 pin I/O control disabled                             |
| 6<br>ADPC6 | ADC Pin Control 6. ADPC6 controls the pin associated with channel AD6.<br>0 AD6 pin I/O control enabled<br>1 AD6 pin I/O control disabled                             |
| 5<br>ADPC5 | <ul><li>ADC Pin Control 5. ADPC5 controls the pin associated with channel AD5.</li><li>0 AD5 pin I/O control enabled</li><li>1 AD5 pin I/O control disabled</li></ul> |
| 4<br>ADPC4 | <ul><li>ADC Pin Control 4. ADPC4 controls the pin associated with channel AD4.</li><li>AD4 pin I/O control enabled</li><li>AD4 pin I/O control disabled</li></ul>     |
| 3<br>ADPC3 | ADC Pin Control 3. ADPC3 controls the pin associated with channel AD3.<br>0 AD3 pin I/O control enabled<br>1 AD3 pin I/O control disabled                             |
| 2<br>ADPC2 | ADC Pin Control 2. ADPC2 controls the pin associated with channel AD2.<br>0 AD2 pin I/O control enabled<br>1 AD2 pin I/O control disabled                             |
| 1<br>ADPC1 | ADC Pin Control 1. ADPC1 controls the pin associated with channel AD1.<br>0 AD1 pin I/O control enabled<br>1 AD1 pin I/O control disabled                             |
| 0<br>ADPC0 | ADC Pin Control 0. ADPC0 controls the pin associated with channel AD0.<br>0 AD0 pin I/O control enabled<br>1 AD0 pin I/O control disabled                             |

## 10.3.9 Pin Control 2 Register (APCTL2)

APCTL2 controls channels 8–15 of the ADC module.



Chapter 11 Inter-Integrated Circuit (S08IICV2)

# 11.7 Initialization/Application Information

| 1  | Write: IIC                                                                                                  | Module Initialization (Slave)                                                  |  |  |  |  |  |  |
|----|-------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------|--|--|--|--|--|--|
| 1. |                                                                                                             | nable or disable general call                                                  |  |  |  |  |  |  |
|    |                                                                                                             | elect 10-bit or 7-bit addressing mode                                          |  |  |  |  |  |  |
| 2  | Write: IIC                                                                                                  | A                                                                              |  |  |  |  |  |  |
|    | — to se                                                                                                     | et the slave address                                                           |  |  |  |  |  |  |
| 3. | Write: IIC                                                                                                  | CC1                                                                            |  |  |  |  |  |  |
|    | — to er                                                                                                     | nable IIC and interrupts                                                       |  |  |  |  |  |  |
| 4. | Initialize                                                                                                  | RAM variables (IICEN = 1 and IICIE = 1) for transmit data                      |  |  |  |  |  |  |
| 5. | Initialize                                                                                                  | RAM variables used to achieve the routine shown in Figure 11-12                |  |  |  |  |  |  |
|    |                                                                                                             |                                                                                |  |  |  |  |  |  |
|    |                                                                                                             |                                                                                |  |  |  |  |  |  |
| 4  | Mrita IIC                                                                                                   | Module Initialization (Master)                                                 |  |  |  |  |  |  |
| 1. | vvrite: IIC                                                                                                 | r<br>At the UC hourd rate (events) are vided in this chanter)                  |  |  |  |  |  |  |
| 2  | Write IIC                                                                                                   |                                                                                |  |  |  |  |  |  |
| ۷. |                                                                                                             | pable IIC and interrupts                                                       |  |  |  |  |  |  |
| 3  | Initialize                                                                                                  | RAM variables (IICEN = 1 and IICIE = 1) for transmit data                      |  |  |  |  |  |  |
| 4. | Initialize                                                                                                  | RAM variables used to achieve the routine shown in Figure 11-12                |  |  |  |  |  |  |
| 5. | Write: IIC                                                                                                  | CC1                                                                            |  |  |  |  |  |  |
|    | — to er                                                                                                     | nable TX                                                                       |  |  |  |  |  |  |
| 6. | Write: IIC                                                                                                  | CC1                                                                            |  |  |  |  |  |  |
|    | — to er                                                                                                     | nable MST (master mode)                                                        |  |  |  |  |  |  |
| 7. | Write: IIC                                                                                                  | D                                                                              |  |  |  |  |  |  |
|    | — with the address of the target slave. (The lsb of this byte determines whether the communication is       |                                                                                |  |  |  |  |  |  |
|    | mas                                                                                                         | ter receive or transmit.)                                                      |  |  |  |  |  |  |
|    | Module Use                                                                                                  |                                                                                |  |  |  |  |  |  |
|    | I ne routine snown in Figure 11-12 can handle both master and slave IIC operations. For slave operation, an |                                                                                |  |  |  |  |  |  |
|    | incoming its message that contains the proper address begins IIC communication. For master operation,       |                                                                                |  |  |  |  |  |  |
|    |                                                                                                             |                                                                                |  |  |  |  |  |  |
|    |                                                                                                             |                                                                                |  |  |  |  |  |  |
|    | Pogiotor Model                                                                                              |                                                                                |  |  |  |  |  |  |
|    |                                                                                                             |                                                                                |  |  |  |  |  |  |
|    | IICA                                                                                                        | AD[7:1] 0                                                                      |  |  |  |  |  |  |
|    |                                                                                                             | When addressed as a alove (in alove made), the medule reasoned to this address |  |  |  |  |  |  |
|    |                                                                                                             | when addressed as a slave (in slave mode), the module responds to this address |  |  |  |  |  |  |
|    | IICF                                                                                                        | MULI                                                                           |  |  |  |  |  |  |
|    |                                                                                                             | Baud rate = BUSCLK / (2 x MULT x (SCL DIVIDER))                                |  |  |  |  |  |  |
|    | IICC1                                                                                                       | IICEN IICIE MST TX TXAK RSTA 0 0                                               |  |  |  |  |  |  |
|    | Module configuration                                                                                        |                                                                                |  |  |  |  |  |  |
|    | IICS TCE IAAS BUSY ARBI O SRW IICIE RXAK                                                                    |                                                                                |  |  |  |  |  |  |
|    | 100                                                                                                         | Module status flags                                                            |  |  |  |  |  |  |
|    | IICD                                                                                                        | DATA                                                                           |  |  |  |  |  |  |
|    |                                                                                                             | Data register; Write to transmit IIC data read to read IIC data                |  |  |  |  |  |  |
|    |                                                                                                             |                                                                                |  |  |  |  |  |  |
|    | 11002                                                                                                       | Address configuration                                                          |  |  |  |  |  |  |
|    |                                                                                                             |                                                                                |  |  |  |  |  |  |

Figure 11-11. IIC Module Quick Start



# Chapter 12 Freescale Controller Area Network (S08MSCANV1)

# 12.1 Introduction

The Freescale controller area network (MSCAN) is a communication controller implementing the CAN 2.0A/B protocol as defined in the Bosch specification dated September 1991. To fully understand the MSCAN specification, it is recommended that the Bosch specification be read first to gain familiarity with the terms and concepts contained within this document.

Though not exclusively intended for automotive applications, CAN protocol is designed to meet the specific requirements of a vehicle serial data bus: real-time processing, reliable operation in the EMI environment of a vehicle, cost-effectiveness, and required bandwidth.

MSCAN uses an advanced buffer arrangement resulting in predictable real-time behavior and simplified application software.

The MSCAN module is available in all devices in the MC9S08DV60 Series.

Chapter 12 Freescale's Controller Area Network (S08MSCANV1)



### 12.1.1 Features

The basic features of the MSCAN are as follows:

- Implementation of the CAN protocol Version 2.0A/B
  - Standard and extended data frames
  - Zero to eight bytes data length
  - Programmable bit rate up to  $1 \text{ Mbps}^1$
  - Support for remote frames
- Five receive buffers with FIFO storage scheme
- Three transmit buffers with internal prioritization using a "local priority" concept
- Flexible maskable identifier filter supports two full-size (32-bit) extended identifier filters, or four 16-bit filters, or eight 8-bit filters
- Programmable wakeup functionality with integrated low-pass filter
- Programmable loopback mode supports self-test operation
- Programmable listen-only mode for monitoring of CAN bus
- Programmable bus-off recovery functionality
- Separate signalling and interrupt capabilities for all CAN receiver and transmitter error states (warning, error passive, bus-off)
- Programmable MSCAN clock source either bus clock or oscillator clock
- Internal timer for time-stamping of received and transmitted messages
- Three low-power modes: sleep, power down, and MSCAN enable
- Global initialization of configuration registers

### 12.1.2 Modes of Operation

The following modes of operation are specific to the MSCAN. See Section 12.5, "Functional Description," for details.

- Listen-Only Mode
- MSCAN Sleep Mode
- MSCAN Initialization Mode
- MSCAN Power Down Mode
- Loopback Self Test Mode

<sup>1.</sup> Depending on the actual bit timing and the clock jitter of the PLL.



Chapter 12 Freescale's Controller Area Network (S08MSCANV1)

# 12.5.2 Message Storage



Figure 12-38. User Model for Message Buffer Organization

MSCAN facilitates a sophisticated message storage system which addresses the requirements of a broad range of network applications.



Chapter 13 Serial Peripheral Interface (S08SPIV3)



# 13.2 External Signal Description

The SPI optionally shares four port pins. The function of these pins depends on the settings of SPI control bits. When the SPI is disabled (SPE = 0), these four pins revert to being general-purpose port I/O pins that are not controlled by the SPI.

### 13.2.1 SPSCK — SPI Serial Clock

When the SPI is enabled as a slave, this pin is the serial clock input. When the SPI is enabled as a master, this pin is the serial clock output.

### 13.2.2 MOSI — Master Data Out, Slave Data In

When the SPI is enabled as a master and SPI pin control zero (SPC0) is 0 (not bidirectional mode), this pin is the serial data output. When the SPI is enabled as a slave and SPC0 = 0, this pin is the serial data input. If SPC0 = 1 to select single-wire bidirectional mode, and master mode is selected, this pin becomes the bidirectional data I/O pin (MOMI). Also, the bidirectional mode output enable bit determines whether the pin acts as an input (BIDIROE = 0) or an output (BIDIROE = 1). If SPC0 = 1 and slave mode is selected, this pin is not used by the SPI and reverts to being a general-purpose port I/O pin.

## 13.2.3 MISO — Master Data In, Slave Data Out

When the SPI is enabled as a master and SPI pin control zero (SPC0) is 0 (not bidirectional mode), this pin is the serial data input. When the SPI is enabled as a slave and SPC0 = 0, this pin is the serial data output. If SPC0 = 1 to select single-wire bidirectional mode, and slave mode is selected, this pin becomes the bidirectional data I/O pin (SISO) and the bidirectional mode output enable bit determines whether the pin acts as an input (BIDIROE = 0) or an output (BIDIROE = 1). If SPC0 = 1 and master mode is selected, this pin is not used by the SPI and reverts to being a general-purpose port I/O pin.

# 13.2.4 SS — Slave Select

When the SPI is enabled as a slave, this pin is the low-true slave select input. When the SPI is enabled as a master and mode fault enable is off (MODFEN = 0), this pin is not used by the SPI and reverts to being a general-purpose port I/O pin. When the SPI is enabled as a master and MODFEN = 1, the slave select output enable bit determines whether this pin acts as the mode fault input (SSOE = 0) or as the slave select output (SSOE = 1).



Chapter 13 Serial Peripheral Interface (S08SPIV3)

Chapter 14 Serial Communications Interface (S08SCIV4)



o - VDD and VSS pins are each internally connected to two pads in 32-pin package

Figure 14-1. MC9S08DV60 Block Diagram



Chapter 15 Real-Time Counter (S08RTCV1)

| Table 16-5. | TPMxCnSC | Field | Descriptions | (continued) |
|-------------|----------|-------|--------------|-------------|
|-------------|----------|-------|--------------|-------------|

| Field                 | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4<br>MSnA             | <ul> <li>Mode select A for TPM channel n. When CPWMS=0 and MSnB=0, MSnA configures TPM channel n for input-capture mode or output compare mode. Refer to Table 16-6 for a summary of channel mode and setup controls.</li> <li>Note: If the associated port pin is not stable for at least two bus clock cycles before changing to input capture mode, it is possible to get an unexpected indication of an edge trigger.</li> </ul>                                                                                                                                                                                                                                                                                                  |
| 3–2<br>ELSnB<br>ELSnA | Edge/level select bits. Depending upon the operating mode for the timer channel as set by CPWMS:MSnB:MSnA and shown in Table 16-6, these bits select the polarity of the input edge that triggers an input capture event, select the level that will be driven in response to an output compare match, or select the polarity of the PWM output. Setting ELSnB:ELSnA to 0:0 configures the related timer pin as a general purpose I/O pin not related to any timer functions. This function is typically used to temporarily disable an input capture channel or to make the timer pin available as a general purpose I/O pin when the associated timer channel is set up as a software timer that does not require the use of a pin. |

| CPWMS | MSnB:MSnA | ELSnB:ELSnA | Mode Configuration                 |                                                  |
|-------|-----------|-------------|------------------------------------|--------------------------------------------------|
| Х     | XX        | 00          | Pin not used for<br>purpose I/O or | TPM - revert to general other peripheral control |
| 0     | 00        | 01          | Input capture                      | Capture on rising edge<br>only                   |
|       |           | 10          |                                    | Capture on falling edge only                     |
|       |           | 11          |                                    | Capture on rising or<br>falling edge             |
|       | 01        | 01          | Output compare                     | Toggle output on<br>compare                      |
|       |           | 10          |                                    | Clear output on<br>compare                       |
|       |           | 11          |                                    | Set output on compare                            |
|       | 1X        | 10          | Edge-aligned<br>PWM                | High-true pulses (clear<br>output on compare)    |
|       |           | X1          |                                    | Low-true pulses (set output on compare)          |
| 1     | XX        | 10          | Center-aligned<br>PWM              | High-true pulses (clear<br>output on compare-up) |
|       |           | X1          |                                    | Low-true pulses (set output on compare-up)       |

Table 16-6. Mode, Edge, and Level Selection

## 16.3.5 TPM Channel Value Registers (TPMxCnVH:TPMxCnVL)

These read/write registers contain the captured TPM counter value of the input capture function or the output compare value for the output compare or PWM functions. The channel registers are cleared by reset.



### 17.3.6 Hardware Breakpoints

The BRKEN control bit in the DBGC register may be set to 1 to allow any of the trigger conditions described in Section 17.3.5, "Trigger Modes," to be used to generate a hardware breakpoint request to the CPU. TAG in DBGC controls whether the breakpoint request will be treated as a tag-type breakpoint or a force-type breakpoint. A tag breakpoint causes the current opcode to be marked as it enters the instruction queue. If a tagged opcode reaches the end of the pipe, the CPU executes a BGND instruction to go to active background mode rather than executing the tagged opcode. A force-type breakpoint causes the CPU to finish the current instruction and then go to active background mode.

If the background mode has not been enabled (ENBDM = 1) by a serial WRITE\_CONTROL command through the BKGD pin, the CPU will execute an SWI instruction instead of going to active background mode.

## 17.4 Register Definition

This section contains the descriptions of the BDC and DBG registers and control bits.

Refer to the high-page register summary in the device overview chapter of this data sheet for the absolute address assignments for all DBG registers. This section refers to registers and control bits only by their names. A Freescale-provided equate or header file is used to translate these names into the appropriate absolute addresses.

### 17.4.1 BDC Registers and Control Bits

The BDC has two registers:

- The BDC status and control register (BDCSCR) is an 8-bit register containing control and status bits for the background debug controller.
- The BDC breakpoint match register (BDCBKPT) holds a 16-bit breakpoint match address.

These registers are accessed with dedicated serial BDC commands and are not located in the memory space of the target MCU (so they do not have addresses and cannot be accessed by user programs).

Some of the bits in the BDCSCR have write limitations; otherwise, these registers may be read or written at any time. For example, the ENBDM control bit may not be written while the MCU is in active background mode. (This prevents the ambiguous condition of the control bit forbidding active background mode while the MCU is already in active background mode.) Also, the four status bits (BDMACT, WS, WSF, and DVF) are read-only status indicators and can never be written by the WRITE\_CONTROL serial BDC command. The clock switch (CLKSW) control bit may be read or written at any time.







SECTION F-F Rotated 90°CW 32 places



| © FREESCALE SEMICONDUCTOR, INC.<br>All rights reserved. |                                 | L OUTLINE       | PRINT VERSION NE | IT TO SCALE |
|---------------------------------------------------------|---------------------------------|-----------------|------------------|-------------|
| TITLE:                                                  | DOCUMENT NE                     | ]: 98ASH70029A  | RE∨: D           |             |
| LOW PROFILE QUAD FLAT PA                                | CASE NUMBER: 873A-03 19 MAY 200 |                 |                  |             |
| 32 LEAD, 0.8 PITCH (7 X                                 | STANDARD: JE                    | IDEC MS-026 BBA |                  |             |

DETAIL G