# E·XFL



#### 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             | Obsolete                                                                |
|----------------------------|-------------------------------------------------------------------------|
| Core Processor             | S12Z                                                                    |
| Core Size                  | 16-Bit                                                                  |
| Speed                      | 50MHz                                                                   |
| Connectivity               | CANbus, SCI, SPI                                                        |
| Peripherals                | DMA, POR, PWM, WDT                                                      |
| Number of I/O              | 31                                                                      |
| Program Memory Size        | 64KB (64K x 8)                                                          |
| Program Memory Type        | FLASH                                                                   |
| EEPROM Size                | 512 x 8                                                                 |
| RAM Size                   | 4K x 8                                                                  |
| Voltage - Supply (Vcc/Vdd) | 3.5V ~ 40V                                                              |
| Data Converters            | A/D 9x12b                                                               |
| Oscillator Type            | Internal                                                                |
| Operating Temperature      | -40°C ~ 150°C (TA)                                                      |
| Mounting Type              | Surface Mount                                                           |
| Package / Case             | 64-LQFP Exposed Pad                                                     |
| Supplier Device Package    | 64-HLQFP (10x10)                                                        |
| Purchase URL               | https://www.e-xfl.com/product-detail/nxp-semiconductors/s912zvmc64f1wkh |

Email: info@E-XFL.COM

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

# 1.9.1.2 Special Single-Chip Mode

This mode is used for debugging operation, boot-strapping, or security related operations. The background debug mode (BDM) is active on leaving reset in this mode

# 1.9.2 Debugging Modes

The background debug mode (BDM) can be activated by the BDC module or directly when resetting into Special Single-Chip mode. Detailed information can be found in the BDC module section.

Writing to internal memory locations using the debugger, whilst code is running or at a breakpoint, can change the flow of application code.

The MC9S12ZVM-Family supports BDC communication throughout the device Stop mode. During Stop mode, writes to control registers can alter the operation and lead to unexpected results. It is thus recommended not to reconfigure the peripherals during STOP using the debugger.

On the S12ZVML and S12ZVMC versions, the DBG module supports breakpoint, tracing and profiling features. At board level the profiling pins can use the same 6-pin connector typically used for the BDC BKGD pin. The connector pin mapping shown in Figure 1-7 is supported by device evaluation boards and leading development tool vendors.



Figure 1-7. Standard Debug Connector Pin Mapping

# 1.9.3 Low Power Modes

The device has two dynamic-power modes (run and wait) and two static low-power modes stop and pseudo stop). For a detailed description refer to the CPMU section.

- Dynamic power mode: Run
  - Run mode is the main full performance operating mode with the entire device clocked. The user can configure the device operating speed through selection of the clock source and the phase locked loop (PLL) frequency. To save power, unused peripherals must not be enabled.
- Dynamic power mode: Wait
  - This mode is entered when the CPU executes the WAI instruction. In this mode the CPU does not execute instructions. The internal CPU clock is switched off. All peripherals can be active in system wait mode. For further power consumption the peripherals can individually turn off their local clocks. Asserting RESET, XIRQ, IRQ, or any other interrupt that is not masked, either locally or globally by a CCR bit, ends system wait mode.
- Static power modes:

Static power (Stop) modes are entered following the CPU STOP instruction unless an NVM command is active. When no NVM commands are active, the Stop request is acknowledged and

| Field                    | Description                                                                                                                                                                                                                                                                                                                      |
|--------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-4 (MMCECL)<br>ACC[3:0] | Access Type Field — The ACC[3:0] bits capture the type of memory access, which caused the access violation. The access type is captured in form of a 4 bit value which is assigned as follows:<br>0: none (no error condition detected)<br>1: opcode fetch<br>2: vector fetch<br>3: data load<br>4: data store<br>5-15: reserved |
| 3-0 (MMCECL)<br>ERR[3:0] | <ul> <li>Error Type Field — The EC[3:0] bits capture the type of the access violation. The type is captured in form of a 4 bit value which is assigned as follows:</li> <li>0: none (no error condition detected)</li> <li>1: access to an illegal access</li> <li>2: uncorrectable ECC error</li> <li>3-15:reserved</li> </ul>  |

The MMCEC register captures debug information about access violations. It is set to a non-zero value if a S12ZCPU access violation or an uncorrectable ECC error has occurred. At the same time this register is set to a non-zero value, access information is captured in the MMCPCn and MMCCCRn registers. The MMCECn, the MMCPCn and the MMCCCRn registers are not updated if the MMCECn registers contain a non-zero value. The MMCECn registers are cleared by writing the value 0xFFFF.

# 3.3.2.3 Captured S12ZCPU Condition Code Register (MMCCCRH, MMCCCRL)



Address: 0x0082 (MMCCCRH)



Read: Anytime

Write: Never

#### Chapter 8 S12 Clock, Reset and Power Management Unit (V10 and V6)

The procedure to change APICLK or APIR[15:0] is first to clear APIFE, then write to APICLK or APIR[15:0], and afterwards set APIFE.

The API Trimming bits ACLKTR[5:0] must be set so the minimum period equals 0.2 ms if stable frequency is desired.

See Table 8-21 for the trimming effect of ACLKTR[5:0].

### NOTE

The first period after enabling the counter by APIFE might be reduced by API start up delay  $t_{sdel}$ .

It is possible to generate with the API a waveform at the external pin API\_EXTCLK by setting APIFE and enabling the external access with setting APIEA.

# 8.7 Initialization/Application Information

# 8.7.1 General Initialization Information

Usually applications run in MCU Normal Mode.

It is recommended to write the CPMUCOP register in any case from the application program initialization routine after reset no matter if the COP is used in the application or not, even if a configuration is loaded via the flash memory after reset. By doing a "controlled" write access in MCU Normal Mode (with the right value for the application) the write once for the COP configuration bits (WCOP,CR[2:0]) takes place which protects these bits from further accidental change. In case of a program sequencing issue (code runaway) the COP configuration can not be accidentally modified anymore.

# 8.7.2 Application information for COP and API usage

In many applications the COP is used to check that the program is running and sequencing properly. Often the COP is kept running during Stop Mode and periodic wake-up events are needed to service the COP on time and maybe to check the system status.

For such an application it is recommended to use the ACLK as clock source for both COP and API. This guarantees lowest possible IDD current during Stop Mode. Additionally it eases software implementation using the same clock source for both, COP and API.

The Interrupt Service Routine (ISR) of the Autonomous Periodic Interrupt API should contain the write instruction to the CPMUARMCOP register. The value (byte) written is derived from the "main routine" (alternating sequence of \$55 and \$AA) of the application software.

Using this method, then in the case of a runtime or program sequencing issue the application "main routine" is not executed properly anymore and the alternating values are not provided properly. Hence the COP is written at the correct time (due to independent API interrupt request) but the wrong value is written (alternating sequence of \$55 and \$AA is no longer maintained) which causes a COP reset.

If the COP is stopped during any Stop Mode it is recommended to service the COP shortly before Stop Mode is entered.

# 9.5.2.12 ADC Conversion Interrupt Flag Register (ADCCONIF)

After being set any of these bits can be cleared by writing a value of 1'b1. All bits are cleared if bit ADC\_EN is clear or via ADC soft-reset (bit ADC\_SR set). Writing any flag with value 1'b0 does not clear the flag. Writing any flag with value 1'b1 does not set the flag.



Figure 9-15. ADC Conversion Interrupt Flag Register (ADCCONIF)

Read: Anytime

Write: Anytime

| Field                       | Description                                                                                                                                                                                                                                                           |
|-----------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <b>15-1</b><br>CON_IF[15:1] | Conversion Interrupt Flags — These bits could be set by the binary coded interrupt select bits<br>INTFLG_SEL[3:0] when the corresponding conversion command has been processed and related data has<br>been stored to RAM.<br>See also notes below.                   |
| 0<br>EOL_IF                 | End Of List Interrupt Flag — This bit is set by the binary coded conversion command type select bits CMD_SEL[1:0] for "end of list" type of commands and after such a command has been processed and the related data has been stored RAM. See also second note below |

### NOTE

These bits can be used to indicate if a certain packet of conversion results is available. Clearing a flag indicates that conversion results have been retrieved by software and the flag can be used again (see also Section 9.9.6, "RVL swapping in RVL double buffer mode and related registers ADCIMDRI and ADCEOLRI.

### NOTE

Overrun situation of a flag CON\_IF[15:1] and EOL\_IF are indicated by flag CONIF\_OIF.

# 10.3.2.2 BATS Module Status Register (BATSR)



### Figure 10-4. BATS Module Status Register (BATSR)

1. Read: Anytime Write: Never

| Field     | Description                                                                                                                                                                                                                                       |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1<br>BVHC | BATS Voltage Sense High Condition Bit — This status bit indicates that a high voltage at VSUP, depending on selection, is present.                                                                                                                |
|           | $ \begin{array}{l} 0 \ V_{measured} < V_{HBI\_A} \ (rising \ edge) \ or \ V_{measured} < V_{HBI\_D} \ (falling \ edge) \\ 1 \ V_{measured} \geq V_{HBI\_A} \ (rising \ edge) \ or \ V_{measured} \geq V_{HBI\_D} \ (falling \ edge) \end{array} $ |
| 0<br>BVLC | BATS Voltage Sense Low Condition Bit — This status bit indicates that a low voltage at VSUP, depending on selection, is present.                                                                                                                  |
|           | $ \begin{array}{l} 0 \ V_{measured} \geq V_{LBI\_A} \ (falling \ edge) \ or \ V_{measured} \geq V_{LBI\_D} \ (rising \ edge) \\ 1 \ V_{measured} < V_{LBI\_A} \ (falling \ edge) \ or \ V_{measured} < V_{LBI\_D} \ (rising \ edge) \end{array} $ |

#### Table 10-3. BATSR - Register Field Descriptions

### Figure 10-5. BATS Voltage Sensing



Chapter 12 Timer Module (TIM16B2CV3) Block Description

# 12.1.3 Block Diagrams



Figure 12-1. TIM16B2CV3 Block Diagram



Figure 12-2. Interrupt Flag Setting

# 12.2 External Signal Description

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

Chapter 12 Timer Module (TIM16B2CV3) Block Description

| Register<br>Name                          |        | Bit 7        | 6            | 5            | 4            | 3            | 2            | 1     | Bit 0 |
|-------------------------------------------|--------|--------------|--------------|--------------|--------------|--------------|--------------|-------|-------|
| 0x000C<br>TIE                             | R<br>W | RESERV<br>ED | RESERV<br>ED | RESERV<br>ED | RESERV<br>ED | RESERV<br>ED | RESERV<br>ED | C1I   | C0I   |
| 0x000D<br>TSCR2                           | R<br>W | TOI          | 0            | 0            | 0            | RESERV<br>ED | PR2          | PR1   | PR0   |
| 0x000E<br>TFLG1                           | R<br>W | RESERV<br>ED | RESERV<br>ED | RESERV<br>ED | RESERV<br>ED | RESERV<br>ED | RESERV<br>ED | C1F   | C0F   |
| 0x000F<br>TEL G2                          | R      | TOF          | 0            | 0            | 0            | 0            | 0            | 0     | 0     |
| 11 202                                    | vv     |              |              |              |              |              |              |       |       |
| 0x0010–0x001F<br>TCxH–TCxL <sup>(1)</sup> | R<br>W | Bit 15       | Bit 14       | Bit 13       | Bit 12       | Bit 11       | Bit 10       | Bit 9 | Bit 8 |
|                                           | R<br>W | Bit 7        | Bit 6        | Bit 5        | Bit 4        | Bit 3        | Bit 2        | Bit 1 | Bit 0 |
| 0x0024–0x002B<br>Reserved                 | R<br>W |              |              |              |              |              |              |       |       |
| 0x002C<br>OCPD                            | R<br>W | RESERV<br>ED | RESERV<br>ED | RESERV<br>ED | RESERV<br>ED | RESERV<br>ED | RESERV<br>ED | OCPD1 | OCPD0 |
| 0x002D<br>Reserved                        | R      |              |              |              |              |              |              |       |       |
| 0x002E<br>PTPSR                           | R<br>W | PTPS7        | PTPS6        | PTPS5        | PTPS4        | PTPS3        | PTPS2        | PTPS1 | PTPS0 |
| 0x002F<br>Reserved                        | R<br>W |              |              |              |              |              |              |       |       |

Figure 12-3. TIM16B2CV3 Register Summary (Sheet 2 of 2)

1. The register is available only if corresponding channel exists.

# 12.3.2.1 Timer Input Capture/Output Compare Select (TIOS)

Module Base + 0x0000

|        | 7        | 6        | 5        | 4        | 3        | 2        | 1    | 0    |
|--------|----------|----------|----------|----------|----------|----------|------|------|
| R<br>W | RESERVED | RESERVED | RESERVED | RESERVED | RESERVED | RESERVED | IOS1 | IOS0 |
| Reset  | 0        | 0        | 0        | 0        | 0        | 0        | 0    | 0    |



Read: Anytime

Write: Anytime

# 13.3.2.5 MSCAN Receiver Flag Register (CANRFLG)

A flag can be cleared only by software (writing a 1 to the corresponding bit position) when the condition which caused the setting is no longer valid. Every flag has an associated interrupt enable bit in the CANRIER register.



Access: User read/write<sup>(1)</sup>



### Figure 13-8. MSCAN Receiver Flag Register (CANRFLG)

1. Read: Anytime

Write: Anytime when not in initialization mode, except RSTAT[1:0] and TSTAT[1:0] flags which are read-only; write of 1 clears flag; write of 0 is ignored

### NOTE

The CANRFLG register is held in the reset state<sup>1</sup> when the initialization mode is active (INITRQ = 1 and INITAK = 1). This register is writable again as soon as the initialization mode is exited (INITRQ = 0 and INITAK = 0).

| Table 13-10. CANRFLG Register Field Descriptions |
|--------------------------------------------------|
|--------------------------------------------------|

| Field      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>WUPIF | <ul> <li>Wake-Up Interrupt Flag — If the MSCAN detects CAN bus activity while in sleep mode (see Section 13.4.5.5, "MSCAN Sleep Mode,") and WUPE = 1 in CANTCTL0 (see Section 13.3.2.1, "MSCAN Control Register 0 (CANCTL0)"), the module will set WUPIF. If not masked, a wake-up interrupt is pending while this flag is set.</li> <li>0 No wake-up activity observed while in sleep mode</li> <li>1 MSCAN detected activity on the CAN bus and requested wake-up</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 6<br>CSCIF | <ul> <li>CAN Status Change Interrupt Flag — This flag is set when the MSCAN changes its current CAN bus status due to the actual value of the transmit error counter (TEC) and the receive error counter (REC). An additional 4-bit (RSTAT[1:0], TSTAT[1:0]) status register, which is split into separate sections for TEC/REC, informs the system on the actual CAN bus status (see Section 13.3.2.6, "MSCAN Receiver Interrupt Enable Register (CANRIER)"). If not masked, an error interrupt is pending while this flag is set. CSCIF provides a blocking interrupt. That guarantees that the receiver/transmitter status bits (RSTAT/TSTAT) are only updated when no CAN status change interrupt is pending. If the TECs/RECs change their current value after the CSCIF is asserted, which would cause an additional state change in the RSTAT/TSTAT bits, these bits keep their status until the current CSCIF interrupt is cleared again.</li> <li>0 No change in CAN bus status occurred since last interrupt</li> <li>1 MSCAN changed current CAN bus status</li> </ul> |

1. The RSTAT[1:0], TSTAT[1:0] bits are not affected by initialization mode.

| Field          | Description                                                                                                                                                                                                                                                                                   |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-0<br>AC[7:0] | Acceptance Code Bits — AC[7:0] comprise a user-defined sequence of bits with which the corresponding bits of the related identifier register (IDRn) of the receive message buffer are compared. The result of this comparison is then masked with the corresponding identifier mask register. |

#### Table 13-21. CANIDAR0–CANIDAR3 Register Field Descriptions

#### Module Base + 0x0018 to Module Base + 0x001B

Access: User read/write<sup>(1)</sup>

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

### Figure 13-21. MSCAN Identifier Acceptance Registers (Second Bank) — CANIDAR4–CANIDAR7

1. Read: Anytime

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

#### Table 13-22. CANIDAR4–CANIDAR7 Register Field Descriptions

| Field          | Description                                                                                                                                                                                                                                                                                   |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-0<br>AC[7:0] | Acceptance Code Bits — AC[7:0] comprise a user-defined sequence of bits with which the corresponding bits of the related identifier register (IDRn) of the receive message buffer are compared. The result of this comparison is then masked with the corresponding identifier mask register. |

### 13.3.2.18 MSCAN Identifier Mask Registers (CANIDMR0–CANIDMR7)

The identifier mask register specifies which of the corresponding bits in the identifier acceptance register are relevant for acceptance filtering. To receive standard identifiers in 32 bit filter mode, it is required to program the last three bits (AM[2:0]) in the mask registers CANIDMR1 and CANIDMR5 to "don't care." To receive standard identifiers in 16 bit filter mode, it is required to program the last three bits (AM[2:0]) in the mask registers CANIDMR1 and CANIDMR5 to "don't care." To receive standard identifiers in 16 bit filter mode, it is required to program the last three bits (AM[2:0]) in the mask registers CANIDMR5, and CANIDMR7 to "don't care."

Module Base + 0x0014 to Module Base + 0x0017

Access: User read/write<sup>(1)</sup>

|        | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|--------|-----|-----|-----|-----|-----|-----|-----|-----|
| R<br>W | AM7 | AM6 | AM5 | AM4 | AM3 | AM2 | AM1 | AM0 |
| Reset  | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

### Figure 13-22. MSCAN Identifier Mask Registers (First Bank) — CANIDMR0–CANIDMR3

1. Read: Anytime

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



# 13.3.3.2 Data Segment Registers (DSR0-7)

The eight data segment registers, each with bits DB[7:0], contain the data to be transmitted or received. The number of bytes to be transmitted or received is determined by the data length code in the corresponding DLR register.

Module Base + 0x00X4 to Module Base + 0x00XB

|        | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|--------|-----|-----|-----|-----|-----|-----|-----|-----|
| R<br>W | DB7 | DB6 | DB5 | DB4 | DB3 | DB2 | DB1 | DB0 |
| Reset: | x   | x   | x   | x   | x   | x   | x   | x   |

Figure 13-34. Data Segment Registers (DSR0–DSR7) — Extended Identifier Mapping

| Field          | Description   |
|----------------|---------------|
| 7-0<br>DB[7:0] | Data bits 7-0 |

| Table 14-6 | . PTUIEL | Register | Field | Descriptions |
|------------|----------|----------|-------|--------------|
|------------|----------|----------|-------|--------------|

| Field        | Description                                                                                                                                                                                                                                                              |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5<br>TG1TEIE | <ul> <li>Trigger Generator 1 Timing Error Interrupt Enable — Enables trigger generator timing error interrupt.</li> <li>0 No interrupt will be requested whenever TG1TEIF is set</li> <li>1 Interrupt will be requested whenever TG1TEIF is set</li> </ul>               |
| 4<br>TG1DIE  | <ul> <li>Trigger Generator 1 Done Interrupt Enable — Enables trigger generator done interrupt.</li> <li>0 No interrupt will be requested whenever TG1DIF is set</li> <li>1 Interrupt will be requested whenever TG1DIF is set</li> </ul>                                 |
| 3<br>TG0AEIE | <ul> <li>Trigger Generator 0 Memory Access Error Interrupt Enable — Enables trigger generator memory access error interrupt.</li> <li>0 No interrupt will be requested whenever TG0AEIF is set</li> <li>1 Interrupt will be requested whenever TG0AEIF is set</li> </ul> |
| 2<br>TG0REIE | <ul> <li>Trigger Generator 0 Reload Error Interrupt Enable — Enables trigger generator reload error interrupt.</li> <li>0 No interrupt will be requested whenever TG0REIF is set</li> <li>1 Interrupt will be requested whenever TG0REIF is set</li> </ul>               |
| 1<br>TG0TEIE | <ul> <li>Trigger Generator 0 Timing Error Interrupt Enable — Enables trigger generator timing error interrupt.</li> <li>0 No interrupt will be requested whenever TG0TEIF is set</li> <li>1 Interrupt will be requested whenever TG0TEIF is set</li> </ul>               |
| 0<br>TG0DIE  | <ul> <li>Trigger Generator 0 Done Interrupt Enable — Enables trigger generator done interrupt.</li> <li>0 No interrupt will be requested whenever TG0DIF is set</li> <li>1 Interrupt will be requested whenever TG0DIF is set</li> </ul>                                 |

# 14.3.2.7 Trigger Generator 0 List Register (TG0LIST)



1. Read: Anytime

Write: Anytime, if TG0EN bit is cleared

### Table 14-9. TG0LIST Register Field Descriptions

| Field        | Description                                                                                                                                                                                      |
|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>TG0LIST | <ul> <li>Trigger Generator 0 List — This bit shows the number of the current used list.</li> <li>0 Trigger generator 0 is using list 0</li> <li>1 Trigger generator 0 is using list 1</li> </ul> |

# 14.3.2.8 Trigger Generator 0 Trigger Number Register (TG0TNUM)



1. Read: Anytime

Write: Never

### Table 14-10. TG0TNUM Register Field Descriptions

| Field               | Description                                                                                                                                                                                                                                             |
|---------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 4:0<br>TG0TNUM[4:0] | Trigger Generator 0 Trigger Number — This register shows the number of generated triggers since the last reload event. After the generation of 32 triggers this register shows zero. The next reload event clears this register. See also Figure 14-22. |

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

indicating that the received byte can be read. If the receive interrupt enable bit, RIE, in SCI control register 2 (SCICR2) is also set, the RDRF flag generates an RDRF interrupt request.

# 16.4.6.3 Data Sampling

The RT clock rate. The RT clock is an internal signal with a frequency 16 times the baud rate. To adjust for baud rate mismatch, the RT clock (see Figure 16-21) is re-synchronized immediately at bus clock edge:

- After every start bit
- After the receiver detects a data bit change from logic 1 to logic 0 (after the majority of data bit samples at RT8, RT9, and RT10 returns a valid logic 1 and the majority of the next RT8, RT9, and RT10 samples returns a valid logic 0)

To locate the start bit, data recovery logic does an asynchronous search for a logic 0 preceded by three logic 1s.When the falling edge of a possible start bit occurs, the RT clock begins to count to 16.



Figure 16-21. Receiver Data Sampling

To verify the start bit and to detect noise, data recovery logic takes samples at RT3, RT5, and RT7. Figure 16-17 summarizes the results of the start bit verification samples.

| RT3, RT5, and RT7 Samples | Start Bit Verification | Noise Flag |
|---------------------------|------------------------|------------|
| 000                       | Yes                    | 0          |
| 001                       | Yes                    | 1          |
| 010                       | Yes                    | 1          |
| 011                       | No                     | 0          |
| 100                       | Yes                    | 1          |
| 101                       | No                     | 0          |
| 110                       | No                     | 0          |
| 111                       | No                     | 0          |
|                           |                        |            |

If start bit verification is not successful, the RT clock is reset and a new search for a start bit begins.

#### Chapter 19 LIN/HV Physical Layer (S12LINPHYV3)

| Field             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>LPDTDIS      | TxD-dominant timeout disable Bit — This bit disables the TxD-dominant timeout feature. Disabling this feature is only recommended for using the LIN Physical Layer for other applications than LIN protocol. It is only writable in shutdown mode (LPE=0).<br>0 TxD-dominant timeout feature is enabled.<br>1 TxD-dominant timeout feature is disabled.                                                                                                                                                                                                                                                                                                                                                                                   |
| 1-0<br>LPSLR[1:0] | <ul> <li>Slew-Rate Bits — Please see section 19.4.2 for details on how the slew rate control works. These bits are only writable in shutdown mode (LPE=0).</li> <li>00 Normal Slew Rate (optimized for 20 kbit/s).</li> <li>01 Slow Slew Rate (optimized for 10.4 kbit/s).</li> <li>10 Fast Mode Slew Rate (up to 250 kbit/s). This mode is not compliant with the LIN Protocol (LIN electrical characteristics like duty cycles, reference levels, etc. are not fulfilled). It is only meant to be used for fast data transmission. Please refer to section 19.4.2.2 for more details on fast mode.Please note that an external pullup resistor stronger than 1 kΩ might be necessary for the range 100 kbit/s to 250 kbit/s.</li> </ul> |

### Table 19-5. LPSLRM Field Description

# 19.3.2.5 Reserved Register

Module Base + Address 0x0004

Access: User read/write<sup>(1)</sup>

| _      | 7        | 6               | 5        | 4        | 3        | 2        | 1        | 0        |
|--------|----------|-----------------|----------|----------|----------|----------|----------|----------|
| R<br>W | Reserved | Reserved        | Reserved | Reserved | Reserved | Reserved | Reserved | Reserved |
| Reset  | Х        | х               | Х        | Х        | Х        | Х        | Х        | Х        |
|        |          | = Unimplemented |          |          |          |          |          |          |



1. Read: Anytime

Write: Only in special mode

### NOTE

This reserved register is designed for factory test purposes only, and is not intended for general user access. Writing to this register when in special mode can alter the module's functionality.

### Table 19-6. Reserved Register Field Description

| Field           | Description                                                                                               |
|-----------------|-----------------------------------------------------------------------------------------------------------|
| 7-0<br>Reserved | These reserved bits are used for test purposes. Writing to these bits can alter the module functionality. |

#### Chapter 19 LIN/HV Physical Layer (S12LINPHYV3)

If LPWUE is not set, no wake up feature is available and the standby mode has the same electrical properties as the shutdown mode. This allows a low-power consumption of the device in stop mode if the wake-up feature is not needed.

If LPWUE is set, the receiver is able to pass wake-up events to the SCI (Serial Communication Interface). If the LIN/HV Physical Layer receives a dominant level longer than  $t_{WUFR}$  followed by a rising edge, it sends a pulse to the SCI which can generate a wake-up interrupt.

Once the device exits stop mode, the LIN/HV Physical Layer returns to normal or receive only mode depending on the status of the RXONLY bit.

### NOTE

Since the wake-up interrupt is requested by the SCI, the wake-up feature is not available if LPRxD is not connected to the SCI..

The internal pullup resistor is selectable only if LPWUE = 1 (wake-up enabled). If LPWUE = 0, the internal pullup resistor is not selectable and remains at 330 k $\Omega$  regardless of the state of the LPPUE bit.

If LPWUE = 1, selecting the 330 k $\Omega$  pullup resistor (LPPUE = 0) reduces the current consumption in standby mode.

### NOTE

The use of the LIN wake-up feature in combination with other non-LIN device wake-up features (like a periodic time interrupt) must be handled with care.

If the device leaves stop mode while the LIN bus is dominant, the LIN/HV Physical Layer returns to normal or receive only mode and the LPRxD signal is re-routed to the RxD pin of the SCI and triggers the edge detection interrupt (if the interrupt's priority of the hardware that awakes the MCU is less than the priority of the SCI interrupt, then the SCI interrupt will execute first). It is up to the software to decide what to do in this case because the LIN/HV Physical Layer may not determine whether it was a valid wake-up pulse.

| Field      | Description                                                                                                                                                                                                                                                                                                                                                                   |
|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0<br>SFDIE | <ul> <li>Single Bit Fault Detect Interrupt Enable — The SFDIE bit controls interrupt generation when a single bit fault is detected during a Flash block read operation.</li> <li>0 SFDIF interrupt disabled whenever the SFDIF flag is set (see Section 20.3.2.8)</li> <li>1 An interrupt will be requested whenever the SFDIF flag is set (see Section 20.3.2.8)</li> </ul> |

### 20.3.2.7 Flash Status Register (FSTAT)

The FSTAT register reports the operational status of the Flash module.

Offset Module Base + 0x0006



### Figure 20-11. Flash Status Register (FSTAT)

1. Reset value can deviate from the value shown if a double bit fault is detected during the reset sequence (see Section 20.6).

CCIF, ACCERR, and FPVIOL bits are readable and writable, MGBUSY and MGSTAT bits are readable but not writable, while remaining bits read 0 and are not writable.

|  | Table 20-1 | 7. FSTAT | Field D | escriptions |
|--|------------|----------|---------|-------------|
|--|------------|----------|---------|-------------|

| Field       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>CCIF   | <ul> <li>Command Complete Interrupt Flag — The CCIF flag indicates that a Flash command has completed. The CCIF flag is cleared by writing a 1 to CCIF to launch a command and CCIF will stay low until command completion or command violation.</li> <li>0 Flash command in progress</li> <li>1 Flash command has completed</li> </ul>                                                                                                                                           |
| 5<br>ACCERR | Flash Access Error Flag — The ACCERR bit indicates an illegal access has occurred to the Flash memory caused by either a violation of the command write sequence (see Section 20.4.5.2) or issuing an illegal Flash command. While ACCERR is set, the CCIF flag cannot be cleared to launch a command. The ACCERR bit is cleared by writing a 1 to ACCERR. Writing a 0 to the ACCERR bit has no effect on ACCERR. 0 No access error detected 1 Access error detected              |
| 4<br>FPVIOL | Flash Protection Violation Flag — The FPVIOL bit indicates an attempt was made to program or erase an address in a protected area of P-Flash or EEPROM memory during a command write sequence. The FPVIOL bit is cleared by writing a 1 to FPVIOL. Writing a 0 to the FPVIOL bit has no effect on FPVIOL. While FPVIOL is set, it is not possible to launch a command or start a command write sequence.<br>0 No protection violation detected<br>1 Protection violation detected |
| 3<br>MGBUSY | <ul> <li>Memory Controller Busy Flag — The MGBUSY flag reflects the active state of the Memory Controller.</li> <li>0 Memory Controller is idle</li> <li>1 Memory Controller is busy executing a Flash command (CCIF = 0)</li> </ul>                                                                                                                                                                                                                                              |

# Chapter 21 CAN Physical Layer (S12CANPHYV3)

| Revision<br>Number | Revision Date | Sections<br>Affected | Description of Changes                                                                                                                                                                                                                                        |
|--------------------|---------------|----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| V02.00             | 05 Nov 2012   |                      | Added CPTXD-dominant timeout feature                                                                                                                                                                                                                          |
| V03.00             | 15 Apr 2013   |                      | <ul> <li>Made transmit driver (CANH &amp; CANL) independent of CPCHVL condition</li> <li>Changed CPCLVL condition to disable CANL only</li> <li>Added mode to cover separation of CANH and CANL drivers</li> <li>Added configurable wake-up filter</li> </ul> |

### Table 21-1. Revision History Table

### NOTE

The information given in this section are preliminary and should be used as a guide only. Values in this section cannot be guaranteed and are subject to change without notice.

# 21.1 Introduction

The CAN Physical Layer provides a physical layer for high speed CAN area network communication in automotive applications. It serves as an integrated interface to the CAN bus lines for the internally connected MSCAN controller through the pins CANH, CANL and SPLIT.

The CAN Physical Layer is designed to meet the CAN Physical Layer ISO 11898-2 and ISO 11898-5 standards.

# 21.1.1 Features

The CAN Physical Layer module includes these distinctive features:

- High speed CAN interface for baud rates of up to 1 Mbit/s
- ISO 11898-2 and ISO 11898-5 compliant for 12 V battery systems
- SPLIT pin driver for bus recessive level stabilization
- Low power mode with remote CAN wake-up handled by MSCAN module
- Configurable wake-up pulse filtering
- Over-current shutdown for CANH and CANL
- Voltage monitoring on CANH and CANL
- CPTXD-dominant timeout feature monitoring the CPTXD signal
- Fulfills the OEM "Hardware Requirements for (LIN,) CAN (and FlexRay) Interfaces in Automotive Applications" v1.3

| Table C-3. ADC Conversion Performance ! | 5 V range (Junction | Temperature From | –40°C To +150°C) |
|-----------------------------------------|---------------------|------------------|------------------|
|-----------------------------------------|---------------------|------------------|------------------|

| Supply voltage 4.5 V < V <sub>DDA</sub> < 5.5 V, 4.5V < V <sub>REF</sub> < 5.5 V. ( $V_{REF} = V_{RH} - V_{RL}$ ). f <sub>ADCCLK</sub> = 8.0 MHz<br>The values are tested to be valid with no PortAD output drivers switching simultaneous with conversions. |   |                                       |        |        |      |      |     |        |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---------------------------------------|--------|--------|------|------|-----|--------|
| Num                                                                                                                                                                                                                                                          | С | Rating <sup>(1)</sup>                 |        | Symbol | Min  | Тур  | Мах | Unit   |
| 1                                                                                                                                                                                                                                                            |   | Resolution (V <sub>REF</sub> = 5.12V) | 12-Bit | LSB    | _    | 1.25 | _   | mV     |
| 2                                                                                                                                                                                                                                                            |   | Differential Nonlinearity             | 12-Bit | DNL    | -4   | ±2   | 4   | counts |
| 3                                                                                                                                                                                                                                                            |   | Integral Nonlinearity                 | 12-Bit | INL    | -5   | ±2.5 | 5   | counts |
| 4                                                                                                                                                                                                                                                            |   | Absolute Error <sup>(2)</sup>         | 12-Bit | AE     | -7   | ±4   | 7   | counts |
| 5                                                                                                                                                                                                                                                            |   | Resolution (V <sub>REF</sub> = 5.12V) | 10-Bit | LSB    | —    | 5    | —   | mV     |
| 6                                                                                                                                                                                                                                                            |   | Differential Nonlinearity             | 10-Bit | DNL    | -1   | ±0.5 | 1   | counts |
| 7                                                                                                                                                                                                                                                            |   | Integral Nonlinearity                 | 10-Bit | INL    | -2   | ±1   | 2   | counts |
| 8                                                                                                                                                                                                                                                            |   | Absolute Error                        | 10-Bit | AE     | -3   | ±2   | 3   | counts |
| 9                                                                                                                                                                                                                                                            |   | Resolution (V <sub>REF</sub> = 5.12V) | 8-Bit  | LSB    | —    | 20   | —   | mV     |
| 10                                                                                                                                                                                                                                                           |   | Differential Nonlinearity             | 8-Bit  | DNL    | -0.5 | ±0.3 | 0.5 | counts |
| 11                                                                                                                                                                                                                                                           |   | Integral Nonlinearity                 | 8-Bit  | INL    | -1   | ±0.5 | 1   | counts |
| 12                                                                                                                                                                                                                                                           |   | Absolute Error                        | 8-Bit  | AE     | -1.5 | ±1   | 1.5 | counts |

1. The 8-bit and 10-bit mode operation is structurally tested in production test. Absolute values are tested in 12-bit mode.

2. These values include the quantization error which is inherently 1/2 count for any A/D converter.

### Table C-4. ADC Conversion Performance 5 V range (Junction Temperature From 150°C To +175°C)

| Supply voltage 4.5 V < $V_{DDA}$ < 5.5 V, 4.5V < $V_{REF}$ < 5.5 V. ( $V_{REF}$ = $V_{RH}$ - $V_{RL}$ ). f <sub>ADCCLK</sub> = 8.0 MHz<br>The values are tested to be valid with no PortAD output drivers switching simultaneous with conversions. |   |                                       |        |     |      |      |      |        |  |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|---------------------------------------|--------|-----|------|------|------|--------|--|
| Num                                                                                                                                                                                                                                                | С | Rating <sup>(1)</sup>                 | Symbol | Min | Тур  | Мах  | Unit |        |  |
| 1                                                                                                                                                                                                                                                  |   | Resolution (V <sub>REF</sub> = 5.12V) | 12-Bit | LSB | _    | 1.25 | —    | mV     |  |
| 2                                                                                                                                                                                                                                                  |   | Differential Nonlinearity             | 12-Bit | DNL | -4   | ±2   | 4    | counts |  |
| 3                                                                                                                                                                                                                                                  |   | Integral Nonlinearity                 | 12-Bit | INL | -5   | ±2.5 | 5    | counts |  |
| 4                                                                                                                                                                                                                                                  |   | Absolute Error <sup>(2)</sup>         | 12-Bit | AE  | -7   | ±4   | 7    | counts |  |
| 5                                                                                                                                                                                                                                                  |   | Resolution (V <sub>REF</sub> = 5.12V) | 10-Bit | LSB | _    | 5    | —    | mV     |  |
| 6                                                                                                                                                                                                                                                  |   | Differential Nonlinearity             | 10-Bit | DNL | -1   | ±0.5 | 1    | counts |  |
| 7                                                                                                                                                                                                                                                  |   | Integral Nonlinearity                 | 10-Bit | INL | -2   | ±1   | 2    | counts |  |
| 8                                                                                                                                                                                                                                                  |   | Absolute Error                        | 10-Bit | AE  | -3   | ±2   | 3    | counts |  |
| 9                                                                                                                                                                                                                                                  |   | Resolution (V <sub>REF</sub> = 5.12V) | 8-Bit  | LSB | —    | 20   | —    | mV     |  |
| 10                                                                                                                                                                                                                                                 |   | Differential Nonlinearity             | 8-Bit  | DNL | -0.5 | ±0.3 | 0.5  | counts |  |
| 11                                                                                                                                                                                                                                                 |   | Integral Nonlinearity                 | 8-Bit  | INL | -1   | ±0.5 | 1    | counts |  |
| 12                                                                                                                                                                                                                                                 |   | Absolute Error                        | 8-Bit  | AE  | -1.5 | ±1   | 1.5  | counts |  |

1. The 8-bit and 10-bit mode operation is structurally tested in production test. Absolute values are tested in 12-bit mode.

2. These values include the quantization error which is inherently 1/2 count for any A/D converter.

# M.10 0x0500-x053F PMF15B6C

| Address | Name     |        | Bit 7  | 6       | 5     | 4     | 3       | 2            | 1            | Bit 0        |  |  |
|---------|----------|--------|--------|---------|-------|-------|---------|--------------|--------------|--------------|--|--|
| 0x0518  | PMFVAL4  | R<br>W |        | PMFVAL4 |       |       |         |              |              |              |  |  |
| 0x0519  | PMFVAL4  | R<br>W |        | PMFVAL4 |       |       |         |              |              |              |  |  |
| 0x051A  | PMFVAL5  | R<br>W |        |         |       | PMF   | VAL5    |              |              |              |  |  |
| 0x051B  | PMFVAL5  | R<br>W |        | PMFVAL5 |       |       |         |              |              |              |  |  |
| 0x051C  | PMFROIE  | R<br>W | 0      | 0       | 0     | 0     | 0       | PMFROIE<br>C | PMFROIE<br>B | PMFROIE<br>A |  |  |
| 0x051D  | PMFROIF  | R<br>W | 0      | 0       | 0     | 0     | 0       | PMFROIF<br>C | PMFROIF<br>B | PMFROIF<br>A |  |  |
| 0x051E  | PMFICCTL | R<br>W | 0      | 0       | PECC  | PECB  | PECA    | ICCC         | ICCB         | ICCA         |  |  |
| 0x051F  | PMFCINV  | R<br>W | 0      | 0       | CINV5 | CINV4 | CINV3   | CINV2        | CINV1        | CINV0        |  |  |
| 0x0520  | PMFENCA  | R<br>W | PWMENA | GLDOKA  | 0     | 0     | 0       | RSTRTA       | LDOKA        | PWMRIEA      |  |  |
| 0x0521  | PMFFQCA  | R<br>W |        | LDF     | QA    |       | HALFA   | PR           | SCA          | PWMRFA       |  |  |
| 0x0522  | PMFCNTA  | R<br>W | 0      |         |       |       | PMFCNTA |              |              |              |  |  |
| 0x0523  | PMFCNTA  | R<br>W |        |         |       | PMF   | CNTA    |              |              |              |  |  |
| 0x0524  | PMFMODA  | R<br>W | 0      |         |       |       | PMFMODA |              |              |              |  |  |
| 0x0525  | PMFMODA  | R<br>W |        |         |       | PMFN  | IODA    |              |              |              |  |  |
| 0x0526  | PMFDTMA  | R<br>W | 0      | 0       | 0     | 0     |         | PMF          | DTMA         |              |  |  |
| 0x0527  | PMFDTMA  | R<br>W |        |         |       | PMF   | DTMA    |              |              |              |  |  |
| 0x0528  | PMFENCB  | R<br>W | PWMENB | GLDOKB  | 0     | 0     | 0       | RSTRTB       | LDOKB        | PWMRIEB      |  |  |

# M.10 0x0500-x053F PMF15B6C

| Address | Name    |        | Bit 7  | 6                       | 5  | 4    | 3                  | 2      | 1     | Bit 0   |
|---------|---------|--------|--------|-------------------------|----|------|--------------------|--------|-------|---------|
| 0x0529  | PMFFQCB | R<br>W |        | LDFQB HALFB PRSCB PWMRF |    |      |                    |        |       | PWMRFB  |
| 0x052A  | PMFCNTB | R<br>W | 0      | PMFCNTB                 |    |      |                    |        |       |         |
| 0x052B  | PMFCNTB | R<br>W |        |                         |    | PMFC | CNTB               |        |       |         |
| 0x052C  | PMFMODB | R<br>W | 0      |                         |    |      | PMFMODB            |        |       |         |
| 0x052D  | PMFMODB | R<br>W |        | PMFMODB                 |    |      |                    |        |       |         |
| 0x052E  | PMFDTMB | R<br>W | 0      | 0 0 0 PMFDTMB           |    |      |                    |        |       |         |
| 0x052F  | PMFDTMB | R<br>W |        | PMFDTMB                 |    |      |                    |        |       |         |
| 0x0530  | PMFENCC | R<br>W | PWMENC | GLDOKC                  | 0  | 0    | 0                  | RSTRTC | LDOKC | PWMRIEC |
| 0x0531  | PMFFQCC | R<br>W |        | LDFQC                   |    |      | HALFC PRSCC PWMRFC |        |       | PWMRFC  |
| 0x0532  | PMFCNTC | R<br>W | 0      |                         |    |      | PMFCNTC            |        |       |         |
| 0x0533  | PMFCNTC | R<br>W |        |                         |    | PMFC | CNTC               |        |       |         |
| 0x0534  | PMFMODC | R<br>W | 0      |                         |    |      | PMFMODC            |        |       |         |
| 0x0535  | PMFMODC | R<br>W |        |                         |    | PMFN | NODC               |        |       |         |
| 0x0536  | PMFDTMC | R<br>W | 0      | 0                       | 0  | 0    |                    | PMFD   | DTMC  |         |
| 0x0537  | PMFDTMC | R<br>W |        | PMFDTMC                 |    |      |                    |        |       |         |
| 0x0538  | PMFDMP0 | R<br>W | DM     | P05                     | DM | P04  | DMP03              | DMP02  | DMP01 | DMP00   |
| 0x0539  | PMFDMP1 | R<br>W | DM     | P15                     | DM | P14  | DMP13              | DMP12  | DMP11 | DMP10   |