

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             | HCS12X                                                       |
| Core Size                  | 16-Bit                                                       |
| Speed                      | 80MHz                                                        |
| Connectivity               | CANbus, EBI/EMI, I <sup>2</sup> C, IrDA, LINbus, SCI, SPI    |
| Peripherals                | LVD, POR, PWM, WDT                                           |
| Number of I/O              | 59                                                           |
| Program Memory Size        | 128KB (128K x 8)                                             |
| Program Memory Type        | FLASH                                                        |
| EEPROM Size                | 2K x 8                                                       |
| RAM Size                   | 12К х 8                                                      |
| Voltage - Supply (Vcc/Vdd) | 2.35V ~ 2.75V                                                |
| Data Converters            | A/D 8x10b                                                    |
| Oscillator Type            | External                                                     |
| Operating Temperature      | -40°C ~ 85°C (TA)                                            |
| Mounting Type              | Surface Mount                                                |
| Package / Case             | 80-QFP                                                       |
| Supplier Device Package    | 80-QFP (14x14)                                               |
| Purchase URL               | https://www.e-xfl.com/pro/item?MUrl=&PartUrl=s912xdg128f2caa |

Email: info@E-XFL.COM

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



#### Table 2-5. PLLCTL Field Descriptions (continued)

| Field     | Description                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2<br>PRE  | <ul> <li>RTI Enable during Pseudo Stop Bit — PRE enables the RTI during pseudo stop mode. Write anytime.</li> <li>0 RTI stops running during pseudo stop mode.</li> <li>1 RTI continues running during pseudo stop mode.</li> <li>Note: If the PRE bit is cleared the RTI dividers will go static while pseudo stop mode is active. The RTI dividers will <u>not</u> initialize like in wait mode with RTIWAI bit set.</li> </ul> |
| 1<br>PCE  | <ul> <li>COP Enable during Pseudo Stop Bit — PCE enables the COP during pseudo stop mode. Write anytime.</li> <li>0 COP stops running during pseudo stop mode</li> <li>1 COP continues running during pseudo stop mode</li> <li>Note: If the PCE bit is cleared, the COP dividers will go static while pseudo stop mode is active. The COP dividers will not initialize like in wait mode with COPWAI bit set.</li> </ul>         |
| 0<br>SCME | Self Clock Mode Enable Bit         Normal modes: Write once         Special modes: Write anytime         SCME can not be cleared while operating in self clock mode (SCM = 1).         0 Detection of crystal clock failure causes clock monitor reset (see Section 2.5.2, "Clock Monitor Reset").         1 Detection of crystal clock failure forces the MCU in self clock mode (see Section 2.4.2.2, "Self Clock Mode").       |

## 2.3.2.8 CRG RTI Control Register (RTICTL)

This register selects the timeout period for the real time interrupt.



Figure 2-11. CRG RTI Control Register (RTICTL)

Read: Anytime

Write: Anytime

#### NOTE

A write to this register initializes the RTI counter.

#### Table 2-6. RTICTL Field Descriptions

| Field           | Description                                                                                                                                                                                                                                                                       |  |  |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 7<br>RTDEC      | <ul> <li>Decimal or Binary Divider Select Bit — RTDEC selects decimal or binary based prescaler values.</li> <li>0 Binary based divider value. See Table 2-7</li> <li>1 Decimal based divider value. See Table 2-8</li> </ul>                                                     |  |  |
| 6–4<br>RTR[6:4] | <b>Real Time Interrupt Prescale Rate Select Bits</b> — These bits select the prescale rate for the RTI. See Table 2-7 and Table 2-8.                                                                                                                                              |  |  |
| 3–0<br>RTR[3:0] | <b>Real Time Interrupt Modulus Counter Select Bits</b> — These bits select the modulus counter target value to provide additional granularity. Table 2-7 and Table 2-8 show all possible divide values selectable by the RTICTL register. The source clock for the RTI is OSCCLK. |  |  |



## 2.4.3.3.1 Wake-up from Pseudo Stop Mode (PSTP=1)

Wake-up from pseudo stop mode is the same as wake-up from wait mode. There are also four different scenarios for the CRG to restart the MCU from pseudo stop mode:

- External reset
- Clock monitor fail
- COP reset
- Wake-up interrupt

If the MCU gets an external reset or COP reset during pseudo stop mode active, the CRG asynchronously restores all configuration bits in the register space to its default settings and starts the reset generator. After completing the reset sequence processing begins by fetching the normal or COP reset vector. pseudo stop mode is left and the MCU is in run mode again.

If the clock monitor is enabled (CME = 1), the MCU is able to leave pseudo stop mode when loss of oscillator/external clock is detected by a clock monitor fail. If the SCME bit is not asserted the CRG generates a clock monitor fail reset (CMRESET). The CRG's behavior for CMRESET is the same compared to external reset, but another reset vector is fetched after completion of the reset sequence. If the SCME bit is asserted the CRG generates a SCM interrupt if enabled (SCMIE = 1). After generating the interrupt the CRG enters self-clock mode and starts the clock quality checker (Section 2.4.1.4, "Clock Quality Checker"). Then the MCU continues with normal operation. If the SCM interrupt is blocked by SCMIE=0, the SCMIF flag will be asserted but the CRG will not wake-up from pseudo stop mode.

If any other interrupt source (e.g., RTI) triggers exit from pseudo stop mode, the MCU immediately continues with normal operation. Because the PLL has been powered-down during stop mode, the PLLSEL bit is cleared and the MCU runs on OSCCLK after leaving stop mode. The software must set the PLLSEL bit again, in order to switch system and core clocks to the PLLCLK.

Table 2-13 summarizes the outcome of a clock loss while in pseudo stop mode.

| Field           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2<br>FIFO       | <ul> <li>Result Register FIFO Mode —If this bit is zero (non-FIFO mode), the A/D conversion results map into the result registers based on the conversion sequence; the result of the first conversion appears in the first result register, the second result in the second result register, and so on.</li> <li>If this bit is one (FIFO mode) the conversion counter is not reset at the beginning or ending of a conversion sequence; sequential conversion results are placed in consecutive result registers. In a continuously scanning conversion sequence, the result register counter will wrap around when it reaches the end of the result register file. The conversion counter value (CC3-0 in ATDSTAT0) can be used to determine where in the result register file, the current conversion result will be placed.</li> <li>Aborting a conversion or starting a new conversion by write to an ATDCTL register (ATDCTL5-0) clears the conversion counter even if FIFO=1. So the first result of a new conversion sequence, started by writing to ATDCTL5, will always be place in the first result register (ATDDDR0). Intended usage of FIFO mode is continuos conversion (SCAN=1) or triggered conversion (ETRIG=1).</li> <li>Finally, which result registers hold valid data can be tracked using the conversion complete flags. Fast flag clear mode may or may not be useful in a particular application to track valid data.</li> <li>0 Conversion results are placed in the corresponding result register up to the selected sequence length.</li> <li>1 Conversion results are placed in consecutive result registers (wrap around at end).</li> </ul> |
| 1:0<br>FRZ[1:0] | <b>Background Debug Freeze Enable</b> — When debugging an application, it is useful in many cases to have the ATD pause when a breakpoint (Freeze Mode) is encountered. These 2 bits determine how the ATD will respond to a breakpoint as shown in Table 4-10. Leakage onto the storage node and comparator reference capacitors may compromise the accuracy of an immediately frozen conversion depending on the length of the freeze period.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |

| S8C | S4C | S2C | S1C Number of Conversions<br>per Sequence |    |  |
|-----|-----|-----|-------------------------------------------|----|--|
| 0   | 0   | 0   | 0                                         | 16 |  |
| 0   | 0   | 0   | 1                                         | 1  |  |
| 0   | 0   | 1   | 0                                         | 2  |  |
| 0   | 0   | 1   | 1                                         | 3  |  |
| 0   | 1   | 0   | 0                                         | 4  |  |
| 0   | 1   | 0   | 1                                         | 5  |  |
| 0   | 1   | 1   | 0                                         | 6  |  |
| 0   | 1   | 1   | 1                                         | 7  |  |
| 1   | 0   | 0   | 0                                         | 8  |  |
| 1   | 0   | 0   | 1                                         | 9  |  |
| 1   | 0   | 1   | 0                                         | 10 |  |
| 1   | 0   | 1   | 1                                         | 11 |  |
| 1   | 1   | 0   | 0                                         | 12 |  |
| 1   | 1   | 0   | 1                                         | 13 |  |
| 1   | 1   | 1   | 0                                         | 14 |  |
| 1   | 1   | 1   | 1                                         | 15 |  |

Table 4-9. Conversion Sequence Length Coding



#### Table 4-14. ATDCTL5 Field Descriptions (continued)

| Field         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0<br>C[D:A} | <b>Analog Input Channel Select Code</b> — These bits select the analog input channel(s) whose signals are sampled and converted to digital codes. Table 4-17 lists the coding used to select the various analog input channels.                                                                                                                                                                                                                                                                                                                                                                                     |
|               | In the case of single channel conversions (MULT = 0), this selection code specified the channel to be examined.<br>In the case of multiple channel conversions (MULT = 1), this selection code represents the first channel to be<br>examined in the conversion sequence. Subsequent channels are determined by incrementing the channel<br>selection code or wrapping around to AN0 (after converting the channel defined by the Wrap Around Channel<br>Select Bits WRAP[3:0] in ATDCTL0). In case starting with a channel number higher than the one defined by<br>WDAP(3) the first example a provide the AN(6). |

Table 4-15. Available Result Data Formats.

| SRES8 | DJM | DSGN Result Data Formats<br>Description and Bus Bit Mapping |                                                |
|-------|-----|-------------------------------------------------------------|------------------------------------------------|
| 1     | 0   | 0                                                           | 8-bit / left justified / unsigned — bits 15:8  |
| 1     | 0   | 1                                                           | 8-bit / left justified / signed — bits 15:8    |
| 1     | 1   | Х                                                           | 8-bit / right justified / unsigned — bits 7:0  |
| 0     | 0   | 0                                                           | 10-bit / left justified / unsigned — bits 15:6 |
| 0     | 0   | 1                                                           | 10-bit / left justified / signed bits 15:6     |
| 0     | 1   | Х                                                           | 10-bit / right justified / unsigned — bits 9:0 |

#### Table 4-16. Left Justified, Signed and Unsigned ATD Output Codes.

| Input Signal<br>V <sub>RL</sub> = 0 Volts<br>V <sub>RH</sub> = 5.12 Volts | Signed<br>8-Bit Codes | Unsigned<br>8-Bit Codes | Signed<br>10-Bit Codes | Unsigned<br>10-Bit Codes |
|---------------------------------------------------------------------------|-----------------------|-------------------------|------------------------|--------------------------|
| 5.120 Volts                                                               | 7F                    | FF                      | 7FC0                   | FFC0                     |
| 5.100                                                                     | 7F                    | FF                      | 7F00                   | FF00                     |
| 5.080                                                                     | 7E                    | FE                      | 7E00                   | FE00                     |
| 2 580                                                                     | 01                    | 81                      | 0100                   | 8100                     |
| 2.500                                                                     | 00                    | 01                      | 0100                   | 8000                     |
| 2.500                                                                     |                       | 00                      | 0000                   | 8000                     |
| 2.540                                                                     | FF                    | 7F                      | FF00                   | 7F00                     |
|                                                                           |                       |                         |                        |                          |
| 0.020                                                                     | 81                    | 01                      | 8100                   | 0100                     |
| 0.000                                                                     | 80                    | 00                      | 8000                   | 0000                     |



# 4.5 Resets

At reset the ATD10B16C is in a power down state. The reset state of each individual bit is listed within Section 4.3, "Memory Map and Register Definition," which details the registers and their bit fields.

# 4.6 Interrupts

The interrupt requested by the ATD10B16C is listed in Table 4-28. Refer to MCU specification for related vector address and priority.

#### Table 4-28. ATD Interrupt Vectors

| Interrupt Source            | CCR Mask | Local Enable     |
|-----------------------------|----------|------------------|
| Sequence Complete Interrupt | l bit    | ASCIE in ATDCTL2 |

See Section 4.3.2, "Register Descriptions," for further details.



# 5.3.2.11 ATD Input Enable Register (ATDDIEN)



Figure 5-13. ATD Input Enable Register (ATDDIEN)

Read: Anytime

Write: Anytime

| Field           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 7–0<br>IEN[7:0] | <ul> <li>ATD Digital Input Enable on channel x (x = 7, 6, 5, 4, 3, 2, 1, 0) — This bit controls the digital input buffer from the analog input pin (ANx) to PTADx data register.</li> <li>0 Disable digital input buffer to PTADx</li> <li>1 Enable digital input buffer to PTADx.</li> <li>Note: Setting this bit will enable the corresponding digital input buffer continuously. If this bit is set while simultaneously using it as an analog port, there is potentially increased power consumption because the digital input buffer maybe in the linear region.</li> </ul> |  |  |

# 5.3.2.12 Port Data Register (PORTAD)

The data port associated with the ATD can be configured as general-purpose I/O or input only, as specified in the device overview. The port pins are shared with the analog A/D inputs AN7–0.

|                 | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|-----------------|-------|-------|-------|-------|-------|-------|-------|-------|
| R               | PTAD7 | PTAD6 | PTAD5 | PTAD4 | PTAD3 | PTAD2 | PTAD1 | PTAD0 |
| W               |       |       |       |       |       |       |       |       |
| Reset           | 1     | 1     | 1     | 1     | 1     | 1     | 1     | 1     |
| Pin<br>Function | AN7   | AN6   | AN5   | AN4   | AN3   | AN2   | AN1   | AN0   |
|                 |       | 1     |       |       |       |       |       |       |

= Unimplemented or Reserved

Figure 5-14. Port Data Register (PORTAD)

Read: Anytime

Write: Anytime, no effect

The A/D input channels may be used for general purpose digital input.

#### Table 5-22. PORTAD Field Descriptions

| Field            | Description                                                                                                                                                                                                                                                                                                                                                                   |
|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–0<br>PTAD[7:0] | <b>A/D Channel x (ANx) Digital Input (x = 7, 6, 5, 4, 3, 2, 1, 0)</b> — If the digital input buffer on the ANx pin is enabled (IENx = 1) or channel x is enabled as external trigger (ETRIGE = 1,ETRIGCH[2–0] = x,ETRIGSEL = 0) read returns the logic level on ANx pin (signal potentials not meeting $V_{IL}$ or $V_{IH}$ specifications will have an indeterminate value). |
|                  | If the digital input buffers are disabled (IENx = 0) and channel x is not enabled as external trigger, read returns a "1".                                                                                                                                                                                                                                                    |
|                  | Reset sets all PORTAD0 bits to "1".                                                                                                                                                                                                                                                                                                                                           |



# CMPL

Compare Immediate 8 bit Constant (Low Byte)



## Operation

 $RS.L - IMM8 \Rightarrow NONE$ , only condition code flags get updated

Subtracts the 8 bit constant IMM8 contained in the instruction code from the low byte of the source register RS.L using binary subtraction and updates the condition code register accordingly.

Remark: There is no equivalent operation using triadic addressing. Comparing the values of two registers can be performed by using the subtract instruction with R0 as destination register.

## **CCR Effects**



- N: Set if bit 7 of the result is set; cleared otherwise.
- Z: Set if the 8 bit result is \$00; cleared otherwise.
- V: Set if a two's complement overflow resulted from the 8 bit operation; cleared otherwise. RS[7] &  $\overline{IMM8[7]}$  &  $\overline{result[7]} | \overline{RS[7]} & IMM8[7] & result[7]$
- C: Set if there is a carry from the Bit 7 to Bit 8 of the result; cleared otherwise.  $\overline{RS[7]}$  & IMM8[7] |  $\overline{RS[7]}$  & result[7] | IMM8[7] & result[7]

## Code and CPU Cycles

| Source Form    | Address<br>Mode |   | Machine Code |   |   |   |    |      | Cycles |
|----------------|-----------------|---|--------------|---|---|---|----|------|--------|
| CMPL RS, #IMM8 | IMM8            | 1 | 1            | 0 | 1 | 0 | RS | IMM8 | Р      |



#### Chapter 8 Pulse-Width Modulator (S12PWM8B8CV1)

| Register<br>Name |        | Bit 7 | 6                           | 5 | 4 | 3 | 2 | 1 | Bit 0 |
|------------------|--------|-------|-----------------------------|---|---|---|---|---|-------|
| PWMCNT0          | R      | Bit 7 | 6                           | 5 | 4 | 3 | 2 | 1 | Bit 0 |
|                  | w      | 0     | 0                           | 0 | 0 | 0 | 0 | 0 | 0     |
| PWMCNT1          | R      | Bit 7 | 6                           | 5 | 4 | 3 | 2 | 1 | Bit 0 |
|                  | w      | 0     | 0                           | 0 | 0 | 0 | 0 | 0 | 0     |
| PWMCNT2          | R      | Bit 7 | 6                           | 5 | 4 | 3 | 2 | 1 | Bit 0 |
|                  | w      | 0     | 0                           | 0 | 0 | 0 | 0 | 0 | 0     |
| PWMCNT3          | R      | Bit 7 | 6                           | 5 | 4 | 3 | 2 | 1 | Bit 0 |
|                  | w      | 0     | 0                           | 0 | 0 | 0 | 0 | 0 | 0     |
| PWMCNT4          | R      | Bit 7 | 6                           | 5 | 4 | 3 | 2 | 1 | Bit 0 |
|                  | w      | 0     | 0                           | 0 | 0 | 0 | 0 | 0 | 0     |
| PWMCNT5          | R      | Bit 7 | 6                           | 5 | 4 | 3 | 2 | 1 | Bit 0 |
|                  | w      | 0     | 0                           | 0 | 0 | 0 | 0 | 0 | 0     |
|                  | R<br>R | Bit 7 | 6                           | 5 | 1 | 3 | 2 | 1 | Bit 0 |
|                  | w      | 0     | 0                           | 0 | 0 | 0 | 0 | 0 | 0     |
|                  | ا<br>م | D:4 7 |                             |   |   |   | 2 | 4 | Dit O |
| PVVIVICINT/      | ĸ      |       | 6                           | 5 | 4 | 3 | 2 | 0 |       |
|                  | ••[    | 0     | 0                           | 0 | 0 | 0 | 0 | 0 | 0     |
| PWMPER0          | R<br>W | Bit 7 | 6                           | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| PWMPER1          | R<br>W | Bit 7 | 6                           | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| PWMPER2          | R<br>W | Bit 7 | 6                           | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| PWMPER3          | R<br>W | Bit 7 | 6                           | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| PWMPER4          | R<br>W | Bit 7 | 6                           | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| PWMPER5          | R<br>W | Bit 7 | 6                           | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| PWMPER6          | R<br>W | Bit 7 | 6                           | 5 | 4 | 3 | 2 | 1 | Bit 0 |
|                  | [      |       | = Unimplemented or Reserved |   |   |   |   |   |       |

## Figure 8-2. PWM Register Summary (Sheet 2 of 3)



To calculate the output frequency in center aligned output mode for a particular channel, take the selected clock source frequency for the channel (A, B, SA, or SB) and divide it by twice the value in the period register for that channel.

- PWMx Frequency = Clock (A, B, SA, or SB) / (2\*PWMPERx)
- PWMx Duty Cycle (high time as a% of period):

```
— Polarity = 0 (PPOLx = 0)
```

```
Duty Cycle = [(PWMPERx-PWMDTYx)/PWMPERx] * 100%
```

```
— Polarity = 1 (PPOLx = 1)
```

```
Duty Cycle = [PWMDTYx / PWMPERx] * 100%
```



## NOTE

The CANTBSEL 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: Find the lowest ordered bit set to 1, all other bits will be read as 0 Write: Anytime when not in initialization mode

#### Table 10-15. CANTBSEL Register Field Descriptions

| Field          | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2:0<br>TX[2:0] | <b>Transmit Buffer Select</b> — The lowest numbered bit places the respective transmit buffer in the CANTXFG register space (e.g., TX1 = 1 and TX0 = 1 selects transmit buffer TX0; TX1 = 1 and TX0 = 0 selects transmit buffer TX1). Read and write accesses to the selected transmit buffer will be blocked, if the corresponding TXEx bit is cleared and the buffer is scheduled for transmission (see Section 10.3.2.7, "MSCAN Transmitter Flag Register (CANTFLG)").<br>0 The associated message buffer is deselected<br>1 The associated message buffer is selected, if lowest numbered bit |

The following gives a short programming example of the usage of the CANTBSEL register:

To get the next available transmit buffer, application software must read the CANTFLG register and write this value back into the CANTBSEL register. In this example Tx buffers TX1 and TX2 are available. The value read from CANTFLG is therefore 0b0000\_0110. When writing this value back to CANTBSEL, the Tx buffer TX1 is selected in the CANTXFG because the lowest numbered bit set to 1 is at bit position 1. Reading back this value out of CANTBSEL results in 0b0000\_0010, because only the lowest numbered bit position set to 1 is presented. This mechanism eases the application software the selection of the next available Tx buffer.

- LDD CANTFLG; value read is 0b0000\_0110
- STD CANTBSEL; value written is 0b0000\_0110
- LDD CANTBSEL; value read is 0b0000\_0010

If all transmit message buffers are deselected, no accesses are allowed to the CANTXFG registers.

## 10.3.2.12 MSCAN Identifier Acceptance Control Register (CANIDAC)

The CANIDAC register is used for identifier acceptance control as described below.





or

• the CPU clears the SLPRQ bit

#### NOTE

The CPU cannot clear the SLPRQ bit before sleep mode (SLPRQ = 1 and SLPAK = 1) is active.

After wake-up, the MSCAN waits for 11 consecutive recessive bits to synchronize to the CAN bus. As a consequence, if the MSCAN is woken-up by a CAN frame, this frame is not received.

The receive message buffers (RxFG and RxBG) contain messages if they were received before sleep mode was entered. All pending actions will be executed upon wake-up; copying of RxBG into RxFG, message aborts and message transmissions. If the MSCAN remains in bus-off state after sleep mode was exited, it continues counting the 128 occurrences of 11 consecutive recessive bits.





## 10.4.5.5 MSCAN Initialization Mode

In initialization mode, any on-going transmission or reception is immediately aborted and synchronization to the CAN bus is lost, potentially causing CAN protocol violations. To protect the CAN bus system from fatal consequences of violations, the MSCAN immediately drives the TXCAN pin into a recessive state.





MC9S12XDP512 Data Sheet, Rev. 2.21

I

(DBGXCTL)". Comparators must be enabled by setting the comparator enable bit in the associated DBGXCTL control register.

| Field          | Description                                                                                                                                                                                                                                                                                                                                                                              |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3–0<br>SC[3:0] | <b>State Control Bits</b> — These bits select the targeted next state while in State3, based upon the match event. The trigger priorities described in Table 19-38 dictate that in the case of simultaneous matches, the match on the lower channel number (0,1,2,3) has priority. The SC[3:0] encoding ensures that a match leading to final state has priority over all other matches. |

#### Table 19-24. DBGSCR3 Field Descriptions

#### Table 19-25. State3 Sequencer Next State Selection

| SC[3:0] | Description                                                                           |
|---------|---------------------------------------------------------------------------------------|
| 0000    | Any match triggers to state1                                                          |
| 0001    | Any match triggers to state2                                                          |
| 0010    | Any match triggers to final state                                                     |
| 0011    | Match0 triggers to State1 Other matches have no effect                                |
| 0100    | Match0 triggers to State2 Other matches have no effect                                |
| 0101    | Match0 triggers to final state Other matches have no effect                           |
| 0110    | Match1 triggers to State1 Other matches have no effect                                |
| 0111    | Match1 triggers to State2 Other matches have no effect                                |
| 1000    | Match1 triggers to final state Other matches have no effect                           |
| 1001    | Match2 triggers to State2 Match0 triggers to final state Other matches have no effect |
| 1010    | Match1 triggers to State1 Match3 triggers to State2 Other matches have no effect      |
| 1011    | Match3 triggers to State2 Match1 triggers to final state Other matches have no effect |
| 1100    | Match2 triggers to final state Other matches have no effect                           |
| 1101    | Match3 triggers to final state Other matches have no effect                           |
| 1110    | Reserved                                                                              |
| 1111    | Reserved                                                                              |

## 19.3.1.11 Comparator Register Descriptions

Each comparator has a bank of registers that are visible through an 8-byte window in the DBG module register address map. Comparators A and C consist of 8 register bytes (3 address bus compare registers, 2 data bus compare registers, 2 data bus mask registers and a control register).

Comparators B and D consist of 4 register bytes (3 address bus compare registers and a control register).

Each set of comparator registers is accessible in the same 8-byte window of the register address map and can be accessed using the COMRV bits in the DBGC1 register. If the Comparators B or D are accessed through the 8-byte window, then only the address and control bytes are visible, the 4 bytes associated with data bus and data bus masking read as 0 and cannot be written. Furthermore the control registers for comparators B and D differ from those of comparators A and C.

Table 19-26. Comparator Register Layout

| 0x0028 | CONTROL | Read/Write |  |
|--------|---------|------------|--|
|        | -       |            |  |

MC9S12XDP512 Data Sheet, Rev. 2.21



# 23.0.5.12 S12X\_EBI Ports Reduced Drive Register (RDRIV)



#### Figure 23-14. S12X\_EBI Ports Reduced Drive Register (RDRIV)

Read: Anytime. In emulation modes, read operations will return the data from the external bus, in all other modes the data source is depending on the data direction value.

Write: Anytime. In emulation modes, write operations will also be directed to the external bus.

This register is used to select reduced drive for the pins associated with ports A, B, E, and K. If enabled, the pins drive at about 1/6 of the full drive strength. The reduced drive function is independent of which function is being used on a particular pin.

The reduced drive functionality does not take effect on the pins in emulation modes.

| Field     | Description                                                                                                                                     |
|-----------|-------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>RDPK | Reduced Drive of Port K         0 All port K output pins have full drive enabled.         1 All port K output pins have reduced drive enabled.  |
| 4<br>RDPE | Reduced Drive of Port E         0 All port E output pins have full drive enabled.         1 All port E output pins have reduced drive enabled.  |
| 3<br>RDPD | Reduced Drive of Port D         0 All port D output pins have full drive enabled.         1 All port D output pins have reduced drive enabled.  |
| 2<br>RDPC | Reduced Drive of Port C         0 All port C output pins have full drive enabled.         1 All port C output pins have reduced drive enabled.  |
| 1<br>RDPB | Reduced Drive of Port B0 All port B output pins have full drive enabled.1 All port B output pins have reduced drive enabled.                    |
| 0<br>RDPA | Reduced Drive of Ports A         0 All Port A output pins have full drive enabled.         1 All port A output pins have reduced drive enabled. |

#### Table 23-15. RDRIV Field Descriptions



#### Table 24-42. RDRH Field Descriptions

| Field            | Description                                                                                                                                              |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–0<br>RDRH[7:0] | <ul> <li>Reduced Drive Port H</li> <li>Full drive strength at output.</li> <li>Associated pin drives at about 1/6 of the full drive strength.</li> </ul> |

# 24.0.5.46 Port H Pull Device Enable Register (PERH)



Figure 24-48. Port H Pull Device Enable Register (PERH)

Read: Anytime.

Write: Anytime.

This register configures whether a pull-up or a pull-down device is activated, if the port is used as input. This bit has no effect if the port is used as output. Out of reset no pull device is enabled.

#### Table 24-43. PERH Field Descriptions

| Field            | Description                                                                                                           |
|------------------|-----------------------------------------------------------------------------------------------------------------------|
| 7–0<br>PERH[7:0] | Pull Device Enable Port H0 Pull-up or pull-down device is disabled.1 Either a pull-up or pull-down device is enabled. |

## 24.0.5.47 Port H Polarity Select Register (PPSH)

| _      | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|--------|-------|-------|-------|-------|-------|-------|-------|-------|
| R<br>W | PPSH7 | PPSH6 | PPSH5 | PPSH4 | PPSH3 | PPSH2 | PPSH1 | PPSH0 |
| Reset  | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |

#### Figure 24-49. Port H Polarity Select Register (PPSH)

Read: Anytime.

Write: Anytime.

This register serves a dual purpose by selecting the polarity of the active interrupt edge as well as selecting a pull-up or pull-down device if enabled.

25 2 Kbyte EEPROM Module (S12XEETX2KV1)

then 182 kHz. In this case, the EEPROM program and erase algorithm timings are increased over the optimum target by:

 $(200 - 182)/200 \times 100 = 9\%$ 

## CAUTION

Program and erase command execution time will increase proportionally with the period of EECLK. Because of the impact of clock synchronization on the accuracy of the functional timings, programming or erasing the EEPROM memory cannot be performed if the bus clock runs at less than 1 MHz. Programming or erasing the EEPROM memory with EECLK < 150 kHz should be avoided. Setting ECLKDIV to a value such that EECLK < 150 kHz can destroy the EEPROM memory due to overstress. Setting ECLKDIV to a value such that (1/EECLK+Tbus) < 5  $\mu$ s can result in incomplete programming or erasure of the EEPROM memory cells.

If the ECLKDIV register is written, the EDIVLD bit is set automatically. If the EDIVLD bit is 0, the ECLKDIV register has not been written since the last reset. If the ECLKDIV register has not been written to, the EEPROM command loaded during a command write sequence will not execute and the ACCERR flag in the ESTAT register will set.



# 25.4.2.6 Sector Modify Command

The sector modify operation will erase both words in a sector of EEPROM memory followed by a reprogram of the addressed word using an embedded algorithm.

An example flow to execute the sector modify operation is shown in Figure 25-23. The sector modify command write sequence is as follows:

- 1. Write to an EEPROM memory address to start the command write sequence for the sector modify command. The EEPROM address written determines the sector to be erased and word to be reprogrammed while byte address bit 0 is ignored.
- 2. Write the sector modify command, 0x60, to the ECMD register.
- 3. Clear the CBEIF flag in the ESTAT register by writing a 1 to CBEIF to launch the sector erase command.

If an EEPROM sector to be modified is in a protected area of the EEPROM memory, the PVIOL flag in the ESTAT register will set and the sector modify command will not launch. Once the sector modify command has successfully launched, the CCIF flag in the ESTAT register will set after the sector modify operation has completed unless a new command write sequence has been buffered.



| Conditions are 4.5 V < $V_{DD35}$ < 5.5 V Temperature from -40°C to +140°C, unless otherwise noted |   |                    |                  |      |     |      |      |  |  |
|----------------------------------------------------------------------------------------------------|---|--------------------|------------------|------|-----|------|------|--|--|
| Num                                                                                                | С | Rating             | Symbol           | Min  | Тур | Max  | Unit |  |  |
| 1                                                                                                  | Р | Input high voltage | VIH              | 1.75 | —   | —    | V    |  |  |
| 2                                                                                                  | Р | Input low voltage  | VIL              | _    | —   | 0.75 | V    |  |  |
| 3                                                                                                  | С | Input hysteresis   | V <sub>HYS</sub> | _    | 100 | —    | mV   |  |  |

#### Table A-8. I/O Characteristics for Port C, D, PE5, PE6, and PK7 for Reduced Input Voltage Thresholds

# A.1.10 Supply Currents

This section describes the current consumption characteristics of the device as well as the conditions for the measurements.

## A.1.10.1 Measurement Conditions

All measurements are without output loads. Unless otherwise noted the currents are measured in single chip mode and the CPU and XGATE code is executed from RAM,  $V_{DD35}=5.5V$ , internal voltage regulator is enabled and the bus frequency is 40MHz using a 4-MHz external clock source (PE7= $\overline{XCLKS}=0$ ). Production testing is performed using a square wave signal at the EXTAL input.



| Conditions are shown in Table A-4 unless otherwise noted |   |                                                            |                    |     |      |      |                |  |
|----------------------------------------------------------|---|------------------------------------------------------------|--------------------|-----|------|------|----------------|--|
| Num                                                      | С | Rating                                                     | Symbol             | Min | Тур  | Max  | Unit           |  |
| 1                                                        | Ρ | Self clock mode frequency                                  | f <sub>SCM</sub>   | 1   | _    | 5.5  | MHz            |  |
| 2                                                        | D | VCO locking range                                          | f <sub>VCO</sub>   | 8   | —    | 80   | MHz            |  |
| 3                                                        | D | Lock detector transition from acquisition to tracking mode | $ \Delta_{trk} $   | 3   | —    | 4    | % <sup>1</sup> |  |
| 4                                                        | D | Lock detection                                             | $ \Delta_{Lock} $  | 0   | —    | 1.5  | % <sup>1</sup> |  |
| 5                                                        | D | Unlock detection                                           | $ \Delta_{unl} $   | 0.5 | —    | 2.5  | % <sup>1</sup> |  |
| 6                                                        | D | Lock detector transition from tracking to acquisition mode | $ \Delta_{unt} $   | 6   | —    | 8    | % <sup>1</sup> |  |
| 7                                                        | С | PLLON total stabilization delay (auto mode) <sup>2</sup>   | t <sub>stab</sub>  | _   | 0.24 | —    | ms             |  |
| 8                                                        | D | PLLON acquisition mode stabilization delay <sup>2</sup>    | t <sub>acq</sub>   | _   | 0.09 | —    | ms             |  |
| 9                                                        | D | PLLON tracking mode stabilization delay <sup>2</sup>       | t <sub>al</sub>    | _   | 0.16 | —    | ms             |  |
| 10                                                       | D | Fitting parameter VCO loop gain                            | K <sub>1</sub>     | —   | -195 | —    | MHz/V          |  |
| 11                                                       | D | Fitting parameter VCO loop frequency                       | f <sub>1</sub>     | _   | 126  | _    | MHz            |  |
| 12                                                       | D | Charge pump current acquisition mode                       | i <sub>ch</sub>    | _   | 38.5 | —    | μA             |  |
| 13                                                       | D | Charge pump current tracking mode                          | ∣i <sub>ch</sub> ∣ | _   | 3.5  | —    | μA             |  |
| 14                                                       | С | Jitter fit parameter 1 <sup>2</sup>                        | j <sub>1</sub>     |     | 0.9  | 1.3  | %              |  |
| 15                                                       | С | Jitter fit parameter 2 <sup>2</sup>                        | j <sub>2</sub>     |     | 0.02 | 0.12 | %              |  |

#### Table A-23. PLL Characteristics

<sup>1</sup> % deviation from target frequency

 $^2$  f<sub>osc</sub> = 4 MHz, f<sub>BUS</sub> = 40 MHz equivalent f<sub>VCO</sub> = 80 MHz: REFDV = #\$00, SYNR = #\$09, C<sub>S</sub> = 4.7 nF, C<sub>P</sub> = 470 pF, R<sub>S</sub> = 4.7 k\Omega

# A.6 MSCAN

#### Table A-24. MSCAN Wake-up Pulse Characteristics

| Conditions are shown in Table A-4 unless otherwise noted |   |                                      |                  |     |     |     |      |  |
|----------------------------------------------------------|---|--------------------------------------|------------------|-----|-----|-----|------|--|
| Num                                                      | С | Rating                               | Symbol           | Min | Тур | Max | Unit |  |
| 1                                                        | Р | MSCAN wakeup dominant pulse filtered | t <sub>WUP</sub> | _   | _   | 2   | μs   |  |
| 2                                                        | Р | MSCAN wakeup dominant pulse pass     | t <sub>WUP</sub> | 5   | —   | —   | μs   |  |



| No. | c | Characteristic <sup>1</sup>             | Symbol            | 1 Stretch<br>Cycle |      | 2 Stretch<br>Cycles |      | 3 Stretch<br>Cycles |      | Unit |
|-----|---|-----------------------------------------|-------------------|--------------------|------|---------------------|------|---------------------|------|------|
|     |   |                                         |                   | Min                | Max  | Min                 | Max  | Min                 | Max  |      |
| —   | — | Internal cycle time                     | t <sub>cyc</sub>  | 25                 | 25   | 25                  | 25   | 25                  | 25   | ns   |
| 1   | — | Cycle time                              | t <sub>cyce</sub> | 50                 | ∞    | 75                  | ∞    | 100                 | ∞    | ns   |
| 2   | D | Pulse width, E high                     | PW <sub>EH</sub>  | 11.5               | 14   | 11.5                | 14   | 11.5                | 14   | ns   |
| 3   | D | E falling to sampling E rising          | t <sub>EFSR</sub> | 35                 | 39.5 | 60                  | 64.5 | 85                  | 89.5 | ns   |
| 4   | D | Address delay time                      | t <sub>AD</sub>   | —                  | 5    | _                   | 5    | —                   | 5    | ns   |
| 5   | D | Address hold time                       | t <sub>AH</sub>   | 0                  | —    | 0                   | —    | 0                   | —    | ns   |
| 6   | D | IVD delay time <sup>2</sup>             | t <sub>IVDD</sub> | —                  | 4.5  | _                   | 4.5  | —                   | 4.5  | ns   |
| 7   | D | IVD hold time <sup>2</sup>              | t <sub>IVDH</sub> | 0                  | —    | 0                   | —    | 0                   | _    | ns   |
| 8   | D | Read data setup time Maskset L15Y       | t <sub>DSR</sub>  | 12                 | —    | 12                  | —    | 12                  | _    | ns   |
|     | D | Read data setup time Maskset M84E       | t <sub>DSR</sub>  | 15                 | —    | 15                  | —    | 15                  | _    | ns   |
| 9   | D | Read data hold time                     | t <sub>DHR</sub>  | 0                  | —    | 0                   | —    | 0                   | _    | ns   |
| 10  | D | Write data delay time                   | t <sub>DDW</sub>  | _                  | 5    | _                   | 5    | _                   | 5    | ns   |
| 11  | D | Write data hold time                    | t <sub>DHW</sub>  | 0                  | _    | 0                   | _    | 0                   | _    | ns   |
| 12  | D | Read/write data delay time <sup>3</sup> | t <sub>RWD</sub>  | -1                 | 5    | -1                  | 5    | -1                  | 5    | ns   |

# Table A-31. Example 2b: Emulation Expanded Mode Timing $V_{DD35} = 5.0 \text{ V}$ (EWAITE = 0)

Typical supply and silicon, room temperature only
 Includes also ACCx, IQSTATx

<sup>3</sup> Includes LSTRB