

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             | S08                                                         |
| 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        | 60KB (60K x 8)                                              |
| Program Memory Type        | FLASH                                                       |
| EEPROM Size                | -                                                           |
| RAM Size                   | 3K x 8                                                      |
| Voltage - Supply (Vcc/Vdd) | 2.7V ~ 5.5V                                                 |
| Data Converters            | A/D 10x12b                                                  |
| Oscillator Type            | External                                                    |
| Operating Temperature      | -40°C ~ 85°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=mc9s08dv60aclc |

Email: info@E-XFL.COM

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



## **Section Number**

### Title

## Page

|      | 12.3.1     | 5MSCAN Identifier Acceptance Registers (CANIDAR0-7)  | 237 |
|------|------------|------------------------------------------------------|-----|
|      | 12.3.1     | 6MSCAN Identifier Mask Registers (CANIDMR0–CANIDMR7) | 238 |
| 12.4 | Program    | nmer's Model of Message Storage                      | 239 |
|      | 12.4.1     | Identifier Registers (IDR0–IDR3)                     | 242 |
|      | 12.4.2     | IDR0–IDR3 for Standard Identifier Mapping            | 244 |
|      | 12.4.3     | Data Segment Registers (DSR0-7)                      | 245 |
|      | 12.4.4     | Data Length Register (DLR)                           | 246 |
|      | 12.4.5     | Transmit Buffer Priority Register (TBPR)             | 247 |
|      | 12.4.6     | Time Stamp Register (TSRH–TSRL)                      | 247 |
| 12.5 | Function   | nal Description                                      | 248 |
|      | 12.5.1     | General                                              | 248 |
|      | 12.5.2     | Message Storage                                      | 249 |
|      | 12.5.3     | Identifier Acceptance Filter                         | 252 |
|      | 12.5.4     | Modes of Operation                                   | 259 |
|      | 12.5.5     | Low-Power Options                                    |     |
|      | 12.5.6     | Reset Initialization                                 |     |
|      | 12.5.7     | Interrupts                                           |     |
| 12.6 | Initializa | ation/Application Information                        |     |
|      | 12.6.1     | MSCAN initialization                                 |     |
|      | 12.6.2     | Bus-Off Recovery                                     |     |
|      |            |                                                      |     |

## Chapter 13 Serial Peripheral Interface (S08SPIV3)

| 13.1 | Introducti | ion                                   | 271 |
|------|------------|---------------------------------------|-----|
|      | 13.1.1 H   | Features                              | 273 |
|      | 13.1.2 H   | Block Diagrams                        | 273 |
|      | 13.1.3 \$  | SPI Baud Rate Generation              | 275 |
| 13.2 | External S | Signal Description                    | 276 |
|      | 13.2.1 \$  | SPSCK — SPI Serial Clock              | 276 |
|      | 13.2.2 N   | MOSI — Master Data Out, Slave Data In | 276 |
|      | 13.2.3 N   | MISO — Master Data In, Slave Data Out | 276 |
|      | 13.2.4 \$  | $\overline{SS}$ — Slave Select        | 276 |
| 13.3 | Modes of   | Operation                             | 277 |
|      | 13.3.1 \$  | SPI in Stop Modes                     | 277 |
| 13.4 | Register I | Definition                            | 277 |
|      | 13.4.1 \$  | SPI Control Register 1 (SPIC1)        | 277 |
|      | 13.4.2 \$  | SPI Control Register 2 (SPIC2)        | 278 |
|      | 13.4.3 \$  | SPI Baud Rate Register (SPIBR)        | 279 |
|      | 13.4.4 \$  | SPI Status Register (SPIS)            | 280 |
|      | 13.4.5 \$  | SPI Data Register (SPID)              | 281 |
| 13.5 | Functiona  | al Description                        | 282 |
|      | 13.5.1 \$  | SPI Clock Formats                     | 282 |
|      |            |                                       |     |



Chapter 1 Device Overview

Table 1-2 provides the functional version of the on-chip modules.

| Module                          | Version |                |
|---------------------------------|---------|----------------|
| Central Processor Unit          | (CPU)   | 3              |
| Multi-Purpose Clock Generator   | (MCG)   | 1              |
| Analog Comparator               | (ACMP)  | 3              |
| Analog-to-Digital Converter     | (ADC)   | 1              |
| Inter-Integrated Circuit        | (IIC)   | 2              |
| Freescale's CAN                 | (MSCAN) | 1              |
| Serial Peripheral Interface     | (SPI)   | 3              |
| Serial Communications Interface | (SCI)   | 4              |
| Real-Time Counter               | (RTC)   | 1              |
| Timer Pulse Width Modulator     | (TPM)   | 3 <sup>1</sup> |
| Debug Module                    | (DBG)   | 2              |

| Table | 1-2. | Module | Versions |
|-------|------|--------|----------|
| Table |      | module | 10130113 |

<sup>1</sup> 3M05C and older masks have TPM version 2.

# **1.3 System Clock Distribution**

Figure 1-2 shows a simplified clock connection diagram. Some modules in the MCU have selectable clock inputs as shown. The clock inputs to the modules indicate the clock(s) that are used to drive the module function.

The following are the clocks used in this MCU:

- BUSCLK The frequency of the bus is always half of MCGOUT.
- LPO Independent 1-kHz clock that can be selected as the source for the COP and RTC modules.
- MCGOUT Primary output of the MCG and is twice the bus frequency.
- MCGLCLK Development tools can select this clock source to speed up BDC communications in systems where BUSCLK is configured to run at a very slow frequency.
- MCGERCLK External reference clock can be selected as the RTC clock source. It can also be used as the alternate clock for the ADC and MSCAN.
- MCGIRCLK Internal reference clock can be selected as the RTC clock source.
- MCGFFCLK Fixed frequency clock can be selected as clock source for the TPM1 and TPM2.
- TPM1CLK External input clock source for TPM1.
- TPM2CLK External input clock source for TPM2.



**Chapter 2 Pins and Connections** 

# 2.2 Recommended System Connections

Figure 2-4 shows pin connections that are common to MC9S08DV60 Series application systems.



ure 2-4. Basic System Connections (Shown in 64-Fin Facka



Chapter 4 Memory

3. Write a 1 to the FCBEF bit in FSTAT to clear FCBEF and launch the command (including its address and data information).

A partial command sequence can be aborted manually by writing a 0 to FCBEF any time after the write to the memory array and before writing the 1 that clears FCBEF and launches the complete command. Aborting a command in this way sets the FACCERR access error flag which must be cleared before starting a new command.

A strictly monitored procedure must be obeyed or the command will not be accepted. This minimizes the possibility of any unintended changes to the memory contents. The command complete flag (FCCF) indicates when a command is complete. The command sequence must be completed by clearing FCBEF to launch the command. Figure 4-2 is a flowchart for executing all of the commands except for burst programming and sector erase abort.

4. Wait until the FCCF bit in FSTAT is set. As soon as FCCF= 1, the operation has completed successfully.



Figure 4-2. Program and Erase Flowchart



Chapter 5 Resets, Interrupts, and General System Control

# 5.4 Computer Operating Properly (COP) Watchdog

The COP watchdog is intended to force a system reset when the application software fails to execute as expected. To prevent a system reset from the COP timer (when it is enabled), application software must reset the COP counter periodically. If the application program gets lost and fails to reset the COP counter before it times out, a system reset is generated to force the system back to a known starting point.

After any reset, the COP watchdog is enabled (see Section 5.8.4, "System Options Register 1 (SOPT1)," for additional information). If the COP watchdog is not used in an application, it can be disabled by clearing COPT bits in SOPT1.

The COP counter is reset by writing 0x55 and 0xAA (in this order) to the address of SRS during the selected timeout period. Writes do not affect the data in the read-only SRS. As soon as the write sequence is done, the COP timeout period is restarted. If the program fails to do this during the time-out period, the MCU will reset. Also, if any value other than 0x55 or 0xAA is written to SRS, the MCU is immediately reset.

The COPCLKS bit in SOPT2 (see Section 5.8.5, "System Options Register 2 (SOPT2)," for additional information) selects the clock source used for the COP timer. The clock source options are either the bus clock or an internal 1-kHz clock source. With each clock source, there are three associated time-outs controlled by the COPT bits in SOPT1. Table 5-6 summaries the control functions of the COPCLKS and COPT bits. The COP watchdog defaults to operation from the 1-kHz clock source and the longest time-out (2<sup>10</sup> cycles).

When the bus clock source is selected, windowed COP operation is available by setting COPW in the SOPT2 register. In this mode, writes to the SRS register to clear the COP timer must occur in the last 25% of the selected timeout period. A premature write immediately resets the MCU. When the 1-kHz clock source is selected, windowed COP operation is not available.

The COP counter is initialized by the first writes to the SOPT1 and SOPT2 registers and after any system reset. Subsequent writes to SOPT1 and SOPT2 have no effect on COP operation. Even if the application will use the reset default settings of COPT, COPCLKS, and COPW bits, the user should write to the write-once SOPT1 and SOPT2 registers during reset initialization to lock in the settings. This will prevent accidental changes if the application program gets lost.

The write to SRS that services (clears) the COP counter should not be placed in an interrupt service routine (ISR) because the ISR could continue to be executed periodically even if the main application program fails.

If the bus clock source is selected, the COP counter does not increment while the MCU is in background debug mode or while the system is in stop mode. The COP counter resumes when the MCU exits background debug mode or stop mode.

If the 1-kHz clock source is selected, the COP counter is re-initialized to zero upon entry to either background debug mode or stop mode and begins from zero upon exit from background debug mode or stop mode.



## 5.5 Interrupts

Interrupts provide a way to save the current CPU status and registers, execute an interrupt service routine (ISR), and then restore the CPU status so processing resumes where it left off before the interrupt. Other than the software interrupt (SWI), which is a program instruction, interrupts are caused by hardware events such as an edge on the IRQ pin or a timer-overflow event. The debug module can also generate an SWI under certain circumstances.

If an event occurs in an enabled interrupt source, an associated read-only status flag will become set. The CPU will not respond unless the local interrupt enable is a 1 to enable the interrupt and the I bit in the CCR is 0 to allow interrupts. The global interrupt mask (I bit) in the CCR is initially set after reset which prevents all maskable interrupt sources. The user program initializes the stack pointer and performs other system setup before clearing the I bit to allow the CPU to respond to interrupts.

When the CPU receives a qualified interrupt request, it completes the current instruction before responding to the interrupt. The interrupt sequence obeys the same cycle-by-cycle sequence as the SWI instruction and consists of:

- Saving the CPU registers on the stack
- Setting the I bit in the CCR to mask further interrupts
- Fetching the interrupt vector for the highest-priority interrupt that is currently pending
- Filling the instruction queue with the first three bytes of program information starting from the address fetched from the interrupt vector locations

While the CPU is responding to the interrupt, the I bit is automatically set to avoid the possibility of another interrupt interrupting the ISR itself (this is called nesting of interrupts). Normally, the I bit is restored to 0 when the CCR is restored from the value stacked on entry to the ISR. In rare cases, the I bit can be cleared inside an ISR (after clearing the status flag that generated the interrupt) so that other interrupts can be serviced without waiting for the first service routine to finish. This practice is not recommended for anyone other than the most experienced programmers because it can lead to subtle program errors that are difficult to debug.

The interrupt service routine ends with a return-from-interrupt (RTI) instruction which restores the CCR, A, X, and PC registers to their pre-interrupt values by reading the previously saved information from the stack.

### NOTE

For compatibility with M68HC08 devices, the H register is not automatically saved and restored. It is good programming practice to push H onto the stack at the start of the interrupt service routine (ISR) and restore it immediately before the RTI that is used to return from the ISR.

If more than one interrupt is pending when the I bit is cleared, the highest priority source is serviced first (see Table 5-1).

## 6.5.1.3 Port A Pull Enable Register (PTAPE)



Figure 6-5. Internal Pull Enable for Port A Register (PTAPE)

### Table 6-3. PTAPE Register Field Descriptions

| Field      | Description                                                                                                       |
|------------|-------------------------------------------------------------------------------------------------------------------|
| 7:0        | Internal Pull Enable for Port A Bits — Each of these control bits determines if the internal pull-up or pull-down |
| PTAPE[7:0] | device is enabled for the associated PTA pin. For port A pins that are configured as outputs, these bits have no  |
|            | effect and the internal pull devices are disabled.                                                                |
|            | 0 Internal pull-up/pull-down device disabled for port A bit n.                                                    |
|            | 1 Internal pull-up/pull-down device enabled for port A 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.1.4 Port A Slew Rate Enable Register (PTASE)

|        | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|
| R<br>W | PTASE7 | PTASE6 | PTASE5 | PTASE4 | PTASE3 | PTASE2 | PTASE1 | PTASE0 |
| Reset: | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |

Figure 6-6. Slew Rate Enable for Port A Register (PTASE)

### Table 6-4. PTASE Register Field Descriptions

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



Chapter 6 Parallel Input/Output Control

## 6.5.2.5 Port B Drive Strength Selection Register (PTBDS)



Figure 6-15. Drive Strength Selection for Port B Register (PTBDS)

### Table 6-13. PTBDS Register Field Descriptions

| Field             | Description                                                                                                                                                                                                                                                                                                                                                                       |
|-------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0<br>PTBDS[7:0] | <ul> <li>Output Drive Strength Selection for Port B Bits — Each of these control bits selects between low and high output drive for the associated PTB pin. For port B pins that are configured as inputs, these bits have no effect.</li> <li>0 Low output drive strength selected for port B bit n.</li> <li>1 High output drive strength selected for port B bit n.</li> </ul> |

### 6.5.2.6 Port B Interrupt Status and Control Register (PTBSC)



### Figure 6-16. Port B Interrupt Status and Control Register (PTBSC)

### Table 6-14. PTBSC Register Field Descriptions

| Field       | Description                                                                                                                                                                                                                             |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3<br>PTBIF  | <ul> <li>Port B Interrupt Flag — PTBIF indicates when a Port B interrupt is detected. Writes have no effect on PTBIF.</li> <li>0 No Port B interrupt detected.</li> <li>1 Port B interrupt detected.</li> </ul>                         |
| 2<br>PTBACK | <b>Port B Interrupt Acknowledge</b> — Writing a 1 to PTBACK is part of the flag clearing mechanism. PTBACK always reads as 0.                                                                                                           |
| 1<br>PTBIE  | <ul> <li>Port B Interrupt Enable — PTBIE determines whether a port B interrupt is requested.</li> <li>0 Port B interrupt request not enabled.</li> <li>1 Port B interrupt request enabled.</li> </ul>                                   |
| 0<br>PTBMOD | <ul> <li>Port B Detection Mode — PTBMOD (along with the PTBES bits) controls the detection mode of the port B interrupt pins.</li> <li>0 Port B pins detect edges only.</li> <li>1 Port B pins detect both edges and levels.</li> </ul> |



Chapter 6 Parallel Input/Output Control

## 6.5.4.7 Port D Interrupt Pin Select Register (PTDPS)



Figure 6-30. Port D Interrupt Pin Select Register (PTDPS)

### Table 6-28. PTDPS Register Field Descriptions

| Field             | Description                                                                                                                                                                                             |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0<br>PTDPS[7:0] | <ul> <li>Port D Interrupt Pin Selects — Each of the PTDPSn bits enable the corresponding port D interrupt pin.</li> <li>0 Pin not enabled as interrupt.</li> <li>1 Pin enabled as interrupt.</li> </ul> |

### 6.5.4.8 Port D Interrupt Edge Select Register (PTDES)

| _      | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|
| R<br>W | PTDES7 | PTDES6 | PTDES5 | PTDES4 | PTDES3 | PTDES2 | PTDES1 | PTDES0 |
| Reset: | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |

### Figure 6-31. Port D Edge Select Register (PTDES)

### Table 6-29. PTDES Register Field Descriptions

| Field      | Description                                                                                                                                                                                                                                              |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0        | Port D Edge Selects — Each of the PTDESn bits serves a dual purpose by selecting the polarity of the active                                                                                                                                              |
| PTDES[7:0] | interrupt edge as well as selecting a pull-up or pull-down device if enabled.                                                                                                                                                                            |
|            | <ul> <li>0 A pull-up device is connected to the associated pin and detects falling edge/low level for interrupt generation.</li> <li>1 A pull-down device is connected to the associated pin and detects rising edge/high level for interrupt</li> </ul> |
|            | generation.                                                                                                                                                                                                                                              |



Chapter 8 Multi-Purpose Clock Generator (S08MCGV1)

# 8.4.7 Fixed Frequency Clock

The MCG presents the divided reference clock as MCGFFCLK for use as an additional clock source. The MCGFFCLK frequency must be no more than 1/4 of the MCGOUT frequency to be valid. Because of this requirement, the MCGFFCLK is not valid in bypass modes for the following combinations of BDIV and RDIV values:

- BDIV=00 (divide by 1), RDIV < 010
- BDIV=01 (divide by 2), RDIV < 011

When MCGFFCLK is valid then MCGFFCLKVALID is set to 1. When MCGFFCLK is not valid then MCGFFCLKVALID is set to 0.

# 8.5 Initialization / Application Information

This section describes how to initialize and configure the MCG module in application. The following sections include examples on how to initialize the MCG and properly switch between the various available modes.

## 8.5.1 MCG Module Initialization Sequence

The MCG comes out of reset configured for FEI mode with the BDIV set for divide-by-2. The internal reference will stabilize in  $t_{irefst}$  microseconds before the FLL can acquire lock. As soon as the internal reference is stable, the FLL will acquire lock in  $t_{fll}$  lock milliseconds.

Upon POR, the internal reference will require trimming to guarantee an accurate clock. Freescale recommends using FLASH location 0xFFAE for storing the fine trim bit, FTRIM in the MCGSC register, and 0xFFAF for storing the 8-bit trim value in the MCGTRM register. The MCU will not automatically copy the values in these FLASH locations to the respective registers. Therefore, user code must copy these values from FLASH to the registers.

### NOTE

The BDIV value should not be changed to divide-by-1 without first trimming the internal reference. Failure to do so could result in the MCU running out of specification.

### 8.5.1.1 Initializing the MCG

Because the MCG comes out of reset in FEI mode, the only MCG modes which can be directly switched to upon reset are FEE, FBE, and FBI modes (see Figure 8-8). Reaching any of the other modes requires first configuring the MCG for one of these three initial modes. Care must be taken to check relevant status bits in the MCGSC register reflecting all configuration changes within each mode.

To change from FEI mode to FEE or FBE modes, follow this procedure:

- 1. Enable the external clock source by setting the appropriate bits in MCGC2.
- 2. Write to MCGC1 to select the clock mode.



external crystal and a maximum reference divider factor of 128, the resulting frequency of the reference clock for the FLL is 62.5 kHz (greater than the 39.0625 kHz maximum allowed).

Care must be taken in the software to minimize the amount of time spent in this state where the FLL is operating in this condition.

The following code sequence describes how to move from FEI mode to PEE mode until the 8 MHz crystal reference frequency is set to achieve a bus frequency of 8 MHz. Because the MCG is in FEI mode out of reset, this example also shows how to initialize the MCG for PEE mode out of reset. First, the code sequence will be described. Then a flowchart will be included which illustrates the sequence.

- 1. First, FEI must transition to FBE mode:
  - a) MCGC2 = 0x36 (%00110110)
    - BDIV (bits 7 and 6) set to %00, or divide-by-1
    - RANGE (bit 5) set to 1 because the frequency of 8 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) Block Interrupts (If applicable by setting the interrupt bit in the CCR).
  - d) MCGC1 = 0xB8 (% 10111000)
    - CLKS (bits 7 and 6) set to %10 in order to select external reference clock as system clock source
    - RDIV (bits 5-3) set to %111, or divide-by-128.

### NOTE

8 MHz / 128 = 62.5 kHz which is greater than the 31.25 kHz to 39.0625 kHz range required by the FLL. Therefore after the transition to FBE is complete, software must progress through to BLPE mode immediately by setting the LP bit in MCGC2.

- IREFS (bit 2) cleared to 0, selecting the external reference clock
- e) Loop until IREFST (bit 4) in MCGSC is 0, indicating the external reference is the current source for the reference clock
- f) Loop until CLKST (bits 3 and 2) in MCGSC are %10, indicating that the external reference clock is selected to feed MCGOUT
- 2. Then, FBE mode transitions into BLPE mode:
  - a) MCGC2 = 0x3E (%00111110)
    - LP (bit 3) in MCGC2 to 1 (BLPE mode entered)

### NOTE

There must be no extra steps (including interrupts) between steps 1d and 2a.

b) Enable Interrupts (if applicable by clearing the interrupt bit in the CCR).



Chapter 9 Analog Comparator (S08ACMPV3)

## 9.1.4 Block Diagram

The block diagram for the analog comparator module is shown Figure 9-2.



Figure 9-2. Analog Comparator (ACMP) Block Diagram

# 9.2 External Signal Description

The ACMP has two analog input pins, ACMPx+ and ACMPx– and one digital output pin ACMPxO. Each of these pins can accept an input voltage that varies across the full operating voltage range of the MCU. As shown in Figure 9-2, the ACMPx- pin is connected to the inverting input of the comparator, and the ACMPx+ pin is connected to the comparator non-inverting input if ACBGS is a 0. As shown in Figure 9-2, the ACMPxO pin can be enabled to drive an external pin.

The signal properties of ACMP are shown in Table 9-1.

| Signal | Function                                                    | I/O |
|--------|-------------------------------------------------------------|-----|
| ACMPx- | Inverting analog input to the ACMP.<br>(Minus input)        | I   |
| ACMPx+ | Non-inverting analog input to the ACMP.<br>(Positive input) | I   |
| ACMPxO | Digital output of the ACMP.                                 | 0   |

**Table 9-1. Signal Properties** 



In 10-bit mode, the ADCCVH register holds the upper two bits of the 10-bit compare value (ADCV[9:8]). These bits are compared to the upper two bits of the result following a conversion in 10-bit mode when the compare function is enabled.

In 8-bit mode, ADCCVH is not used during compare.

## 10.3.6 Compare Value Low Register (ADCCVL)

This register holds the lower 8 bits of the 12-bit or 10-bit compare value or all 8 bits of the 8-bit compare value. When the compare function is enabled, bits ADCV[7:0] are compared to the lower 8 bits of the result following a conversion in 12-bit, 10-bit or 8-bit mode.





### **10.3.7** Configuration Register (ADCCFG)

ADCCFG selects the mode of operation, clock source, clock divide, and configures for low power and long sample time.



Figure 10-9. Configuration Register (ADCCFG)

### Table 10-6. ADCCFG Register Field Descriptions

| Field       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>ADLPC  | <ul> <li>Low-Power Configuration. ADLPC controls the speed and power configuration of the successive approximation converter. This optimizes power consumption when higher sample rates are not required.</li> <li>0 High speed configuration</li> <li>1 Low power configuration: The power is reduced at the expense of maximum clock speed.</li> </ul>                                                                                        |
| 6:5<br>ADIV | Clock Divide Select. ADIV selects the divide ratio used by the ADC to generate the internal clock ADCK.<br>Table 10-7 shows the available clock configurations.                                                                                                                                                                                                                                                                                 |
| 4<br>ADLSMP | Long Sample Time Configuration. ADLSMP selects between long and short sample time. This adjusts the sample period to allow higher impedance inputs to be accurately sampled or to maximize conversion speed for lower impedance inputs. Longer sample times can also be used to lower overall power consumption when continuous conversions are enabled if high conversion rates are not required.<br>0 Short sample time<br>1 Long sample time |



### NOTE

The CANTIER register is held in the reset state when the initialization mode is active (INITRQ = 1 and INITAK = 1). This register is writable when not in initialization mode (INITRQ = 0 and INITAK = 0).

Read: Anytime

Write: Anytime when not in initialization mode

### Table 12-12. CANTIER Register Field Descriptions

| Field             | Description                                                                                                                                                                                                                                                                                                   |  |  |  |
|-------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| 2:0<br>TXEIE[2:0] | <ul> <li>Transmitter Empty Interrupt Enable</li> <li>0 No interrupt request is generated from this event.</li> <li>1 A transmitter empty (transmit buffer available for transmission) event causes a transmitter empty interrupt request. See Section 12.5.2.2, "Transmit Structures" for details.</li> </ul> |  |  |  |

## 12.3.8 MSCAN Transmitter Message Abort Request Register (CANTARQ)

The CANTARQ register allows abort request of messages queued for transmission.



### Figure 12-12. MSCAN Transmitter Message Abort Request Register (CANTARQ)

### NOTE

The CANTARQ register is held in the reset state when the initialization mode is active (INITRQ = 1 and INITAK = 1). This register is writable when not in initialization mode (INITRQ = 0 and INITAK = 0).

Read: Anytime

Write: Anytime when not in initialization mode

| Table 12-13 | . CANTARQ | Register | Field | Descriptions |
|-------------|-----------|----------|-------|--------------|
|-------------|-----------|----------|-------|--------------|

| Field             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0<br>ABTRQ[2:0] | Abort Request — The CPU sets the ABTRQx bit to request that a scheduled message buffer (TXEx = 0) be<br>aborted. The MSCAN grants the request if the message has not already started transmission, or if the<br>transmission is not successful (lost arbitration or error). When a message is aborted, the associated TXE (see<br>Section 12.3.6, "MSCAN Transmitter Flag Register (CANTFLG)") and abort acknowledge flags (ABTAK, see<br> |



| Register<br>Name |        | Bit 7 | 6    | 5    | 4                  | 3                  | 2    | 1    | Bit0             |
|------------------|--------|-------|------|------|--------------------|--------------------|------|------|------------------|
| IDR0             | R<br>W | ID28  | ID27 | ID26 | ID25               | ID24               | ID23 | ID22 | ID21             |
| IDR1             | R<br>W | ID20  | ID19 | ID18 | SRR <sup>(1)</sup> | IDE <sup>(1)</sup> | ID17 | ID16 | ID15             |
| IDR2             | R<br>W | ID14  | ID13 | ID12 | ID11               | ID10               | ID9  | ID8  | ID7              |
| IDR3             | R<br>W | ID6   | ID5  | ID4  | ID3                | ID2                | ID1  | ID0  | RTR <sup>2</sup> |
| DSR0             | R<br>W | DB7   | DB6  | DB5  | DB4                | DB3                | DB2  | DB1  | DB0              |
| DSR1             | R<br>W | DB7   | DB6  | DB5  | DB4                | DB3                | DB2  | DB1  | DB0              |
| DSR2             | R<br>W | DB7   | DB6  | DB5  | DB4                | DB3                | DB2  | DB1  | DB0              |
| DSR3             | R<br>W | DB7   | DB6  | DB5  | DB4                | DB3                | DB2  | DB1  | DB0              |
| DSR4             | R<br>W | DB7   | DB6  | DB5  | DB4                | DB3                | DB2  | DB1  | DB0              |
| DSR5             | R<br>W | DB7   | DB6  | DB5  | DB4                | DB3                | DB2  | DB1  | DB0              |
| DSR6             | R<br>W | DB7   | DB6  | DB5  | DB4                | DB3                | DB2  | DB1  | DB0              |
| DSR7             | R<br>W | DB7   | DB6  | DB5  | DB4                | DB3                | DB2  | DB1  | DB0              |
| DLR              | R<br>W |       |      |      |                    | DLC3               | DLC2 | DLC1 | DLC0             |
|                  | _      |       |      |      |                    |                    |      |      |                  |

= Unused, always read 'x'

### Figure 12-23. Receive/Transmit Message Buffer — Extended Identifier Mapping

<sup>1</sup> SRR and IDE are both 1s.

 $^2$  The position of RTR differs between extended and standard indentifier mapping.

Read: For transmit buffers, anytime when TXEx flag is set (see Section 12.3.6, "MSCAN Transmitter Flag Register (CANTFLG)") and the corresponding transmit buffer is selected in CANTBSEL (see



Chapter 13 Serial Peripheral Interface (S08SPIV3)

#### Chapter 15 Real-Time Counter (S08RTCV1)

```
#pragma TRAP_PROC
void RTC_ISR(void)
{
        /* Clear the interrupt flag */
        RTCSC.byte = RTCSC.byte | 0x80;
        /* RTC interrupts every 1 Second */
        Seconds++;
        /* 60 seconds in a minute */
        if (Seconds > 59){
        Minutes++;
        Seconds = 0;
        }
        /* 60 minutes in an hour */
        if (Minutes > 59){
        Hours++;
        Minutes = 0;
        }
        /* 24 hours in a day */
        if (Hours > 23){
        Days ++;
        Hours = 0;
```

}



Appendix A Electrical Characteristics







Figure A-4. Pin Interrupt Timing

### A.12.2 Timer/PWM

Synchronizer circuits determine the shortest input pulses that can be recognized or the fastest clock that can be used as the optional external source to the timer counter. These synchronizers operate from the current bus rate clock.

| Num | С | Rating                    | Symbol            | Min | Мах                 | Unit             |
|-----|---|---------------------------|-------------------|-----|---------------------|------------------|
| 1   | _ | External clock frequency  | f <sub>TCLK</sub> | dc  | f <sub>Bus</sub> /4 | MHz              |
| 2   | _ | External clock period     | t <sub>TCLK</sub> | 4   | _                   | t <sub>cyc</sub> |
| 3   | D | External clock high time  | t <sub>clkh</sub> | 1.5 | _                   | t <sub>cyc</sub> |
| 4   | D | External clock low time   | t <sub>clkl</sub> | 1.5 | _                   | t <sub>cyc</sub> |
| 5   | D | Input capture pulse width | t <sub>ICPW</sub> | 1.5 | _                   | t <sub>cyc</sub> |

Table A-14. TPM Input Timing



#### Appendix B Timer Pulse-Width Modulator (TPMV2)

at the transition from the value set in the modulus register and the next lower count value. This corresponds to the end of a PWM period. (The 0x0000 count value corresponds to the center of a period.)

## **B.4.3** Channel Event Interrupt Description

The meaning of channel interrupts depends on the current mode of the channel (input capture, output compare, edge-aligned PWM, or center-aligned PWM).

When a channel is configured as an input capture channel, the ELSnB:ELSnA control bits select rising edges, falling edges, any edge, or no edge (off) as the edge that triggers an input capture event. When the selected edge is detected, the interrupt flag is set. The flag is cleared by the 2-step sequence described in Section B.4.1, "Clearing Timer Interrupt Flags."

When a channel is configured as an output compare channel, the interrupt flag is set each time the main timer counter matches the 16-bit value in the channel value register. The flag is cleared by the 2-step sequence described in Section B.4.1, "Clearing Timer Interrupt Flags."

## B.4.4 PWM End-of-Duty-Cycle Events

For channels that are configured for PWM operation, there are two possibilities:

- When the channel is configured for edge-aligned PWM, the channel flag is set when the timer counter matches the channel value register that marks the end of the active duty cycle period.
- When the channel is configured for center-aligned PWM, the timer count matches the channel value register twice during each PWM cycle. In this CPWM case, the channel flag is set at the start and at the end of the active duty cycle, which are the times when the timer counter matches the channel value register.

The flag is cleared by the 2-step sequence described in Section B.4.1, "Clearing Timer Interrupt Flags."



# Appendix C Ordering Information and Mechanical Drawings

# C.1 Ordering Information

This section contains ordering information for MC9S08DV60 Series devices.

Example of the device numbering system:



## C.1.1 MC9S08DV60 Series Devices

| Dovice Number      | Men    | nory | Available Packages <sup>1</sup> |  |
|--------------------|--------|------|---------------------------------|--|
| Device Number      | Flash  | RAM  | Available Fackages              |  |
| MC9S08 <b>DV60</b> | 62,080 | 3072 |                                 |  |
| MC9S08DV48         | 49,152 | 2048 | 48-LQFP,<br>48-LQFP 32-LQFP     |  |
| MC9S08DV32         | 33,792 | 2048 |                                 |  |
| MC9S08 <b>DV16</b> | 16,896 | 1024 | 48-LQFP, 32-LQFP                |  |

Table C-1. Devices in the MC9S08DV60 Series

<sup>1</sup> See for package information.

# C.2 Mechanical Drawings

The following pages are mechanical drawings for the packages described in the following table: