

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

E·XFI

| 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              | 25                                                          |
| Program Memory Size        | 16КВ (16К х 8)                                              |
| Program Memory Type        | FLASH                                                       |
| EEPROM Size                | -                                                           |
| RAM Size                   | 1K x 8                                                      |
| Voltage - Supply (Vcc/Vdd) | 2.7V ~ 5.5V                                                 |
| Data Converters            | A/D 10x12b                                                  |
| Oscillator Type            | External                                                    |
| Operating Temperature      | -40°C ~ 125°C (TA)                                          |
| Mounting Type              | Surface Mount                                               |
| Package / Case             | 32-LQFP                                                     |
| Supplier Device Package    | 32-LQFP (7x7)                                               |
| Purchase URL               | https://www.e-xfl.com/pro/item?MUrl=&PartUrl=mc9s08dv16amlc |

Email: info@E-XFL.COM

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



Chapter 1 Device Overview

<sup>1</sup> ACMP2O is not available.

# 1.2 MCU Block Diagram

Figure 1-1 is the MC9S08DV60 Series system-level block diagram.



To maintain I/O states for pins that were configured as general-purpose I/O before entering stop2, the user must restore the contents of the I/O port registers, which have been saved in RAM, to the port registers before writing to the PPDACK bit. If the port registers are not restored from RAM before writing to PPDACK, then the pins will switch to their reset states when PPDACK is written.

For pins that were configured as peripheral I/O, the user must reconfigure the peripheral module that interfaces to the pin before writing to the PPDACK bit. If the peripheral module is not enabled before writing to PPDACK, the pins will be controlled by their associated port control registers when the I/O latches are opened.

## 3.6.3 On-Chip Peripheral Modules in Stop Modes

When the MCU enters any stop mode, system clocks to the internal peripheral modules are stopped. Even in the exception case (ENBDM = 1), where clocks to the background debug logic continue to operate, clocks to the peripheral systems are halted to reduce power consumption. Refer to Section 3.6.2, "Stop2 Mode" and Section 3.6.1, "Stop3 Mode" for specific information on system behavior in stop modes.

| Poriphoral              | Мс                         | ode                        |
|-------------------------|----------------------------|----------------------------|
| renpilerai              | Stop2                      | Stop3                      |
| CPU                     | Off                        | Standby                    |
| RAM                     | Standby                    | Standby                    |
| Flash                   | Off                        | Standby                    |
| Parallel Port Registers | Off                        | Standby                    |
| ACMP                    | Off                        | Off                        |
| ADC                     | Off                        | Optionally On <sup>1</sup> |
| IIC                     | Off                        | Standby                    |
| MCG                     | Off                        | Optionally On <sup>2</sup> |
| MSCAN                   | Off                        | Standby                    |
| RTC                     | Optionally On <sup>3</sup> | Optionally On <sup>3</sup> |
| SCI                     | Off                        | Standby                    |
| SPI                     | Off                        | Standby                    |
| ТРМ                     | Off                        | Standby                    |
| Voltage Regulator       | Off                        | Optionally On <sup>4</sup> |
| XOSC                    | Off                        | Optionally On <sup>5</sup> |
| I/O Pins                | States Held                | States Held                |
| BDM                     | Off <sup>6</sup>           | Optionally On              |
| LVD/LVW                 | Off <sup>7</sup>           | Optionally On              |

<sup>1</sup> Requires the asynchronous ADC clock and LVD to be enabled, else in standby.

<sup>2</sup> IRCLKEN and IREFSTEN set in MCGC1, else in standby.

<sup>3</sup> Requires the RTC to be enabled, else in standby.

<sup>4</sup> Requires the LVD or BDC to be enabled.



#### Chapter 3 Modes of Operation

- <sup>5</sup> ERCLKEN and EREFSTEN set in MCGC2 for, else in standby. For high frequency range (RANGE in MCGC2 set) requires the LVD to also be enabled in stop3.
- <sup>6</sup> If ENBDM is set when entering stop2, the MCU will actually enter stop3.
- <sup>7</sup> If LVDSE is set when entering stop2, the MCU will actually enter stop3.



# 4.5.7 Block Protection

The block protection feature prevents the protected region of Flash from program or erase changes. Block protection is controlled through the Flash protection register (FPROT). The FPS bits determine the protected region of Flash. See Section 4.5.10.4, "Flash Protection Register (FPROT and NVPROT)."

After exit from reset, FPROT is loaded with the contents of the NVPROT location, which is in the nonvolatile register block of the Flash memory. Any FPROT write that attempts to decrease the size of the protected region will be ignored. Because NVPROT is within the last sector of Flash, if any amount of memory is protected, NVPROT is itself protected and cannot be unprotected (intentionally or unintentionally) by the application software. FPROT can be written through background debug commands, which provides a way to erase and reprogram protected Flash memory.

One use for block protection is to block protect an area of Flash memory for a bootloader program. this bootloader program can call a routine outside of Flash that can be used to sector erase the rest of the Flash memory and reprogram it. The bootloader is protected even if MCU power is lost during an erase and reprogram operation.

# 4.5.8 Vector Redirection

While any Flash is block protected, 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 0. For redirection to occur, at least some portion of the Flash memory must be block protected by programming the NVPROT register located at address 0xFFBD. All interrupt vectors (memory locations 0xFFC0–0xFFFD) are redirected, though the reset vector (0xFFFE:0xFFFF) is not.

For example, if 1536 bytes of Flash are protected, the protected address region is from 0xFA00 through 0xFFFF. The interrupt vectors (0xFFC0–0xFFFD) are redirected to the locations 0xF9C0–0xF9FD. If vector redirection is enabled and an interrupt occurs, the values in the locations 0xF9E0:0xF9E1 are used for the vector instead of the values in the locations 0xFFE0:0xFFE1. 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.5.9 Security

The MC9S08DV60 Series 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 register bits (SEC[1:0]) 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 performed at the same time the Flash memory is programmed. The 1:0 state disengages



An output pin can be selected to have high output drive strength by setting the corresponding bit in the drive strength select register (PTxDSn). When high drive is selected, a pin is capable of sourcing and sinking greater current. Even though every I/O pin can be selected as high drive, the user must ensure that the total current source and sink limits for the MCU are not exceeded. Drive strength selection is intended to affect the DC behavior of I/O pins. However, the AC behavior is also affected. High drive allows a pin to drive a greater load with the same switching speed as a low drive enabled pin into a smaller load. Because of this, the EMC emissions may be affected by enabling pins as high drive.

# 6.3 Pin Interrupts

Port A, port B, and port D pins can be configured as external interrupt inputs and as an external means of waking the MCU from stop or wait low-power modes.



The block diagram for each port interrupt logic is shown Figure 6-2.

Figure 6-2. Port Interrupt Block Diagram

Writing to the PTxPSn bits in the port interrupt pin select register (PTxPS) independently enables or disables each port pin. Each port can be configured as edge sensitive or edge and level sensitive based on the PTxMOD bit in the port interrupt status and control register (PTxSC). Edge sensitivity can be software programmed to be either falling or rising; the level can be either low or high. The polarity of the edge or edge and level sensitivity is selected using the PTxESn bits in the port interrupt edge select register (PTxSC).

Synchronous logic is used to detect edges. Prior to detecting an edge, enabled port inputs must be at the deasserted logic level. A falling edge is detected when an enabled port input signal is seen as a logic 1 (the deasserted level) during one bus cycle and then a logic 0 (the asserted level) during the next cycle. A rising edge is detected when the input signal is seen as a logic 0 during one bus cycle and then a logic 1 during the next cycle.

# 6.3.1 Edge Only Sensitivity

A valid edge on an enabled port pin will set PTxIF in PTxSC. If PTxIE in PTxSC is set, an interrupt request will be presented to the CPU. Clearing of PTxIF is accomplished by writing a 1 to PTxACK in PTxSC.

## 6.5.6.3 Port F Pull Enable Register (PTFPE)



Figure 6-39. Internal Pull Enable for Port F Register (PTFPE)

#### Table 6-37. PTFPE Register Field Descriptions

| Field      | Description                                                                                                       |
|------------|-------------------------------------------------------------------------------------------------------------------|
| 7:0        | Internal Pull Enable for Port F Bits — Each of these control bits determines if the internal pull-up device is    |
| PTFPE[7:0] | enabled for the associated PTF pin. For port F pins that are configured as outputs, these bits have no effect and |
|            | the internal pull devices are disabled.                                                                           |
|            | 0 Internal pull-up device disabled for port F bit n.                                                              |
|            | 1 Internal pull-up device enabled for port F bit n.                                                               |

### NOTE

Pull-down devices only apply when using pin interrupt functions, when corresponding edge select and pin select functions are configured.

### 6.5.6.4 Port F Slew Rate Enable Register (PTFSE)

| _      | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|
| R<br>W | PTFSE7 | PTFSE6 | PTFSE5 | PTFSE4 | PTFSE3 | PTFSE2 | PTFSE1 | PTFSE0 |
| Reset: | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |

Figure 6-40. Slew Rate Enable for Port F Register (PTFSE)

#### Table 6-38. PTFSE Register Field Descriptions

| Field             | Description                                                                                                                                                                                                                                                                                                                                                                   |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0<br>PTFSE[7:0] | <ul> <li>Output Slew Rate Enable for Port F Bits — Each of these control bits determines if the output slew rate control is enabled for the associated PTF pin. For port F pins that are configured as inputs, these bits have no effect.</li> <li>Output slew rate control disabled for port F bit n.</li> <li>Output slew rate control enabled for port F bit n.</li> </ul> |

**Note:** Slew rate reset default values may differ between engineering samples and final production parts. Always initialize slew rate control to the desired value to ensure correct operation.



| Source Operation                                                                                                |                                                                                                                                                                                                                                                                                                                                                                                                    | dress<br>lode                                       | Object Code                                                                      | /cles                           | Cyc-by-Cyc                                       | Affect<br>on CCR      |           |  |
|-----------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------|----------------------------------------------------------------------------------|---------------------------------|--------------------------------------------------|-----------------------|-----------|--|
|                                                                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                    | PΑ                                                  |                                                                                  | ΰ                               | Dotano                                           | <b>V</b> 1 1 <b>H</b> | INZC      |  |
| SUB #opr8i<br>SUB opr8a<br>SUB opr16a<br>SUB oprx16,X<br>SUB oprx8,X<br>SUB ,X<br>SUB oprx16,SP<br>SUB oprx8,SP | Subtract<br>A $\leftarrow$ (A) – (M)                                                                                                                                                                                                                                                                                                                                                               | IMM<br>DIR<br>EXT<br>IX2<br>IX1<br>IX<br>SP2<br>SP1 | A0 ii<br>B0 dd<br>C0 hh ll<br>D0 ee ff<br>E0 ff<br>F0<br>9E D0 ee ff<br>9E E0 ff | 2<br>3<br>4<br>3<br>3<br>5<br>4 | pp<br>rpp<br>prpp<br>rpp<br>rfp<br>pprpp<br>prpp | ↓11-                  | - ↓ ↓ ↓   |  |
| SWI                                                                                                             | Software Interrupt<br>PC $\leftarrow$ (PC) + \$0001<br>Push (PCL); SP $\leftarrow$ (SP) - \$0001<br>Push (PCH); SP $\leftarrow$ (SP) - \$0001<br>Push (X); SP $\leftarrow$ (SP) - \$0001<br>Push (A); SP $\leftarrow$ (SP) - \$0001<br>Push (CCR); SP $\leftarrow$ (SP) - \$0001<br>I $\leftarrow$ 1;<br>PCH $\leftarrow$ Interrupt Vector High Byte<br>PCL $\leftarrow$ Interrupt Vector Low Byte | INH                                                 | 83                                                                               | 11                              | sssssvvfppp                                      | - 1 1 -               | 1         |  |
| ТАР                                                                                                             | Transfer Accumulator to CCR $CCR \leftarrow (A)$                                                                                                                                                                                                                                                                                                                                                   | INH                                                 | 84                                                                               | 1                               | р                                                | \$11\$                | ¢ ¢ ¢ ¢ ¢ |  |
| ТАХ                                                                                                             | Transfer Accumulator to X (Index Register Low) $X \leftarrow (A)$                                                                                                                                                                                                                                                                                                                                  | INH                                                 | 97                                                                               | 1                               | р                                                | - 1 1 -               |           |  |
| ТРА                                                                                                             | Transfer CCR to Accumulator $A \leftarrow (CCR)$                                                                                                                                                                                                                                                                                                                                                   | INH                                                 | 85                                                                               | 1                               | q                                                | - 1 1 -               |           |  |
| TST opr8a<br>TSTA<br>TSTX<br>TST oprx8,X<br>TST oprx8,SP                                                        | Test for Negative or Zero<br>(M) - \$00<br>(A) - \$00<br>(X) - \$00<br>(M) - \$00<br>(M) - \$00<br>(M) - \$00<br>(M) - \$00                                                                                                                                                                                                                                                                        | DIR<br>INH<br>INH<br>IX1<br>IX<br>SP1               | 3D dd<br>4D<br>5D<br>6D ff<br>7D<br>9E 6D ff                                     | 4<br>1<br>4<br>3<br>5           | rfpp<br>p<br>rfpp<br>rfp<br>prfpp                | 011-                  | - \$ \$ - |  |
| TSX                                                                                                             | Transfer SP to Index Reg.<br>H:X $\leftarrow$ (SP) + \$0001                                                                                                                                                                                                                                                                                                                                        | INH                                                 | 95                                                                               | 2                               | fp                                               | - 1 1 -               |           |  |
| ТХА                                                                                                             | Transfer X (Index Reg. Low) to Accumulator $A \leftarrow (X)$                                                                                                                                                                                                                                                                                                                                      | INH                                                 | 9F                                                                               | 1                               | q                                                | - 1 1 -               |           |  |

### Table 7-2. Instruction Set Summary (Sheet 8 of 9)



# 8.3.4 MCG Status and Control Register (MCGSC)



Figure 8-6. MCG Status and Control Register (MCGSC)

| Field        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|--------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>LOLS    | <ul> <li>Loss of Lock Status — This bit is a sticky indication of lock status for the FLL or PLL. LOLS is set when lock detection is enabled and after acquiring lock, the FLL or PLL output frequency has fallen outside the lock exit frequency tolerance, D<sub>unl</sub>. LOLIE determines whether an interrupt request is made when set. LOLS is cleared by reset or by writing a logic 1 to LOLS when LOLS is set. Writing a logic 0 to LOLS has no effect.</li> <li>0 FLL or PLL has not lost lock since LOLS was last cleared.</li> <li>1 FLL or PLL has lost lock since LOLS was last cleared.</li> </ul>                                                                                                                                                                                                                                                                                                                             |
| 6<br>LOCK    | Lock Status — Indicates whether the FLL or PLL has acquired lock. Lock detection is disabled when both the FLL and PLL are disabled. If the lock status bit is set then changing the value of any of the following bits IREFS, PLLS, RDIV[2:0], TRIM[7:0] (if in FEI or FBI modes), or VDIV[3:0] (if in PBE or PEE modes), will cause the lock status bit to clear and stay cleared until the FLL or PLL has reacquired lock. Stop mode entry will also cause the lock status bit to clear and stay cleared until the FLL or PLL has reacquired lock. Entry into BLPI or BLPE mode will also cause the lock status bit to clear and stay cleared until the FLL or PLL has reacquired lock. Entry into BLPI or BLPE mode will also cause the lock status bit to clear and stay cleared until the MCG has exited these modes and the FLL or PLL has reacquired lock.<br>0 FLL or PLL is currently unlocked.<br>1 FLL or PLL is currently locked. |
| 5<br>PLLST   | <ul> <li>PLL Select Status — The PLLST bit indicates the current source for the PLLS clock. The PLLST bit does not update immediately after a write to the PLLS bit due to internal synchronization between clock domains.</li> <li>0 Source of PLLS clock is FLL clock.</li> <li>1 Source of PLLS clock is PLL clock.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 4<br>IREFST  | <ul> <li>Internal Reference Status — The IREFST bit indicates the current source for the reference clock. The IREFST bit does not update immediately after a write to the IREFS bit due to internal synchronization between clock domains.</li> <li>0 Source of reference clock is external reference clock (oscillator or external clock source as determined by the EREFS bit in the MCGC2 register).</li> <li>1 Source of reference clock is internal reference clock.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| 3:2<br>CLKST | <ul> <li>Clock Mode Status — The CLKST bits indicate the current clock mode. The CLKST bits do not update immediately after a write to the CLKS bits due to internal synchronization between clock domains.</li> <li>00 Encoding 0 — Output of FLL is selected.</li> <li>01 Encoding 1 — Internal reference clock is selected.</li> <li>10 Encoding 2 — External reference clock is selected.</li> <li>11 Encoding 3 — Output of PLL is selected.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |

MC9S08DV60 Series Data Sheet, Rev 3



### 9.1.2 Features

The ACMP has the following features:

- Full rail to rail supply operation.
- Selectable interrupt on rising edge, falling edge, or either rising or falling edges of comparator output.
- Option to compare to fixed internal bandgap reference voltage.
- Option to allow comparator output to be visible on a pin, ACMPxO.

### 9.1.3 Modes of Operation

This section defines the ACMP operation in wait, stop, and background debug modes.

### 9.1.3.1 ACMP in Wait Mode

The ACMP continues to run in wait mode if enabled before executing the appropriate instruction. Therefore, the ACMP can be used to bring the MCU out of wait mode if the ACMP interrupt is enabled (ACIE is set). For lowest possible current consumption, the ACMP should be disabled by software if not required as an interrupt source during wait mode.

### 9.1.3.2 ACMP in Stop Modes

The ACMP is disabled in all stop modes, regardless of the settings before executing the stop instruction. Therefore, the ACMP cannot be used as a wake up source from stop modes.

During stop2 mode, the ACMP module is fully powered down. Upon wake-up from stop2 mode, the ACMP module is in the reset state.

During stop3 mode, clocks to the ACMP module are halted. No registers are affected. In addition, the ACMP comparator circuit enters a low-power state. No compare operation occurs while in stop3.

If stop3 is exited with a reset, the ACMP is put into its reset state. If stop3 is exited with an interrupt, the ACMP continues from the state it was in when stop3 was entered.

### 9.1.3.3 ACMP in Active Background Mode

When the microcontroller is in active background mode, the ACMP continues to operate normally.



## 11.1.1 Features

The IIC includes these distinctive features:

- Compatible with IIC bus standard
- Multi-master operation
- Software programmable for one of 64 different serial clock frequencies
- Software selectable acknowledge bit
- Interrupt driven byte-by-byte data transfer
- Arbitration lost interrupt with automatic mode switching from master to slave
- Calling address identification interrupt
- Start and stop signal generation/detection
- Repeated start signal generation
- Acknowledge bit generation/detection
- Bus busy detection
- General call recognition
- 10-bit address extension

### 11.1.2 Modes of Operation

A brief description of the IIC in the various MCU modes is given here.

- **Run mode** This is the basic mode of operation. To conserve power in this mode, disable the module.
- **Wait mode** The module continues to operate while the MCU is in wait mode and can provide a wake-up interrupt.
- **Stop mode** The IIC is inactive in stop3 mode for reduced power consumption. The stop instruction does not affect IIC register states. Stop2 resets the register contents.



#### Chapter 11 Inter-Integrated Circuit (S08IICV2)

the transition from master to slave mode does not generate a stop condition. Meanwhile, a status bit is set by hardware to indicate loss of arbitration.

## 11.4.1.7 Clock Synchronization

Because wire-AND logic is performed on the SCL line, a high-to-low transition on the SCL line affects all the devices connected on the bus. The devices start counting their low period and after a device's clock has gone low, it holds the SCL line low until the clock high state is reached. However, the change of low to high in this device clock may not change the state of the SCL line if another device clock is still within its low period. Therefore, synchronized clock SCL is held low by the device with the longest low period. Devices with shorter low periods enter a high wait state during this time (see Figure 11-10). When all devices concerned have counted off their low period, the synchronized clock SCL line is released and pulled high. There is then no difference between the device clocks and the state of the SCL line and all the devices start counting their high periods. The first device to complete its high period pulls the SCL line low again.



### 11.4.1.8 Handshaking

The clock synchronization mechanism can be used as a handshake in data transfer. Slave devices may hold the SCL low after completion of one byte transfer (9 bits). In such a case, it halts the bus clock and forces the master clock into wait states until the slave releases the SCL line.

### 11.4.1.9 Clock Stretching

The clock synchronization mechanism can be used by slaves to slow down the bit rate of a transfer. After the master has driven SCL low the slave can drive SCL low for the required period and then release it. If the slave SCL low period is greater than the master SCL low period then the resulting SCL bus signal low period is stretched.



# 12.3.14 MSCAN Transmit Error Counter (CANTXERR)

This register reflects the status of the MSCAN transmit error counter.





Read: Only when in sleep mode (SLPRQ = 1 and SLPAK = 1) or initialization mode (INITRQ = 1 and INITAK = 1)

Write: Unimplemented

### NOTE

Reading this register when in any other mode other than sleep or initialization mode, may return an incorrect value. For MCUs with dual CPUs, this may result in a CPU fault condition.

Writing to this register when in special modes can alter the MSCAN functionality.

## 12.3.15 MSCAN Identifier Acceptance Registers (CANIDAR0-7)

On reception, each message is written into the background receive buffer. The CPU is only signalled to read the message if it passes the criteria in the identifier acceptance and identifier mask registers (accepted); otherwise, the message is overwritten by the next message (dropped).

The acceptance registers of the MSCAN are applied on the IDR0–IDR3 registers (see Section 12.4.1, "Identifier Registers (IDR0–IDR3)") of incoming messages in a bit by bit manner (see Section 12.5.3, "Identifier Acceptance Filter").

For extended identifiers, all four acceptance and mask registers are applied. For standard identifiers, only the first two (CANIDAR0/1, CANIDMR0/1) are applied.

|        | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|--------|-----|-----|-----|-----|-----|-----|-----|-----|
| R<br>W | AC7 | AC6 | AC5 | AC4 | AC3 | AC2 | AC1 | AC0 |
| Reset  | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

Figure 12-19. MSCAN Identifier Acceptance Registers (First Bank) — CANIDAR0–CANIDAR3

Read: Anytime

Write: Anytime in initialization mode (INITRQ = 1 and INITAK = 1)



Chapter 13 Serial Peripheral Interface (S08SPIV3)



Figure 13-3. SPI Module Block Diagram

## 13.1.3 SPI Baud Rate Generation

As shown in Figure 13-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.

| Chapter 15 Real-Time Counter (S08RTCV1) |      |      |      |      |      |      |  |  |  |  |  |  |
|-----------------------------------------|------|------|------|------|------|------|--|--|--|--|--|--|
| Internal 1-kHz<br>Clock Source          |      |      |      |      |      |      |  |  |  |  |  |  |
| RTC Clock<br>(RTCPS = 0xA)              |      |      |      |      |      |      |  |  |  |  |  |  |
| RTCCNT                                  | 0x52 | 0x53 | 0x54 | 0x55 | 0x00 | 0x01 |  |  |  |  |  |  |
|                                         |      |      |      |      |      |      |  |  |  |  |  |  |
| RTIF                                    |      |      |      |      |      |      |  |  |  |  |  |  |
| 570105                                  | [    |      |      |      |      | 1    |  |  |  |  |  |  |
| RICMOD                                  |      |      | 0x   | 55   |      |      |  |  |  |  |  |  |

Figure 15-6. RTC Counter Overflow Example

In the example of Figure 15-6, the selected clock source is the 1-kHz internal oscillator clock source. The prescaler (RTCPS) is set to 0xA or divide-by-4. The modulo value in the RTCMOD register is set to 0x55. When the counter, RTCCNT, reaches the modulo value of 0x55, the counter overflows to 0x00 and continues counting. The real-time interrupt flag, RTIF, sets when the counter value changes from 0x55 to 0x00. A real-time interrupt is generated when RTIF is set, if RTIE is set.

# 15.5 Initialization/Application Information

This section provides example code to give some basic direction to a user on how to initialize and configure the RTC module. The example software is implemented in C language.

The example below shows how to implement time of day with the RTC using the 1-kHz clock source to achieve the lowest possible power consumption. Because the 1-kHz clock source is not as accurate as a crystal, software can be added for any adjustments. For accuracy without adjustments at the expense of additional power consumption, the external clock (ERCLK) or the internal clock (IRCLK) can be selected with appropriate prescaler and modulo values.



## 16.2.1.1 EXTCLK — External Clock Source

Control bits in the timer status and control register allow the user to select nothing (timer disable), the bus-rate clock (the normal default source), a crystal-related clock, or an external clock as the clock which drives the TPM prescaler and subsequently the 16-bit TPM counter. The external clock source is synchronized in the TPM. The bus clock clocks the synchronizer; the frequency of the external source must be no more than one-fourth the frequency of the bus-rate clock, to meet Nyquist criteria and allowing for jitter.

The external clock signal shares the same pin as a channel I/O pin, so the channel pin will not be usable for channel I/O function when selected as the external clock source. It is the user's responsibility to avoid such settings. If this pin is used as an external clock source (CLKSB:CLKSA = 1:1), the channel can still be used in output compare mode as a software timer (ELSnB:ELSnA = 0:0).

## 16.2.1.2 TPMxCHn — TPM Channel n I/O Pin(s)

Each TPM channel is associated with an I/O pin on the MCU. The function of this pin depends on the channel configuration. The TPM pins share with general purpose I/O pins, where each pin has a port data register bit, and a data direction control bit, and the port has optional passive pullups which may be enabled whenever a port pin is acting as an input.

The TPM channel does not control the I/O pin when (ELSnB:ELSnA = 0:0) or when (CLKSB:CLKSA = 0:0) so it normally reverts to general purpose I/O control. When CPWMS = 1 (and ELSnB:ELSnA not = 0:0), all channels within the TPM are configured for center-aligned PWM and the TPMxCHn pins are all controlled by the TPM system. When CPWMS=0, the MSnB:MSnA control bits determine whether the channel is configured for input capture, output compare, or edge-aligned PWM.

When a channel is configured for input capture (CPWMS=0, MSnB:MSnA = 0:0 and ELSnB:ELSnA not = 0:0), the TPMxCHn pin is forced to act as an edge-sensitive input to the TPM. ELSnB:ELSnA control bits determine what polarity edge or edges will trigger input-capture events. A synchronizer based on the bus clock is used to synchronize input edges to the bus clock. This implies the minimum pulse width—that can be reliably detected—on an input capture pin is four bus clock periods (with ideal clock pulses as near as two bus clocks can be detected). TPM uses this pin as an input capture input to override the port data and data direction controls for the same pin.

When a channel is configured for output compare (CPWMS=0, MSnB:MSnA = 0:1 and ELSnB:ELSnA not = 0:0), the associated data direction control is overridden, the TPMxCHn pin is considered an output controlled by the TPM, and the ELSnB:ELSnA control bits determine how the pin is controlled. The remaining three combinations of ELSnB:ELSnA determine whether the TPMxCHn pin is toggled, cleared, or set each time the 16-bit channel value register matches the timer counter.

When the output compare toggle mode is initially selected, the previous value on the pin is driven out until the next output compare event—then the pin is toggled.



#### Chapter 16 Timer/PWM Module (S08TPMV3)

When a channel is configured for edge-aligned PWM (CPWMS=0, MSnB=1 and ELSnB:ELSnA not = 0:0), the data direction is overridden, the TPMxCHn pin is forced to be an output controlled by the TPM, and ELSnA controls the polarity of the PWM output signal on the pin. When ELSnB:ELSnA=1:0, the TPMxCHn pin is forced high at the start of each new period (TPMxCNT=0x0000), and the pin is forced low when the channel value register matches the timer counter. When ELSnA=1, the TPMxCHn pin is forced high when the channel value register matches the timer counter.

TPMxMODH:TPMxMODL = 0x0008 TPMxCnVH:TPMxCnVL = 0x0005

| TPMxCNTH:TPMxCNTL [ |   | 0 | 1 | 2 | 3 | 4 | 5    | 6 | 7 | 8 | 0    | 1 | 2 |  |
|---------------------|---|---|---|---|---|---|------|---|---|---|------|---|---|--|
|                     | I |   |   |   |   |   | ł    |   |   |   |      |   |   |  |
| TPMxCHn -           |   |   |   |   |   |   | <br> |   |   |   |      |   |   |  |
| CHnF BIT            |   |   |   |   |   |   |      |   |   |   | 1    |   |   |  |
|                     | i |   |   |   |   |   | 1    |   |   |   | <br> |   |   |  |
| IOF BIT             |   |   |   |   |   |   |      |   |   |   |      |   |   |  |

Figure 16-3. High-True Pulse of an Edge-Aligned PWM

| TPMxCNTH:TPMxCNTL |             | 0 | 1 | 2 | 3 | 4 | 5    | 6 | 7 | 8 | 0 | 1 | 2 |  |
|-------------------|-------------|---|---|---|---|---|------|---|---|---|---|---|---|--|
| TPMxCHn -         |             |   |   |   |   |   |      |   |   |   |   |   |   |  |
| CHnF BIT          | 1<br>I<br>I |   |   |   |   |   |      |   |   |   |   |   |   |  |
| TOF BIT           | l           |   |   |   |   |   | <br> |   |   |   |   |   |   |  |

Figure 16-4. Low-True Pulse of an Edge-Aligned PWM

TPMxMODH:TPMxMODL = 0x0008 TPMxCnVH:TPMxCnVL = 0x0005



## 17.4.3.8 Debug Trigger Register (DBGT)

This register can be read any time, but may be written only if ARM = 0, except bits 4 and 5 are hard-wired to 0s.



#### Figure 17-8. Debug Trigger Register (DBGT)

#### Table 17-5. DBGT Register Field Descriptions

| Field           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>TRGSEL     | <ul> <li>Trigger Type — Controls whether the match outputs from comparators A and B are qualified with the opcode tracking logic in the debug module. If TRGSEL is set, a match signal from comparator A or B must propagate through the opcode tracking logic and a trigger event is only signalled to the FIFO logic if the opcode at the match address is actually executed.</li> <li>0 Trigger on access to compare address (force)</li> <li>1 Trigger if opcode at compare address is executed (tag)</li> </ul> |
| 6<br>BEGIN      | <ul> <li>Begin/End Trigger Select — Controls whether the FIFO starts filling at a trigger or fills in a circular manner until a trigger ends the capture of information. In event-only trigger modes, this bit is ignored and all debug runs are assumed to be begin traces.</li> <li>0 Data stored in FIFO until trigger (end trace)</li> <li>1 Trigger initiates data storage (begin trace)</li> </ul>                                                                                                             |
| 3:0<br>TRG[3:0] | Select Trigger Mode — Selects one of nine triggering modes, as described below. $0000$ A-only $0001$ A OR B $0010$ A Then B $0011$ Event-only B (store data) $0100$ A then event-only B (store data) $0101$ A AND B data (full mode) $0110$ A AND NOT B data (full mode) $0111$ Inside range: A ≤ address ≤ B $1000$ Outside range: address < A or address > B $1001 - 1111$ (No trigger)                                                                                                                            |

| Num | с | Parameter                                                         | Symbol | V <sub>DD</sub> (V) | Typical <sup>1</sup> | Max <sup>2</sup> | Unit |
|-----|---|-------------------------------------------------------------------|--------|---------------------|----------------------|------------------|------|
| 6   |   | RTC adder to stop2 or stop3 <sup>5</sup> , 25°C                   |        | 5                   | 300                  | _                | nA   |
| 6   | C |                                                                   |        | 3                   | 300                  | _                | nA   |
| 7   | с | LVD adder to stop3 (LVDE = LVDSE = 1)                             |        | 5                   | 110                  | —                | μA   |
|     |   |                                                                   |        | 3                   | 90                   | —                | μA   |
|     |   | Adder to stop3 for oscillator enabled <sup>6</sup>                |        | 5                   | 5                    | —                | μA   |
| 8   | С | (IKCLKEN = 1 and IREFSTEN = 1 or<br>ERCLKEN = 1 and EREFSTEN = 1) |        | 3                   | 5                    |                  | μA   |

Table A-7. Supply Current Characteristics (continued)

<sup>1</sup> Typicals are measured at 25°C, unless otherwise noted.

<sup>2</sup> Maximum values in this column apply for the full operating temperature range of the device unless otherwise noted.

<sup>3</sup> All modules except ADC active, MCG configured for FBE, and does not include any dc loads on port pins

<sup>4</sup> Stop currents are tested in production for 25°C on all parts. Tests at other temperatures depend upon the part number suffix and maturity of the product. Freescale may eliminate a test insertion at a particular temperature from the production test flow once sufficient data has been collected and is approved.

<sup>5</sup> Most customers are expected to find that auto-wakeup from stop2 or stop3 can be used instead of the higher current wait mode.

<sup>6</sup> Values given under the following conditions: low range operation (RANGE = 0), low power mode (HGO = 0).

# A.8 Analog Comparator (ACMP) Electricals

Table A-8. Analog Comparator Electrical Specifications

| Num | С | Rating                                 | Symbol             | Min                   | Typical | Max             | Unit |
|-----|---|----------------------------------------|--------------------|-----------------------|---------|-----------------|------|
| 1   |   | Supply voltage                         | V <sub>DD</sub>    | 2.7                   |         | 5.5             | V    |
| 2   | D | Supply current (active)                | I <sub>DDAC</sub>  | —                     | 20      | 35              | μA   |
| 3   | D | Analog input voltage                   | V <sub>AIN</sub>   | V <sub>SS</sub> – 0.3 | _       | V <sub>DD</sub> | 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.9 ADC Characteristics

#### Table A-9. 12-bit ADC Operating Conditions

| Characteristic | Conditions                                                                  | Symb              | Min  | Typ <sup>1</sup> | Мах  | Unit | Comment |
|----------------|-----------------------------------------------------------------------------|-------------------|------|------------------|------|------|---------|
| Supply voltage | Absolute                                                                    | V <sub>DDAD</sub> | 2.7  |                  | 5.5  | V    |         |
|                | Delta to V <sub>DD</sub> (V <sub>DD</sub> -V <sub>DDAD</sub> ) <sup>2</sup> | $\Delta V_{DDAD}$ | -100 | 0                | +100 | mV   |         |
| Ground voltage | Delta to $V_{SS} (V_{SS} - V_{SSAD})^2$                                     | $\Delta V_{SSAD}$ | -100 | 0                | +100 | mV   |         |



**Appendix A Electrical Characteristics** 



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.







1.  $\overline{SS}$  output mode (MODFEN = 1, SSOE = 1).

2. LSBF = 0. For LSBF = 1, bit order is LSB, bit 1, ..., bit 6, MSB.



MC9S08DV60 Series Data Sheet, Rev 3



# A.13 Flash

This section provides details about program/erase times and program-erase endurance for the Flash memory.

Program and erase operations do not require any special power sources other than the normal V<sub>DD</sub> supply. For more detailed information about program/erase operations, see Chapter 4, "Memory."

| Num | с | Rating                                                                                                                  | Symbol                  | Min    | Typical           | Max  | Unit              |
|-----|---|-------------------------------------------------------------------------------------------------------------------------|-------------------------|--------|-------------------|------|-------------------|
| 1   | — | Supply voltage for program/erase                                                                                        | V <sub>prog/erase</sub> | 2.7    |                   | 5.5  | V                 |
| 2   |   | Supply voltage for read operation<br>0 < f <sub>Bus</sub> < 8 MHz<br>0 < f <sub>Bus</sub> < 20 MHz                      | V <sub>Read</sub>       | 2.7    |                   | 5.5  | V                 |
| 3   | _ | Internal FCLK frequency <sup>1</sup>                                                                                    | f <sub>FCLK</sub>       | 150    |                   | 200  | kHz               |
| 4   |   | Internal FCLK period (1/FCLK)                                                                                           | t <sub>Fcyc</sub>       | 5      |                   | 6.67 | μs                |
| 5   | _ | Byte program time (random location) <sup>(2)</sup>                                                                      | t <sub>prog</sub>       |        | t <sub>Fcyc</sub> |      |                   |
| 6   | _ | Byte program time (burst mode) <sup>(2)</sup>                                                                           | t <sub>Burst</sub>      |        | 4                 |      | t <sub>Fcyc</sub> |
| 7   | — | Page erase time <sup>2</sup>                                                                                            | t <sub>Page</sub>       |        | 4000              |      | t <sub>Fcyc</sub> |
| 8   | — | Mass erase time <sup>(2)</sup>                                                                                          | t <sub>Mass</sub>       |        | 20,000            |      | t <sub>Fcyc</sub> |
| 9   | С | Flash Program/erase endurance <sup>3</sup><br>T <sub>L</sub> to T <sub>H</sub> = $-40^{\circ}$ C to + 125°C<br>T = 25°C | N <sub>FLPE</sub>       | 10,000 | 100,000           | —    | cycles            |
| 10  | С | Data retention <sup>4</sup>                                                                                             | t <sub>D_ret</sub>      | 15     | 100               | —    | years             |

<sup>1</sup> The frequency of this clock is controlled by a software setting.

<sup>2</sup> These values are hardware state machine controlled. User code does not need to count cycles. This information supplied for calculating approximate time to program and erase.

<sup>3</sup> **Typical endurance** for Flash is based on the intrinsic bit cell performance. For additional information on how Freescale Semiconductor defines typical endurance, please refer to Engineering Bulletin EB619, *Typical Endurance for Nonvolatile Memory.* 

<sup>4</sup> Typical data retention values are based on intrinsic capability of the technology measured at high temperature and de-rated to 25°C using the Arrhenius equation. For additional information on how Freescale Semiconductor defines typical data retention, please refer to Engineering Bulletin EB618, *Typical Data Retention for Nonvolatile Memory.* 

# A.14 EMC Performance

Electromagnetic compatibility (EMC) performance is highly dependant on the environment in which the MCU resides. Board design and layout, circuit topology choices, location and characteristics of external components as well as MCU software operation all play a significant role in EMC performance. The system designer should consult Freescale applications notes such as AN2321, AN1050, AN1263, AN2764, and AN1259 for advice and guidance specifically targeted at optimizing EMC performance.