# E·XFL

#### NXP USA Inc. - S912ZVC12F0MKH Datasheet



#### Welcome to <u>E-XFL.COM</u>

#### What is "Embedded - Microcontrollers"?

"Embedded - Microcontrollers" refer to small, integrated circuits designed to perform specific tasks within larger systems. These microcontrollers are essentially compact computers on a single chip, containing a processor core, memory, and programmable input/output peripherals. They are called "embedded" because they are embedded within electronic devices to control various functions, rather than serving as standalone computers. Microcontrollers are crucial in modern electronics, providing the intelligence and control needed for a wide range of applications.

Applications of "<u>Embedded -</u> <u>Microcontrollers</u>"

#### Details

| Product Status             | Active                                                                 |
|----------------------------|------------------------------------------------------------------------|
| Core Processor             | S12Z                                                                   |
| Core Size                  | 16-Bit                                                                 |
| Speed                      | 32MHz                                                                  |
| Connectivity               | CANbus, I <sup>2</sup> C, SCI, SPI                                     |
| Peripherals                | DMA, POR, PWM, WDT                                                     |
| Number of I/O              | 42                                                                     |
| Program Memory Size        | 128KB (128K x 8)                                                       |
| Program Memory Type        | FLASH                                                                  |
| EEPROM Size                | 2K x 8                                                                 |
| RAM Size                   | 8K x 8                                                                 |
| Voltage - Supply (Vcc/Vdd) | 3.5V ~ 40V                                                             |
| Data Converters            | A/D 16x10b; D/A 1x8b                                                   |
| Oscillator Type            | Internal                                                               |
| Operating Temperature      | -40°C ~ 125°C (TA)                                                     |
| Mounting Type              | Surface Mount                                                          |
| Package / Case             | 64-LQFP Exposed Pad                                                    |
| Supplier Device Package    | 64-LQFP (10x10)                                                        |
| Purchase URL               | https://www.e-xfl.com/product-detail/nxp-semiconductors/s912zvc12f0mkh |

Email: info@E-XFL.COM

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

| Global<br>Address | Register<br>Name |        | Bit 7    | 6        | 5        | 4        | 3        | 2        | 1        | Bit 0    |
|-------------------|------------------|--------|----------|----------|----------|----------|----------|----------|----------|----------|
| 0x028A-<br>0x028B | Reserved         | R<br>W | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        |
| 0x028C            | PIEADH           | R<br>W | PIEADH7  | PIEADH6  | PIEADH5  | PIEADH4  | PIEADH3  | PIEADH2  | PIEADH1  | PIEADH0  |
| 0x028D            | PIEADL           | R<br>W | PIEADL7  | PIEADL6  | PIEADL5  | PIEADL4  | PIEADL3  | PIEADL2  | PIEADL1  | PIEADL0  |
| 0x028E            | PIFADH           | R<br>W | PIFADH7  | PIFADH6  | PIFADH5  | PIFADH4  | PIFADH3  | PIFADH2  | PIFADH1  | PIFADH0  |
| 0x028F            | PIFADL           | R<br>W | PIFADL7  | PIFADL6  | PIFADL5  | PIFADL4  | PIFADL3  | PIFADL2  | PIFADL1  | PIFADL0  |
| 0x0290–<br>0x0297 | Reserved         | R<br>W | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        |
| 0x0298            | DIENADH          | R<br>W | DIENADH7 | DIENADH6 | DIENADH5 | DIENADH4 | DIENADH3 | DIENADH2 | DIENADH1 | DIENADH0 |
| 0x0299            | DIENADL          | R<br>W | DIENADL7 | DIENADL6 | DIENADL5 | DIENADL4 | DIENADL3 | DIENADL2 | DIENADL1 | DIENADL0 |
| 0x029A–<br>0x02BF | Reserved         | R<br>W | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        |
| 0x02C0            | РТТ              | R<br>W | PTT7     | PTT6     | PTT5     | PTT4     | PTT3     | PTT2     | PTT1     | PTT0     |
| 0x02C1            | PTIT             | R<br>W | PTIT7    | PTIT6    | PTIT5    | PTIT4    | PTIT3    | PTIT2    | PTIT1    | PTITO    |
| 0x02C2            | DDRT             | R<br>W | DDRT7    | DDRT6    | DDRT5    | DDRT4    | DDRT3    | DDRT2    | DDRT1    | DDRT0    |
| 0x02C3            | PERT             | R<br>W | PERT7    | PERT6    | PERT5    | PERT4    | PERT3    | PERT2    | PERT1    | PERT0    |
| 0x02C4            | PPST             | R<br>W | PPST7    | PPST6    | PPST5    | PPST4    | PPST3    | PPST2    | PPST1    | PPST0    |
| 0x02C5-<br>0x02CE | Reserved         | R<br>W | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        |
| 0x02CF            | Reserved         | R<br>W | 0        | 0        | 0        | 0        | 0        | 0        | 0        | 0        |

MC9S12ZVC Family Reference Manual, Rev. 2.0

#### **Port L Input Register (PTIL)** 2.3.4.4

Address 0x0331



Figure 2-24. Port L Input Register (PTIL)

1 Read: Anytime Write: No Write

#### Table 2-24. PTIL - Register Field Descriptions

| Field   | Description                                                                                                                                                                                                                                                                                                        |
|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1-0     | <b>Port Input Data Register Port L</b> —                                                                                                                                                                                                                                                                           |
| PTIL1-0 | A read returns the synchronized input state if the associated HVI pin is used in digital mode, that is the related DIENL bit is set to 1 and the pin is not used in analog mode (PTAENL=0). See Section 2.3.4.10, "Port L ADC Connection Enable Register (PTAENL)". A one is read in any other case <sup>1</sup> . |

<sup>1</sup> Refer to PTTEL bit description in Section 2.3.4.12, "Port L Test Enable Register (PTTEL) for an override condition.

#### **Port L Pull Select Register (PTPSL)** 2.3.4.5



Figure 2-25. Port L Pull Select Register (PTPSL)

Read: Anytime

1

Write: Anytime

#### Table 2-25. PTPSL Register Field Descriptions

| Field           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1-0<br>PTPSL1-0 | <b>Port L Pull Select</b> —<br>This bit selects a pull device on the HVI pin in analog mode for open input detection. By default a pulldown device is active as part of the input voltage divider. If this bit set to 1 and PTTEL=1 and not in stop mode a pullup to a level close to $V_{DDX}$ takes effect and overrides the weak pulldown device. Refer to Section 2.5.5, "Open Input Detection on PL[1:0] (HVI)"). 1 Pullup enabled<br>0 Pulldown enabled |

#### Chapter 3 Background Debug Controller (S12ZBDCV2)

The BDC serial interface uses a clocking scheme in which the external host generates a falling edge on the BKGD pin to indicate the start of each bit time. This falling edge is sent for every bit whether data is transmitted or received. Data is transferred most significant bit (MSB) first at 16 target clock cycles per bit. The interface times out if during a command 512 clock cycles occur between falling edges from the host. The timeout forces the current command to be discarded.

The BKGD pin is a pseudo open-drain pin and has a weak on-chip active pull-up that is enabled at all times. It is assumed that there is an external pull-up and that drivers connected to BKGD do not typically drive the high level. Since R-C rise time could be unacceptably long, the target system and host provide brief drive-high (speedup) pulses to drive BKGD to a logic 1. The source of this speedup pulse is the host for transmit cases and the target for receive cases.

The timing for host-to-target is shown in Figure 3-6 and that of target-to-host in Figure 3-7 and Figure 3-8. All cases begin when the host drives the BKGD pin low to generate a falling edge. Since the host and target operate from separate clocks, it can take the target up to one full clock cycle to recognize this edge; this synchronization uncertainty is illustrated in Figure 3-6. The target measures delays from this perceived start of the bit time while the host measures delays from the point it actually drove BKGD low to start the bit up to one target clock cycle earlier. Synchronization between the host and target is established in this manner at the start of every bit time.

Figure 3-6 shows an external host transmitting a logic 1 and transmitting a logic 0 to the BKGD pin of a target system. The host is asynchronous to the target, so there is up to a one clock-cycle delay from the host-generated falling edge to where the target recognizes this edge as the beginning of the bit time. Ten target clock cycles later, the target senses the bit level on the BKGD pin. Internal glitch detect logic requires the pin be driven high no later than eight target clock cycles after the falling edge for a logic 1 transmission.

Since the host drives the high speedup pulses in these two cases, the rising edges look like digitally driven signals.



Figure 3-6. BDC Host-to-Target Serial Bit Timing

Figure 3-7 shows the host receiving a logic 1 from the target system. The host holds the BKGD pin low long enough for the target to recognize it (at least two target clock cycles). The host must release the low

#### Chapter 5 S12Z Interrupt (S12ZINTV0)

| Address   | Register<br>Name |   | Bit 7 | 6          | 5              | 4     | 3 | 2            | 1             | Bit 0 |
|-----------|------------------|---|-------|------------|----------------|-------|---|--------------|---------------|-------|
| 0x00001D  | INT_CFDATA5      | R | 0     | 0          | 0              | 0     | 0 | PRIOLVL[2:0] |               |       |
|           |                  | W |       |            |                |       |   |              |               |       |
| 0x00001E  | INT CFDATA6      | R | 0     | 0          | 0              | 0     | 0 |              |               |       |
| 0.1000012 |                  | w |       | •          |                | •     |   | PRIOLVL[2:0] |               |       |
|           |                  |   |       |            |                |       |   | L            |               |       |
| 0x00001F  | INT_CFDATA7      | R | 0     | 0          | 0              | 0     | 0 |              | DDIOLVI [2.0] | 1     |
|           |                  | W |       |            |                |       |   |              | PRIOLVL[2.0]  | J     |
|           |                  |   |       | = Unimplem | nented or Rese | erved |   |              |               |       |



### 5.3.2.1 Interrupt Vector Base Register (IVBR)

Address: 0x000010



Figure 5-3. Interrupt Vector Base Register (IVBR)

Read: Anytime

Write: Anytime

| Table 5-4 | . IVBR | Field | Descriptions |
|-----------|--------|-------|--------------|
|-----------|--------|-------|--------------|

| Field                      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|----------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15–1<br>IVB_ADDR<br>[15:1] | <ul> <li>Interrupt Vector Base Address Bits — These bits represent the upper 15 bits of all vector addresses. Out of reset these bits are set to 0xFFFE (i.e., vectors are located at 0xFFFE00-0xFFFFF).</li> <li>Note: A system reset will initialize the interrupt vector base register with "0xFFFE" before it is used to determine the reset vector address. Therefore, changing the IVBR has no effect on the location of the reset vector (0xFFFFC-0xFFFFFF).</li> </ul> |

Chapter 6 S12Z DebugLite (S12ZDBGV3) Module

| Address           | Name     |        | Bit 7        | 6            | 5    | 4    | 3       | 2   | 1        | Bit 0  |  |
|-------------------|----------|--------|--------------|--------------|------|------|---------|-----|----------|--------|--|
| 0x0111-           | Reserved | R      | 0            | 0            | 0    | 0    | 0       | 0   | 0        | 0      |  |
| 0x0114            |          | w      |              |              |      |      |         |     |          |        |  |
| 0x0115            | DBGAAH   | R<br>W |              | DBGAA[23:16] |      |      |         |     |          |        |  |
| 0x0116            | DBGAAM   | R<br>W |              |              |      | DBGA | A[15:8] |     |          |        |  |
| 0x0117            | DBGAAL   | R<br>W |              |              |      | DBGA | A[7:0]  |     |          |        |  |
| 0x0118            | DBGAD0   | R<br>W | Bit 31       | 30           | 29   | 28   | 27      | 26  | 25       | Bit 24 |  |
| 0x0119            | DBGAD1   | R<br>W | Bit 23       | 22           | 21   | 20   | 19      | 18  | 17       | Bit 16 |  |
| 0x011A            | DBGAD2   | R<br>W | Bit 15       | 14           | 13   | 12   | 11      | 10  | 9        | Bit 8  |  |
| 0x011B            | DBGAD3   | R<br>W | Bit 7        | 6            | 5    | 4    | 3       | 2   | 1        | Bit 0  |  |
| 0x011C            | DBGADM0  | R<br>W | Bit 31       | 30           | 29   | 28   | 27      | 26  | 25       | Bit 24 |  |
| 0x011D            | DBGADM1  | R<br>W | Bit 23       | 22           | 21   | 20   | 19      | 18  | 17       | Bit 16 |  |
| 0x011E            | DBGADM2  | R<br>W | Bit 15       | 14           | 13   | 12   | 11      | 10  | 9        | Bit 8  |  |
| 0x011F            | DBGADM3  | R<br>W | Bit 7        | 6            | 5    | 4    | 3       | 2   | 1        | Bit 0  |  |
| 0x0120            | DBGBCTL  | R<br>W | 0            | 0            | INST | 0    | RW      | RWE | reserved | COMPE  |  |
| 0x0121-           | Reserved | R      | 0            | 0            | 0    | 0    | 0       | 0   | 0        | 0      |  |
| 0x0124            | Reserved | W      |              |              |      |      |         |     |          |        |  |
| 0x0125            | DBGBAH   | R<br>W | DBGBA[23:16] |              |      |      |         |     |          |        |  |
| 0x0126            | DBGBAM   | R<br>W | DBGBA[15:8]  |              |      |      |         |     |          |        |  |
| 0x0127            | DBGBAL   | R<br>W | DBGBA[7:0]   |              |      |      |         |     |          |        |  |
| 0x0128-<br>0x012F | Reserved | R<br>W | 0            | 0            | 0    | 0    | 0       | 0   | 0        | 0      |  |
| 0x0130-<br>0x013F | Reserved | R<br>W | 0            | 0            | 0    | 0    | 0       | 0   | 0        | 0      |  |

Figure 6-2. Quick Reference to DBG Registers

MC9S12ZVC Family Reference Manual, Rev. 2.0

### 6.3.2.5 Debug State Control Register 3 (DBGSCR3)

Address: 0x0109



Read: Anytime.

Write: If DBG is not armed.

The state control register three selects the targeted next state whilst in State3. The matches refer to the outputs of the comparator match control logic as depicted in Figure 6-1 and described in Section 6.3.2.8, "Debug Comparator A Control Register (DBGACTL)". Comparators must be enabled by setting the comparator enable bit in the associated DBGxCTL control register.

| Field            | Description                                                                                                                                                                                                                      |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1–0              | Channel 0 State Control.                                                                                                                                                                                                         |
| C0SC[1:0]        | These bits select the targeted next state whilst in State3 following a match0.                                                                                                                                                   |
| 3–2              | Channel 1 State Control.                                                                                                                                                                                                         |
| C1SC[1:0]        | These bits select the targeted next state whilst in State3 following a match1.                                                                                                                                                   |
| 7–6<br>C3SC[1:0] | Channel 3 State Control.<br>If EEVE !=10, these bits select the targeted next state whilst in State3 following a match3.<br>If EEVE =10, these bits select the targeted next state whilst in State3 following an external event. |

Table 6-12. State3 Match State Sequencer Transitions

| CxSC[1:0] | Function                              |
|-----------|---------------------------------------|
| 00        | Match has no effect                   |
| 01        | Match forces sequencer to State1      |
| 10        | Match forces sequencer to State2      |
| 11        | Match forces sequencer to Final State |

In the case of simultaneous matches, the match on the higher channel number (3....0) has priority.

### 6.3.2.6 Debug Event Flag Register (DBGEFR)

Address: 0x010A



Figure 6-9. Debug Event Flag Register (DBGEFR)

MC9S12ZVC Family Reference Manual, Rev. 2.0

Chapter 8 S12 Clock, Reset and Power Management Unit (S12CPMU\_UHV\_V7)

This supply domain is monitored by the Low Voltage Reset circuit.

### 8.2.6 .VDDC, VSSC — CANPHY Supply Pin

VDDC is the supply domain for the CANPHY.

An off-chip decoupling capacitor (10 $\mu$ F plus 220 nF(X7R ceramic)) between VDDC and VSSC is required.

This supply domain is monitored by the Low Voltage Reset circuit.

### 8.2.7 BCTL — Base Control Pin for external PNP

BCTL is the ballast connection for the on chip voltage regulator. It provides the base current of an external

BJT (PNP) of the VDDX and VDDA supplies. An additional  $1K\Omega$  resistor between emitter and base of the BJT is required.

### 8.2.8 BCTLC — Base Control Pin for external PNP for VDDC

BCTLC is the ballast connection for the on chip voltage regulator. It provides the base current of an external BJT (PNP) of the VDDC supply. An additional  $1K\Omega$  resistor between emitter and base of the BJT is required.

### 8.2.9 VSS — Core Logic Ground Pin

VSS is the core logic supply return pins. It must be grounded.

### 8.2.10 VDD — Internal Regulator Output Supply (Core Logic)

Node VDD is a device internal supply output of the voltage regulator that provides the power supply for the internal core logic.

This supply domain is monitored by the Low Voltage Reset circuit and The Power On Reset circuit.

# 8.2.11 VDDF — Internal Regulator Output Supply (NVM Logic)

Node VDDF is a device internal supply output of the voltage regulator that provides the power supply for the NVM logic.

This supply domain is monitored by the Low Voltage Reset circuit.

### 8.2.12 API\_EXTCLK — API external clock output pin

This pin provides the signal selected via APIES and is enabled with APIEA bit. See the device specification if this clock output is available on this device and to which pin it might be connected.

| Field     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |  |  |
|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 7<br>SEQA | <b>Conversion Sequence Abort Event</b> — This bit indicates that a conversion sequence abort event is in progress.<br>When this bit is set the ongoing conversion sequence and current CSL will be aborted at the next conversion boundary. This bit gets cleared when the ongoing conversion sequence is aborted and ADC is idle.<br>This bit can only be set if bit ADC_EN is set.<br>This bit is cleared if bit ADC_EN is clear.<br><i>Data Bus Control</i> :                 |  |  |
|           | This bit can be controlled via the data bus if access control is configured accordingly via ACC_CFG[1:0].<br>Writing a value of 1'b0 does not clear the flag.<br>Writing a one to this bit does not clear it but causes an overrun if the bit has already been set. See Section 9.5.3.2.6,<br>"Conversion flow control in case of conversion sequence control bit overrun scenarios for more details."                                                                           |  |  |
|           | Internal Interface Control:<br>This bit can be controlled via the internal interface Signal "Seq_Abort" if access control is configured accordingly via<br>ACC_CFG[1:0]. After being set an additional request via the internal interface Signal "Seq_Abort" causes an overrun. See<br>also conversion flow control in case of overrun situations.<br><i>Canoral</i> :                                                                                                           |  |  |
|           | In both conversion flow control modes (Restart Mode and Trigger Mode) when bit RSTA gets set automatically bit SEQA<br>gets set when the ADC has not reached one of the following scenarios:<br>- A Sequence Abort request is about to be executed or has been executed.<br>- "End Of List" command type has been executed or is about to be executed<br>In case bit SEQA is set automatically the Restart error flag RSTA_EIF is set to indicate an unexpected Restart Request. |  |  |
|           | 1       Conversion sequence abort request.                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
| 6<br>TRIG | Conversion Sequence Trigger Bit — This bit starts a conversion sequence if set and no conversion or conversion sequence is ongoing. This bit is cleared when the first conversion of a sequence starts to sample. This bit can only be set if bit ADC_EN is set. This bit is cleared if bit ADC_EN is clear. Data Bus Control:                                                                                                                                                   |  |  |
|           | This bit can be controlled via the data bus if access control is configured accordingly via ACC_CFG[1:0].<br>Writing a value of 1'b0 does not clear the flag.<br>After being set this bit can not be cleared by writing a value of 1'b1 instead the error flag TRIG_EIF is set. See also<br>Section 9.5.3.2.6, "Conversion flow control in case of conversion sequence control bit overrun scenarios for more details.                                                           |  |  |
|           | Internal Interface Control:<br>This bit can be controlled via the internal interface Signal "Trigger" if access control is configured accordingly via<br>ACC_CFG[1:0]. After being set an additional request via internal interface Signal "Trigger" causes the flag TRIG_EIF to<br>be set.<br>0. No conversion sequence trigger                                                                                                                                                 |  |  |
|           | 1 Trigger to start conversion sequence.                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |

In freeze mode there is a software programmable option to disable the input clock to the prescaler. This is useful for emulation.

Wait: The prescaler keeps on running, unless PSWAI in PWMCTL is set to 1.

Freeze: The prescaler keeps on running, unless PFRZ in PWMCTL is set to 1.

# 13.1.3 Block Diagram

Figure 13-1 shows the block diagram for the 8-bit up to 8-channel scalable PWM block.



- - - Maximum possible channels, scalable in pairs from PWM0 to PWM7.

Figure 13-1. Scalable PWM Block Diagram

# **13.2** External Signal Description

The scalable PWM module has a selected number of external pins. Refer to device specification for exact number.

When the transmit shift register is not transmitting a frame, the TXD pin goes to the idle condition, logic 1. If at any time software clears the TE bit in SCI control register 2 (SCICR2), the transmitter enable signal goes low and the transmit signal goes idle.

If software clears TE while a transmission is in progress (TC = 0), the frame in the transmit shift register continues to shift out. To avoid accidentally cutting off the last frame in a message, always wait for TDRE to go high after the last frame before clearing TE.

To separate messages with preambles with minimum idle line time, use this sequence between messages:

- 1. Write the last byte of the first message to SCIDRH/L.
- 2. Wait for the TDRE flag to go high, indicating the transfer of the last frame to the transmit shift register.
- 3. Queue a preamble by clearing and then setting the TE bit.
- 4. Write the first byte of the second message to SCIDRH/L.

### 14.4.5.3 Break Characters

Writing a logic 1 to the send break bit, SBK, in SCI control register 2 (SCICR2) loads the transmit shift register with a break character. A break character contains all logic 0s and has no start, stop, or parity bit. Break character length depends on the M bit in SCI control register 1 (SCICR1). As long as SBK is at logic 1, transmitter logic continuously loads break characters into the transmit shift register. After software clears the SBK bit, the shift register finishes transmitting the last break character and then transmits at least one logic 1. The automatic logic 1 at the end of a break character guarantees the recognition of the start bit of the next frame.

The SCI recognizes a break character when there are 10 or 11(M = 0 or M = 1) consecutive zero received. Depending if the break detect feature is enabled or not receiving a break character has these effects on SCI registers.

If the break detect feature is disabled (BKDFE = 0):

- Sets the framing error flag, FE
- Sets the receive data register full flag, RDRF
- Clears the SCI data registers (SCIDRH/L)
- May set the overrun flag, OR, noise flag, NF, parity error flag, PE, or the receiver active flag, RAF (see 3.4.4 and 3.4.5 SCI Status Register 1 and 2)

If the break detect feature is enabled (BKDFE = 1) there are two scenarios<sup>1</sup>

The break is detected right from a start bit or is detected during a byte reception.

- Sets the break detect interrupt flag, BKDIF
- Does not change the data register full flag, RDRF or overrun flag OR
- Does not change the framing error flag FE, parity error flag PE.
- Does not clear the SCI data registers (SCIDRH/L)
- May set noise flag NF, or receiver active flag RAF.

<sup>1.</sup> A Break character in this context are either 10 or 11 consecutive zero received bits

#### Chapter 14 Serial Communication Interface (S12SCIV6)

Figure 14-17 shows two cases of break detect. In trace RXD\_1 the break symbol starts with the start bit, while in RXD\_2 the break starts in the middle of a transmission. If BRKDFE = 1, in RXD\_1 case there will be no byte transferred to the receive buffer and the RDRF flag will not be modified. Also no framing error or parity error will be flagged from this transfer. In RXD\_2 case, however the break signal starts later during the transmission. At the expected stop bit position the byte received so far will be transferred to the receive buffer, the receive data register full flag will be set, a framing error and if enabled and appropriate a parity error will be set. Once the break is detected the BRKDIF flag will be set.



Figure 14-17. Break Detection if BRKDFE = 1 (M = 0)

### 14.4.5.4 Idle Characters

An idle character (or preamble) contains all logic 1s and has no start, stop, or parity bit. Idle character length depends on the M bit in SCI control register 1 (SCICR1). The preamble is a synchronizing idle character that begins the first transmission initiated after writing the TE bit from 0 to 1.

If the TE bit is cleared during a transmission, the TXD pin becomes idle after completion of the transmission in progress. Clearing and then setting the TE bit during a transmission queues an idle character to be sent after the frame currently being transmitted.

### NOTE

When queueing an idle character, return the TE bit to logic 1 before the stop bit of the current frame shifts out through the TXD pin. Setting TE after the stop bit appears on TXD causes data previously written to the SCI data register to be lost. Toggle the TE bit for a queued idle character while the TDRE flag is set and immediately before writing the next byte to the SCI data register.

If the TE bit is clear and the transmission is complete, the SCI is not the master of the TXD pin

#### Chapter 14 Serial Communication Interface (S12SCIV6)

The transmitting device can address messages to selected receivers by including addressing information in the initial frame or frames of each message.

The WAKE bit in SCI control register 1 (SCICR1) determines how the SCI is brought out of the standby state to process an incoming message. The WAKE bit enables either idle line wakeup or address mark wakeup.

### 14.4.6.6.1 Idle Input line Wakeup (WAKE = 0)

In this wakeup method, an idle condition on the RXD pin clears the RWU bit and wakes up the SCI. The initial frame or frames of every message contain addressing information. All receivers evaluate the addressing information, and receivers for which the message is addressed process the frames that follow. Any receiver for which a message is not addressed can set its RWU bit and return to the standby state. The RWU bit remains set and the receiver remains on standby until another idle character appears on the RXD pin.

Idle line wakeup requires that messages be separated by at least one idle character and that no message contains idle characters.

The idle character that wakes a receiver does not set the receiver idle bit, IDLE, or the receive data register full flag, RDRF.

The idle line type bit, ILT, determines whether the receiver begins counting logic 1s as idle character bits after the start bit or after the stop bit. ILT is in SCI control register 1 (SCICR1).

### 14.4.6.6.2 Address Mark Wakeup (WAKE = 1)

In this wakeup method, a logic 1 in the most significant bit (MSB) position of a frame clears the RWU bit and wakes up the SCI. The logic 1 in the MSB position marks a frame as an address frame that contains addressing information. All receivers evaluate the addressing information, and the receivers for which the message is addressed process the frames that follow. Any receiver for which a message is not addressed can set its RWU bit and return to the standby state. The RWU bit remains set and the receiver remains on standby until another address frame appears on the RXD pin.

The logic 1 MSB of an address frame clears the receiver's RWU bit before the stop bit is received and sets the RDRF flag.

Address mark wakeup allows messages to contain idle characters but requires that the MSB be reserved for use in address frames.

### NOTE

With the WAKE bit clear, setting the RWU bit after the RXD pin has been idle can cause the receiver to wake up immediately.

### 14.4.7 Single-Wire Operation

Normally, the SCI uses two pins for transmitting and receiving. In single-wire operation, the RXD pin is disconnected from the SCI. The SCI uses the TXD pin for both receiving and transmitting.

| Field         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| 7<br>IBEN     | <ul> <li>I-Bus Enable — This bit controls the software reset of the entire IIC bus module.</li> <li>0 The module is reset and disabled. This is the power-on reset situation. When low the interface is held in reset but registers can be accessed</li> <li>1 The IIC bus module is enabled. This bit must be set before any other IBCR bits have any effect</li> <li>If the IIC bus module is enabled in the middle of a byte transfer the interface behaves as follows: slave mode ignores the current transfer on the bus and starts operating whenever a subsequent start condition is detected. Master mode will not be aware that the bus is busy, hence if a start cycle is initiated then the current bus cycle may become corrupt. This would ultimately result in either the current bus master or the IIC bus module losing arbitration, after which bus operation would return to normal.</li> </ul> |  |  |
| 6<br>IBIE     | <ul> <li>I-Bus Interrupt Enable</li> <li>Interrupts from the IIC bus module are disabled. Note that this does not clear any currently pending interrupt condition</li> <li>Interrupts from the IIC bus module are enabled. An IIC bus interrupt occurs provided the IBIF bit in the status register is also set.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |  |
| 5<br>MS/SL    | <ul> <li>Master/Slave Mode Select Bit — Upon reset, this bit is cleared. When this bit is changed from 0 to 1, a START signal is generated on the bus, and the master mode is selected. When this bit is changed from 1 to 0, a STOP signal is generated and the operation mode changes from master to slave. A STOP signal should only be generated if the IBIF flag is set. MS/SL is cleared without generating a STOP signal when the master loses arbitration.</li> <li>0 Slave Mode</li> <li>1 Master Mode</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                        |  |  |
| 4<br>Tx/Rx    | <ul> <li>Transmit/Receive Mode Select Bit — This bit selects the direction of master and slave transfers. When addressed as a slave this bit should be set by software according to the SRW bit in the status register. In master mode this bit should be set according to the type of transfer required. Therefore, for address cycles, this bit will always be high.</li> <li>0 Receive</li> <li>1 Transmit</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |  |
| 3<br>TXAK     | <b>Transmit Acknowledge Enable</b> — This bit specifies the value driven onto SDA during data acknowledge cycles for both master and slave receivers. The IIC module will always acknowledge address matches, provided it is enabled, regardless of the value of TXAK. Note that values written to this bit are only used when the IIC bus is a receiver, not a transmitter.<br>0 An acknowledge signal will be sent out to the bus at the 9th clock bit after receiving one byte data<br>1 No acknowledge signal response is sent (i.e., acknowledge bit = 1)                                                                                                                                                                                                                                                                                                                                                    |  |  |
| 2<br>RSTA     | <ul> <li>Repeat Start — Writing a 1 to this bit will generate a repeated START condition on the bus, provided it is the current bus master. This bit will always be read as a low. Attempting a repeated start at the wrong time, if the bus is owned by another master, will result in loss of arbitration.</li> <li>1 Generate repeat start cycle</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |
| 1<br>RESERVED | <b>Reserved</b> — Bit 1 of the IBCR is reserved for future compatibility. This bit will always read 0.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |  |
| 0<br>IBSWAI   | I Bus Interface Stop in Wait Mode         0 IIC bus module clock operates normally         1 Halt IIC bus module clock generation in wait mode                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |  |

Wait mode is entered via execution of a CPU WAI instruction. In the event that the IBSWAI bit is set, all clocks internal to the IIC will be stopped and any transmission currently in progress will halt. If the CPU were woken up by a source other than the IIC module, then clocks would restart and the IIC would resume from where was during the previous transmission. It is not possible for the IIC to wake up the CPU when its internal clocks are stopped.

If it were the case that the IBSWAI bit was cleared when the WAI instruction was executed, the IIC internal clocks and interface would remain alive, continuing the operation which was currently underway. It is also

| Offset<br>Address | Register                                              |     |  |
|-------------------|-------------------------------------------------------|-----|--|
| 0x00X0            | IDR0 — Identifier Register 0                          | R/W |  |
| 0x00X1            | IDR1 — Identifier Register 1                          | R/W |  |
| 0x00X2            | IDR2 — Identifier Register 2                          | R/W |  |
| 0x00X3            | IDR3 — Identifier Register 3                          | R/W |  |
| 0x00X4            | DSR0 — Data Segment Register 0                        | R/W |  |
| 0x00X5            | DSR1 — Data Segment Register 1                        | R/W |  |
| 0x00X6            | DSR2 — Data Segment Register 2                        | R/W |  |
| 0x00X7            | DSR3 — Data Segment Register 3                        |     |  |
| 0x00X8            | DSR4 — Data Segment Register 4                        |     |  |
| 0x00X9            | DSR5 — Data Segment Register 5                        |     |  |
| 0x00XA            | DSR6 — Data Segment Register 6                        | R/W |  |
| 0x00XB            | DSR7 — Data Segment Register 7                        | R/W |  |
| 0x00XC            | DLR — Data Length Register                            | R/W |  |
| 0x00XD            | TBPR — Transmit Buffer Priority Register <sup>1</sup> | R/W |  |
| 0x00XE            | TSRH — Time Stamp Register (High Byte)                | R   |  |
| 0x00XF            | TSRL — Time Stamp Register (Low Byte)                 | R   |  |

#### Table 18-25. Message Buffer Organization

<sup>1</sup> Not applicable for receive buffers

Figure 18-24 shows the common 13-byte data structure of receive and transmit buffers for extended identifiers. The mapping of standard identifiers into the IDR registers is shown in Figure 18-25.

All bits of the receive and transmit buffers are 'x' out of reset because of RAM-based implementation<sup>1</sup>. All reserved or unused bits of the receive and transmit buffers always read 'x'.

<sup>1.</sup> Exception: The transmit buffer priority registers are 0 out of reset.

### **19.4.2.1** Control Register (DACCTL)



#### Figure 19-3. Control Register (DACCTL)

<sup>1</sup> Read: Anytime

Write: Anytime

#### Table 19-3. DACCTL Field Description

| Field            | Description                                                                                                                                                                                                                                                                                                                                               |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>FVR         | <ul> <li>Full Voltage Range — This bit defines the voltage range of the DAC.</li> <li>0 DAC resistor network operates with the reduced voltage range</li> <li>1 DAC resistor network operates with the full voltage range</li> <li>Note: For more details see Section 19.5.8, "Analog output voltage calculation".</li> </ul>                             |
| 6<br>DRIVE       | <ul> <li>Drive Select — This bit selects the output drive capability of the operational amplifier, see electrical Spec. for more details.</li> <li>0 Low output drive for high resistive loads</li> <li>1 High output drive for low resistive loads</li> </ul>                                                                                            |
| 2:0<br>DACM[2:0] | <ul> <li>Mode Select — These bits define the mode of the DAC. A write access with an unsupported mode will be ignored.</li> <li>000 Off</li> <li>001 Operational Amplifier</li> <li>010 Internal DAC only</li> <li>100 Unbuffered DAC</li> <li>101 Unbuffered DAC with Operational Amplifier</li> <li>111 Buffered DAC</li> <li>other Reserved</li> </ul> |

Chapter 19 Digital Analog Converter (DAC\_8B5V\_V2)

#### Chapter 22 192 KB Flash Module (S12ZFTMRZ192K2KV2)

| Register | FCCOB Parameters                              |                                                |  |
|----------|-----------------------------------------------|------------------------------------------------|--|
| FCCOB0   | 0x0E                                          | Global address [23:16] to identify Flash block |  |
| FCCOB1   | Global address [15:0] to identify Flash block |                                                |  |
| FCCOB2   | Margin level setting.                         |                                                |  |

| Table 22-58. | Set Field Margin | Level Command | <b>FCCOB Requirements</b> |
|--------------|------------------|---------------|---------------------------|
|--------------|------------------|---------------|---------------------------|

Upon clearing CCIF to launch the Set Field Margin Level command, the Memory Controller will set the field margin level for the targeted block and then set the CCIF flag.

#### NOTE

When the EEPROM block is targeted, the EEPROM field margin levels are applied only to the EEPROM reads. However, when the P-Flash block is targeted, the P-Flash field margin levels are applied to both P-Flash and EEPROM reads. It is not possible to apply field margin levels to the P-Flash block only.

Valid margin level settings for the Set Field Margin Level command are defined in Table 22-59.

| FCCOB2 | Level Description                 |
|--------|-----------------------------------|
| 0x0000 | Return to Normal Level            |
| 0x0001 | User Margin-1 Level <sup>1</sup>  |
| 0x0002 | User Margin-0 Level <sup>2</sup>  |
| 0x0003 | Field Margin-1 Level <sup>1</sup> |
| 0x0004 | Field Margin-0 Level <sup>2</sup> |

#### Table 22-59. Valid Set Field Margin Level Settings

<sup>1</sup> Read margin to the erased state

<sup>2</sup> Read margin to the programmed state

#### Table 22-60. Set Field Margin Level Command Error Handling

| Register | Error Bit | Error Condition                                                     |
|----------|-----------|---------------------------------------------------------------------|
|          | ACCERR    | Set if CCOBIX[2:0] != 010 at command launch                         |
|          |           | Set if command not available in current mode (see Table 22-28)      |
| FSTAT    |           | Set if an invalid global address [23:0] is supplied see Table 22-2) |
|          |           | Set if an invalid margin level setting is supplied                  |
|          | FPVIOL    | None                                                                |
|          | MGSTAT1   | None                                                                |
|          | MGSTAT0   | None                                                                |

| Register | FCCOB Parameters                                                                                                                                      |                                                    |  |
|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------|--|
| FCCOB0   | 0x12                                                                                                                                                  | Global address [23:16] to identify<br>EEPROM block |  |
| FCCOB1   | Global address [15:0] anywhere within the sector to be erased.<br>See <st-blue>Section 22.1.2.2 EEPROM Features for EEPROM sector<br/>size.</st-blue> |                                                    |  |

 Table 22-65. Erase EEPROM Sector Command FCCOB Requirements

Upon clearing CCIF to launch the Erase EEPROM Sector command, the Memory Controller will erase the selected Flash sector and verify that it is erased. The CCIF flag will set after the Erase EEPROM Sector operation has completed.

| Register | Error Bit | Error Condition                                                                     |  |
|----------|-----------|-------------------------------------------------------------------------------------|--|
| FSTAT    | ACCERR    | Set if CCOBIX[2:0] != 001 at command launch                                         |  |
|          |           | Set if command not available in current mode (see Table 22-28)                      |  |
|          |           | Set if an invalid global address [23:0] is suppliedsee Table 22-2                   |  |
|          |           | Set if a misaligned word address is supplied (global address [0] != 0)              |  |
|          | FPVIOL    | Set if the selected area of the EEPROM memory is protected                          |  |
|          | MGSTAT1   | Set if any errors have been encountered during the verify operation                 |  |
|          | MGSTAT0   | Set if any non-correctable errors have been encountered during the verify operation |  |

 Table 22-66. Erase EEPROM Sector Command Error Handling

### 22.4.7.17 Protection Override Command

The Protection Override command allows the user to temporarily override the protection limits, either decreasing, increasing or disabling protection limits, on P-Flash and/or EEPROM, if the comparison key provided as a parameter loaded on FCCOB matches the value of the key previously programmed on the Flash Configuration Field (see Table 22-3.). The value of the Protection Override Comparison Key must not be 16'hFFFF, that is considered invalid and if used as argument will cause the Protection Override feature to be disabled. Any valid key value that does not match the value programmed in the Flash Configuration Field will cause the Protection Override feature to be disabled. Current status of the Protection Override feature can be observed on FPSTAT FPOVRD bit (see Section 22.3.2.4, "Flash Protection Status Register (FPSTAT)).

Table 22-67. Protection Override Command FCCOB Requirements

| Register | FCCOB Parameters |                                                       |
|----------|------------------|-------------------------------------------------------|
| FCCOB0   | 0x13             | Protection Update Selection [1:0]<br>See Table 22-68. |
| FCCOB1   | Comparison Key   |                                                       |
| FCCOB2   | reserved         | New FPROT value                                       |
| FCCOB3   | reserved         | New DFPROT value                                      |

# I.3 Dynamic Electrical Characteristics

### Table I-3. Dynamic Electrical Characteristics

| Charac<br>reflect | teristics noted under conditions $5.5V \le VSUP \le 18 V >$ , -40°C the approximate parameter mean at $T_A = 25$ °C under nominal c                    | $C \le Tj \le 150^{\circ}$<br>onditions unles | °C > unless o<br>ss otherwise | therwise not noted.                    | ed. Typical va | ilues noted |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|-------------------------------|----------------------------------------|----------------|-------------|
| Num               | Ratings                                                                                                                                                | Symbol                                        | Min                           | Тур                                    | Max            | Unit        |
|                   | SIGNAL EDGE RISE AND FAL                                                                                                                               | L TIMES (CA                                   | NH, CANL)                     |                                        | 1              |             |
| 1                 | Propagation Loop Delay TXD to RXD (Recessive to<br>Dominant)<br>Slew Rate 6<br>Slew Rate 5<br>Slew Rate 4<br>Slew Rate 2<br>Slew Rate 1<br>Slew Rate 0 | t <sub>LRD</sub>                              |                               | 146<br>112<br>89<br>83<br>72<br>64     | (255)          | ns          |
| 2                 | Propagation Delay TXD to CAN (Recessive to Dominant)<br>Slew Rate 6<br>Slew Rate 5<br>Slew Rate 4<br>Slew Rate 2<br>Slew Rate 1<br>Slew Rate 0         | t <sub>TRD</sub>                              |                               | 98<br>63<br>43<br>38<br>28<br>23       |                | ns          |
| 3                 | Propagation Delay CAN to RXD (Recessive to Dominant, using slew rate 0)                                                                                | t <sub>RRD</sub>                              |                               | 42                                     |                | ns          |
| 4                 | Propagation Loop Delay TXD to RXD (Dominant to<br>Recessive)<br>Slew Rate 6<br>Slew Rate 5<br>Slew Rate 4<br>Slew Rate 2<br>Slew Rate 1<br>Slew Rate 0 | t <sub>LDR</sub>                              |                               | 366<br>224<br>153<br>139<br>114<br>102 | (255)          | ns          |
| 5                 | Propagation Delay TXD to CAN (Dominant to Recessive)<br>Slew Rate 6<br>Slew Rate 5<br>Slew Rate 4<br>Slew Rate 2<br>Slew Rate 1<br>Slew Rate 0         | t <sub>TDR</sub>                              |                               | 280<br>152<br>90<br>81<br>56<br>46     |                | ns          |
| 6                 | Propagation Delay CAN to RXD (Dominant to Recessive, using slew rate 0)                                                                                | t <sub>RDR</sub>                              |                               | 56                                     |                | ns          |

| NU<br>M     | С                    | Rating                                                                                                                                                                                                                                                                                                                                                                                             | Symbol              | Min           | Тур                                  | Max | Unit                    |  |  |  |
|-------------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|---------------|--------------------------------------|-----|-------------------------|--|--|--|
|             | Program Flash Arrays |                                                                                                                                                                                                                                                                                                                                                                                                    |                     |               |                                      |     |                         |  |  |  |
| 1           | С                    | Data retention at an average junction temperature of $T_{Javg} = 85^{\circ}C^{1}$ after up to 10,000 program/erase cycles                                                                                                                                                                                                                                                                          | t <sub>NVMRET</sub> | 20            | 100 <sup>2</sup>                     |     | Years                   |  |  |  |
| 2           | C                    | Program Flash number of program/erase cycles $(-40^{\circ}C \le Tj \le 150^{\circ}C)$                                                                                                                                                                                                                                                                                                              | n <sub>FLPE</sub>   | 10K           | 100K <sup>3</sup>                    |     | Cycles                  |  |  |  |
|             |                      | EEPROM Array                                                                                                                                                                                                                                                                                                                                                                                       |                     |               |                                      |     |                         |  |  |  |
|             |                      | EEPROM Array                                                                                                                                                                                                                                                                                                                                                                                       |                     |               |                                      |     |                         |  |  |  |
| 3           | C                    | <b>EEPROM Array</b><br>Data retention at an average junction temperature of $T_{Javg} = 85^{\circ}C^{1}$ after up to 100,000 program/erase cycles                                                                                                                                                                                                                                                  | t <sub>NVMRET</sub> | 5             | 100 <sup>2</sup>                     |     | Years                   |  |  |  |
| 3           | C<br>C               | EEPROM ArrayData retention at an average junction temperature of $T_{Javg} = 85^{\circ}C^{1}$ after up<br>to 100,000 program/erase cyclesData retention at an average junction temperature of $T_{Javg} = 85^{\circ}C^{1}$ after up<br>to 10,000 program/erase cycles                                                                                                                              | t <sub>NVMRET</sub> | 5             | 100 <sup>2</sup><br>100 <sup>2</sup> |     | Years<br>Years          |  |  |  |
| 3<br>4<br>5 | C<br>C<br>C          | EEPROM ArrayData retention at an average junction temperature of $T_{Javg} = 85^{\circ}C^{1}$ after up<br>to 100,000 program/erase cyclesData retention at an average junction temperature of $T_{Javg} = 85^{\circ}C^{1}$ after up<br>to 10,000 program/erase cyclesData retention at an average junction temperature of $T_{Javg} = 85^{\circ}C^{1}$ after less<br>than 100 program/erase cycles | t <sub>NVMRET</sub> | 5<br>10<br>20 | $100^2$<br>$100^2$<br>$100^2$        |     | Years<br>Years<br>Years |  |  |  |

#### Table K-3. NVM Reliability Characteristics (Junction Temperature From -40°C To +175°C)

<sup>1</sup> T<sub>Javg</sub> does not exceed 85°C in a typical temperature profile over the lifetime of a consumer, industrial or automotive application.

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

<sup>3</sup> Spec table quotes typical endurance evaluated at 25°C for this product family. For additional information on how NXP defines Typical Endurance, please refer to Engineering Bulletin EB619.

# K.3 NVM Factory Shipping Condition

Devices are shipped from the factory with flash and EEPROM in the erased state. Data retention specifications begin at time of this erase operation. For additional information on how NXP defines Typical Data Retention, please refer to Engineering Bulletin EB618.