

Welcome to E-XFL.COM

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

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

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

#### Details

E·XFI

| Product Status             | Active                                                       |
|----------------------------|--------------------------------------------------------------|
| Core Processor             | S12Z                                                         |
| Core Size                  | 16-Bit                                                       |
| Speed                      | 50MHz                                                        |
| Connectivity               | CANbus, LINbus, SCI, SPI                                     |
| Peripherals                | DMA, POR, PWM, WDT                                           |
| Number of I/O              | 31                                                           |
| Program Memory Size        | 32KB (32K 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-LQFP (10x10)                                              |
| Purchase URL               | https://www.e-xfl.com/pro/item?MUrl=&PartUrl=s912zvml32f1wkh |

Email: info@E-XFL.COM

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

|      | 13.1.2     | Block Diagram                         | 478 |
|------|------------|---------------------------------------|-----|
|      | 13.1.3     | Features                              | 479 |
|      | 13.1.4     | Modes of Operation                    | 479 |
| 13.2 | External   | l Signal Description                  | 480 |
|      | 13.2.1     | RXCAN — CAN Receiver Input Pin        | 480 |
|      | 13.2.2     | TXCAN — CAN Transmitter Output Pin    | 480 |
|      | 13.2.3     | CAN System                            | 480 |
| 13.3 | Memory     | y Map and Register Definition         |     |
|      | 13.3.1     | Module Memory Map                     | 481 |
|      | 13.3.2     | Register Descriptions                 | 483 |
|      | 13.3.3     | Programmer's Model of Message Storage | 502 |
| 13.4 | Function   | nal Description                       | 513 |
|      | 13.4.1     | General                               | 513 |
|      | 13.4.2     | Message Storage                       | 513 |
|      | 13.4.3     | Identifier Acceptance Filter          | 516 |
|      | 13.4.4     | Modes of Operation                    | 522 |
|      | 13.4.5     | Low-Power Options                     | 524 |
|      | 13.4.6     | Reset Initialization                  | 528 |
|      | 13.4.7     | Interrupts                            | 528 |
| 13.5 | Initializa | ation/Application Information         | 530 |
|      | 13.5.1     | MSCAN initialization                  | 530 |
|      | 13.5.2     | Bus-Off Recovery                      | 530 |

# Chapter 14 Programmable Trigger Unit (PTUV3)

| 14.1 | Introdu  | ction                                    | l |
|------|----------|------------------------------------------|---|
|      | 14.1.1   | Features                                 | 1 |
|      | 14.1.2   | Modes of Operation                       | 2 |
|      | 14.1.3   | Block Diagram                            | 3 |
| 14.2 | External | Signal Description                       | 3 |
|      | 14.2.1   | PTUT0 — PTU Trigger 0                    | 3 |
|      | 14.2.2   | PTUT1 — PTU Trigger 1                    | 3 |
|      | 14.2.3   | PTURE — PTUE Reload Event                | 1 |
| 14.3 | Memory   | <sup>7</sup> Map and Register Definition | 1 |
|      | 14.3.1   | Register Summary                         | 1 |
|      | 14.3.2   | Register Descriptions                    | 5 |
| 14.4 | Function | nal Description                          | 2 |
|      | 14.4.1   | General                                  | 2 |
|      | 14.4.2   | Memory based trigger event list 554      | 1 |
|      | 14.4.3   | Reload mechanism                         | 5 |
|      | 14.4.4   | Async reload event                       | 5 |
|      | 14.4.5   | Interrupts and error handling            | 5 |
|      | 14.4.6   | Debugging                                | 7 |
|      |          |                                          |   |

| 19.2 | External Signal Description                                  |  |
|------|--------------------------------------------------------------|--|
|      | 19.2.1 LIN — LIN Bus Pin                                     |  |
|      | 19.2.2 LGND — LIN Ground Pin                                 |  |
|      | 19.2.3 VLINSUP — Positive Power Supply                       |  |
|      | 19.2.4 LPTxD — LIN Transmit Pin                              |  |
|      | 19.2.5 LPRxD — LIN Receive Pin                               |  |
| 19.3 | Memory Map and Register Definition                           |  |
|      | 19.3.1 Module Memory Map                                     |  |
|      | 19.3.2 Register Descriptions                                 |  |
| 19.4 | Functional Description                                       |  |
|      | 19.4.1 General                                               |  |
|      | 19.4.2 Slew Rate and LIN Mode Selection                      |  |
|      | 19.4.3 Modes                                                 |  |
|      | 19.4.4 Interrupts                                            |  |
| 19.5 | Application Information                                      |  |
|      | 19.5.1 Module Initialization                                 |  |
|      | 19.5.2 Interrupt handling in Interrupt Service Routine (ISR) |  |

# Chapter 20 Flash Module (S12ZFTMRZ)

| 20.1 | Introduction                                                    |  |
|------|-----------------------------------------------------------------|--|
|      | 20.1.1 Glossary                                                 |  |
|      | 20.1.2 Features                                                 |  |
|      | 20.1.3 Block Diagram                                            |  |
| 20.2 | External Signal Description                                     |  |
| 20.3 | Memory Map and Registers                                        |  |
|      | 20.3.1 Module Memory Map                                        |  |
|      | 20.3.2 Register Descriptions                                    |  |
| 20.4 | Functional Description                                          |  |
|      | 20.4.1 Modes of Operation                                       |  |
|      | 20.4.2 IFR Version ID Word                                      |  |
|      | 20.4.3 Flash Block Read Access                                  |  |
|      | 20.4.4 Internal NVM resource                                    |  |
|      | 20.4.5 Flash Command Operations                                 |  |
|      | 20.4.6 Allowed Simultaneous P-Flash and EEPROM Operations       |  |
|      | 20.4.7 Flash Command Description                                |  |
|      | 20.4.8 Interrupts                                               |  |
|      | 20.4.9 Wait Mode                                                |  |
|      | 20.4.10Stop Mode                                                |  |
| 20.5 | Security                                                        |  |
|      | 20.5.1 Unsecuring the MCU using Backdoor Key Access             |  |
|      | 20.5.2 Unsecuring the MCU in Special Single Chip Mode using BDM |  |
|      | 20.5.3 Mode and Security Effects on Flash Command Availability  |  |
| 20.6 | Initialization                                                  |  |

- Water pump
- Oil pump
- A/C compressor
- HVAC blower
- Engine cooling fan
- Electric vehicle battery cooling fan
- Brush DC motor control requiring driving in 2 directions, along with PWM control for
  - Reversible wiper
  - Trunk opener

# 1.2 Features

This section describes the key features of the MC9S12ZVM-Family. It documents the superset of features within the family. Some module versions differ from one part to another within the family. Section 1.2.1 MC9S12ZVM-Family Member Comparison provides information to help access the correct information for a particular part within the family.

# 1.2.1 MC9S12ZVM-Family Member Comparison

Table 1-2 provides a summary of feature set differences within the MC9S12ZVM-Family.

| Feature         | ZVMC25<br>6        | ZVML12<br>8  | ZVMC12<br>8  | ZVML6<br>4   | ZVMC6<br>4   | ZVML3<br>2   | ZVML3<br>1   | ZVML3<br>1   | ZVM32        | ZVM32        | ZVM16        | ZVM16        |
|-----------------|--------------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|
| Flash           | 256 KB             | 128 KB       | 128 KB       | 64 KB        | 64 KB        | 32 KB        | 16 KB        | 16 KB        |
| EEPROM          | 1 KB               | 512<br>Bytes | 512<br>Bytes | 512<br>Bytes | 512<br>Bytes | 512<br>Bytes | 128<br>Bytes | 128<br>Bytes | 128<br>Bytes | 128<br>Bytes | 128<br>Bytes | 128<br>Bytes |
| RAM             | 32 KB              | 8 KB         | 8 KB         | 4 KB         | 2 KB         | 2 KB         |
| Package         | 80 pin             | 64 pin       | 64 pin       | 64 pin       | 64 pin       | 64 pin       | 64 pin       | 48 pin       | 64 pin       | 48 pin       | 64 pin       | 48 pin       |
| LINPHY          | -                  | 1            | -            | 1            | -            | 1            | 1            | 1            | -            | -            | -            | -            |
| HVPHY           | -                  | -            | -            | -            | -            | -            | -            | -            | 1            | 1            | 1            | 1            |
| SCI             | 2                  | 2            | 2            | 2            | 2            | 2            | 2            | 2            | 2            | 2            | 2            | 2            |
| SPI             | 1                  | 1            | 1            | 1            | 1            | 1            | 1            | 0            | 1            | 0            | 1            | 0            |
| ADC<br>channels | 8+8                | 4+5          | 4+5          | 4+5          | 4+5          | 4+5          | 4+5          | 1+3          | 4+5          | 1+3          | 4+5          | 1+3          |
| PMF<br>channels | 6                  | 6            | 6            | 6            | 6            | 6            | 6            | 6            | 6            | 6            | 6            | 6            |
| TIM<br>channels | 4 TIM0 +<br>2 TIM1 | 4            | 4            | 4            | 4            | 4            | 4            | 3            | 4            | 3            | 4            | 3            |

 Table 1-2. S12ZVM Family Feature Set Differences

The exposed pad on the package bottom must be connected to a grounded contact pad on the PCB.



Figure 1-5. S12ZVMC Option 64-pin LQFP pin out

MC9S12ZVM Family Reference Manual Rev. 2.11

Chapter 1 Device Overview MC9S12ZVM-Family

| Pin | Pin   |              | (Priority a  | Supply       | Internal Pull<br>Resistor |              |              |              |                  |               |                |
|-----|-------|--------------|--------------|--------------|---------------------------|--------------|--------------|--------------|------------------|---------------|----------------|
| #   | Name  | 1st<br>Func. | 2nd<br>Func. | 3rd<br>Func. | 4th<br>Func.              | 5th<br>Func. | 6th<br>Func. | 7th<br>Func. | Supply           | CTRL          | Reset<br>State |
| 48  | HS0   | —            | —            | —            | —                         | —            | _            | _            | —                | —             | _              |
| 49  | HS2   | —            | _            | —            | —                         | —            | _            | _            | —                | —             | _              |
| 50  | HG2   | —            | _            | —            | —                         | —            | _            | _            | —                | —             | _              |
| 51  | VBS2  | —            | —            | —            | —                         | —            | _            | _            | —                | —             | _              |
| 52  | VLS2  | —            | _            | —            | —                         | —            | _            | _            | —                | —             | _              |
| 53  | LG2   | —            | _            | —            | —                         | —            | _            | _            | —                | —             | _              |
| 54  | LS2   | —            | _            | —            | —                         | —            | _            | _            | —                | —             | _              |
| 55  | LS1   | —            | —            | —            | —                         | —            | _            | _            | —                | —             | —              |
| 56  | LG1   | —            | —            | —            | —                         | —            | _            | _            | —                | —             | _              |
| 57  | VLS1  | —            | —            | —            | —                         | —            | _            | _            | —                | —             | _              |
| 58  | VBS1  | —            | —            | —            | —                         | —            | _            | _            | —                | —             | —              |
| 59  | HG1   | —            | —            | —            | —                         | —            | _            | _            | —                | —             | —              |
| 60  | HS1   | —            | —            | —            | —                         | —            |              |              | —                | —             | —              |
| 61  | PT0   | IOC0_0       | PWM1_<br>3   | MISO0        | RXD0                      | PWM0_<br>5   |              |              | V <sub>DDX</sub> | PERT/<br>PPST | Off            |
| 62  | PT1   | IOC0_1       | PWM1_<br>4   | MOSI0        | TXD0                      | —            |              | _            | V <sub>DDX</sub> | PERT/<br>PPST | Off            |
| 63  | PT2   | IOC0_2       | PWM1_<br>0   | SCK0         | PWM0_<br>7                | —            | —            | —            | V <sub>DDX</sub> | PERT/<br>PPST | Off            |
| 64  | PT3   | IOC0_3       | PWM1_<br>2   | SS0          | PWM0_<br>3                | —            | —            | —            | V <sub>DDX</sub> | PERT/<br>PPST | Off            |
| 65  | RESET | —            | —            | —            | —                         | —            | —            | _            | V <sub>DDX</sub> | TEST<br>pin   | Up             |
| 66  | PE1   | XTAL         | _            | _            | _                         | _            | _            |              | V <sub>DDX</sub> | PERE/<br>PPSE | Down           |
| 67  | PE0   | EXTAL        | —            | _            | —                         | _            | _            | _            | V <sub>DDX</sub> | PERE/<br>PPSE | Down           |
| 68  | TEST  | —            | _            | _            | _                         | _            |              | _            | -                | RESET         | Down           |
| 69  | PS3   | KWS3         | TXD1         | MOSI0        | CPTXD<br>0                | DBGEE<br>V   | IOC1_1       | _            | V <sub>DDX</sub> | PERS/<br>PPSS | Up             |
| 70  | PS2   | KWS2         | RXD1         | MISO0        | CPRXD<br>0                | IOC1_0       | _            | —            | V <sub>DDX</sub> | PERS/<br>PPSS | Up             |

Table 1-9. Pin Summary For 80-Pin Package Option (ZVMC256 Only) (Sheet 4 of 5)

MC9S12ZVM Family Reference Manual Rev. 2.11

#### Chapter 1 Device Overview MC9S12ZVM-Family



Figure 1-13. BDCM Complementary Mode Waveform

Assuming first quadrant operation, forward accelerating operation, the applied voltage at node A must exceed the applied voltage at node B (Figure 1-11). Thus the PWM0\_0 duty cycle must exceed the PWM0\_2 duty cycle.

The duty cycle of PWM0\_0 defines the voltage at the first power stage branch.

The duty cycle of PWM0\_2 defines the voltage at the second power stage branch.

Modulating the duty cycle every period using the function  $F_{PWM}$  then the duty cycle is expressed as:

 $PWM0_0 \text{ duty-cycle} = 0.5 + (0.5 * F_{PWM}); \text{ For -1} <= F_{PWM} <= 1;$ 

 $PWM0_2 \text{ duty-cycle} = 0.5 - (0.5 * F_{PWM})$ 

Chapter 2 Port Integration Module (S12ZVMPIMV3)

• Selectable drive strength for high current capable outputs

# 2.2 External Signal Description

This section lists and describes the signals that do connect off-chip.

Table 2-2 to Table 2-8 show all pins with the pins and functions that are controlled by the PIM. Routing options are denoted in parenthesis.

### NOTE

If there is more than one function associated with a pin, the <u>output</u> priority is indicated by the position in the table from top (highest priority) to bottom (lowest priority).Inputs do not arbitrate priority unless noted differently in Table 2-40.

| Port | Pin<br>Name | ZVMC256 | ZVMC128\64 | ZVML128/64/32 | ZVML31 | ZVM32/16 | Pin Function<br>& Priority | 1/0 | Description             | Routing<br>Register Bit | Pin Function<br>after Reset |
|------|-------------|---------|------------|---------------|--------|----------|----------------------------|-----|-------------------------|-------------------------|-----------------------------|
| -    | BKGD        | <       | <          | >             | >      | >        | MODC <sup>1</sup>          | Ι   | MODC input during RESET | —                       | BKGD                        |
|      |             | >       | ۲          | >             | >      | >        | BKGD                       | I/O | S12ZBDC communication   | —                       |                             |

| Table 2-2. | BKGD | Pin | <b>Functions</b> | and | <b>Priorities</b> |
|------------|------|-----|------------------|-----|-------------------|
|            |      |     |                  |     |                   |

1. Function active when RESET asserted.

| Port | Pin<br>Name | ZVMC256 | ZVMC128\64 | ZVML128/64/32 | 15VML31 | ZVM32/16 | Pin Function<br>& Priority | I/O | Description     | Routing<br>Register Bit | Pin Function<br>after Reset |
|------|-------------|---------|------------|---------------|---------|----------|----------------------------|-----|-----------------|-------------------------|-----------------------------|
| Е    | PE1         | >       | ٢          | ~             | >       | <        | XTAL                       | -   | CPMU OSC signal | —                       | GPIO                        |
|      |             | >       | •          | >             | >       | ~        | PTE[1]                     | I/O | General-purpose | —                       |                             |
|      | PE0         | ~       | <          | ~             | ~       | ~        | EXTAL                      | -   | CPMU OSC signal | —                       |                             |
|      |             | >       | •          | •             | >       | ~        | PTE[0]                     | I/O | General-purpose | —                       |                             |

#### Table 2-3. Port E Pin Functions and Priorities

# 2.3 Memory Map and Register Definition

This section provides a detailed description of all port integration module registers.

Subsection 2.3.1 shows all registers and bits at their related addresses within the global SoC register map. A detailed description of every register bit is given in subsection 2.3.2 to 2.3.4.

# 3.1.1 Glossary

| Term                      | Definition                                                                                  |
|---------------------------|---------------------------------------------------------------------------------------------|
| MCU                       | Microcontroller Unit                                                                        |
| CPU                       | S12Z Central Processing Unit                                                                |
| BDC                       | S12Z Background Debug Controller                                                            |
| ADC                       | Analog-to-Digital Converter                                                                 |
| PTU                       | Programmable Trigger Unit                                                                   |
| unmapped<br>address range | Address space that is not assigned to a memory                                              |
| reserved address<br>range | Address space that is reserved for future use cases                                         |
| illegal access            | Memory access, that is not supported or prohibited by the S12ZMMC, e.g. a data store to NVM |
| access violation          | Either an illegal access or an uncorrectable ECC error                                      |
| byte                      | 8-bit data                                                                                  |
| word                      | 16-bit data                                                                                 |

#### Table 3-2. Glossary Of Terms

## 3.1.2 Overview

The S12ZMMC provides access to on-chip memories and peripherals for the S12ZCPU, the S12ZBDC, the PTU, and the ADC. It arbitrates memory accesses and determines all of the MCU memory maps. Furthermore, the S12ZMMC is responsible for selecting the MCUs functional mode.

## 3.1.3 Features

- S12ZMMC mode operation control
- Memory mapping for S12ZCPU and S12ZBDC, PTU and ADCs
  - Maps peripherals and memories into a 16 MByte address space for the S12ZCPU, the S12ZBDC, the PTU, and the ADCs
  - Handles simultaneous accesses to different on-chip resources (NVM, RAM, and peripherals)
- Access violation detection and logging
  - Triggers S12ZCPU machine exceptions upon detection of illegal memory accesses and uncorrectable ECC errors
  - Logs the state of the S12ZCPU and the cause of the access error

#### Chapter 6 S12Z Debug (S12ZDBG) Module

The number of core clock cycles since the last entry equals the timestamp + 1. The core clock runs at twice the frequency of the bus clock. The timestamp of the first trace buffer entry is 0x0000. With timestamps enabled trace buffer entries are initiated in the following ways:

- according to the trace mode specification, for example COF PC addresses in Normal mode
- on a timestamp counter overflow If the timestamp counter reaches 0xFFFF then a trace buffer entry is made, with timestamp= 0xFFFF and the timestamp overflow bit TOVF is set.
- on a match of comparator D

If STAMP and DSTAMP are set then comparator D is used for forcing trace buffer entries with timestamps. The state control register settings determine if comparator D is also used to trigger the state sequencer. Thus if the state control register configuration does not use comparator D, then it is used solely for the timestamp function. If comparator D initiates a timestamp then the CTI bit is set in the INFO byte. This can be used in Normal/Loop1 mode to indicate when a particular data access occurs relative to the PC flow. For example when the timing of an access may be unclear due to the use of indexes.

### NOTE

If comparator D is configured to match a PC address then associated timestamps trigger a trace buffer entry during execution of the previous instruction. Thus the PC stored to the trace buffer is that of the previous instruction. The comparator must contain the PC address of the instruction's first opcode byte

Timestamps are disabled in Pure PC mode.

## 6.4.5.4 Reading Data from Trace Buffer

The data stored in the trace buffer can be read using either the background debug controller (BDC) module or the CPU provided the DBG module is not armed and is configured for tracing by TSOURCE. When the ARM bit is set the trace buffer is locked to prevent reading. The trace buffer can only be unlocked for reading by an aligned word write to DBGTB when the module is disarmed. The trace buffer can only be read through the DBGTB register using aligned word reads. Reading the trace buffer while the DBG module is armed, or trace buffer locked returns 0xEE and no shifting of the RAM pointer occurs. Any byte or misaligned reads return 0xEE and do not cause the trace buffer pointer to increment to the next trace buffer address.

Reading the trace buffer is prevented by internal hardware whilst profiling is active because the RAM pointer is used to indicate the next row to be transmitted. Thus attempted reads of DBGTB do not return valid data when the PTACT bit is set. To initialize the pointer and read profiling data, the PTACT bit must be cleared and remain cleared.

The trace buffer data is read out first-in first-out. By reading CNT in DBGCNT the number of valid 64-bit lines can be determined. DBGCNT does not decrement as data is read.

Whilst reading, an internal pointer is used to determine the next line to be read. After a tracing session, the pointer points to the oldest data entry, thus if no overflow has occurred, the pointer points to line0. The

# 7.2.2.5 ECC Debug Data (ECCDDH, ECCDDL)



Figure 7-6. ECC Debug Data (ECCDDH, ECCDDL)

#### Table 7-6. ECCDD Register Field Descriptions

| Field           | Description                                                                                                                                                                      |
|-----------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DDATA<br>[23:0] | ECC Debug Raw Data — This register contains the raw data which will be written into the system memory during a debug write command or the read data from the debug read command. |

# 7.2.2.6 ECC Debug ECC (ECCDE)



1. Read: Anytime Write: Anytime

#### Figure 7-7. ECC Debug ECC (ECCDE)

#### Table 7-7. ECCDE Field Description

| Field            | Description                                                                                                                                                                           |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5:0<br>DECC[5:0] | ECC Debug ECC — This register contains the raw ECC value which will be written into the system memory during a debug write command or the ECC read value from the debug read command. |

#### MC9S12ZVM Family Reference Manual Rev. 2.11

<sup>1.</sup> Read: Anytime Write: Anytime



Figure 9-28. Sampling and Conversion Timing Example (8-bit Resolution, 4 Cycle Sampling)

Please note that there is always a pump phase of two ADC\_CLK cycles before the sample phase begins, hence glitches during the pump phase could impact the conversion accuracy for short sample times.

## 9.6.3 Digital Sub-Block

The digital sub-block contains a list-based programmer's model and the control logic for the analog subblock circuits.

### 9.6.3.1 Analog-to-Digital (A/D) Machine

The A/D machine performs the analog-to-digital conversion. The resolution is program selectable to be either 8- or 10- or 12 bits. The A/D machine uses a successive approximation architecture. It functions by comparing the sampled and stored analog voltage with a series of binary coded discrete voltages.

By following a binary search algorithm, the A/D machine identifies the discrete voltage that is nearest to the sampled and stored voltage.

Only analog input signals within the potential range of VRL\_0/1 to VRH\_0/1/3 (availability of VRL\_1 and VRH\_2 see Table 9-2) (A/D reference potentials) will result in a non-railed digital output code.

### 9.6.3.2 Introduction of the Programmer's Model

The ADC\_LBA provides a programmer's model that uses a system memory list-based architecture for definition of the conversion command sequence and conversion result handling.

The Command Sequence List (CSL) and Result Value List (RVL) are implemented in double buffered manner and the buffer mode is user selectable for each list (bits CSL\_BMOD, RVL\_BMOD). The 32-bit wide conversion command is double buffered and the currently active command is visible in the ADC register map at ADCCMD register space.

- When finished:

This bit is cleared when the first conversion command of the sequence from top of active Sequence Command List is loaded

- Mandatory Requirement:

- In all ADC conversion flow control modes a Restart Event causes bit RSTA to be set. Bit SEQA is set simultaneously by ADC hardware if:

\* ADC not idle (a conversion or conversion sequence is ongoing and current CSL not finished) and no Sequence Abort Event in progress (bit SEQA not already set or set simultaneously via internal interface or data bus)

\* ADC idle but RVL done condition not reached

The RVL done condition is reached by one of the following:

\* A "End Of List" command type has been executed

\* A Sequence Abort Event is in progress or has been executed (bit SEQA already set or set simultaneously via internal interface or data bus)

The ADC executes the Sequence Abort Event followed by the Restart Event for the conditions described before or only a Restart Event.

- In ADC conversion flow control mode "Trigger Mode" a Restart Event causes bit TRIG being set automatically. Bit TRIG is set when no conversion or conversion sequence is ongoing (ADC idle) and the RVL done condition is reached by one of the following:

\* A "End Of List" command type has been executed

\* A Sequence Abort Event is in progress or has been executed

The ADC executes the Restart Event followed by the Trigger Event.

- In ADC conversion flow control mode "Trigger Mode" a Restart Event and a simultaneous Trigger Event via internal interface or data bus causes the TRIG\_EIF bit being set and ADC cease operation.

### • Restart Event + CSL Exchange (Swap)

Internal Interface Signals: Restart + LoadOK Corresponding Bit Names: RSTA + LDOK

- Function:

Go to top of active CSL (clear index register for CSL) and switch to other offset register for address calculation if configured for double buffer mode (exchange the CSL list) *Requested by:* 

- Internal interface with the assertion of Interface Signal Restart the interface Signal LoadOK is evaluated and bit LDOK is set accordingly (bit LDOK set if Interface Signal LoadOK asserted when Interface Signal Restart asserts).

- Write Access via data bus to set control bit RSTA simultaneously with bit LDOK.

- When finished:

Bit LDOK can only be cleared if it was set as described before and both bits (LDOK, RSTA) are cleared when the first conversion command from top of active Sequence Command List is loaded

*– Mandatory Requirement:* 

No ongoing conversion or conversion sequence Details if using the internal interface:



Figure 15-72. Setting asserted LDOK bit at PWM reload event

## 15.4.12.2 Global Load Enable

If a global load enable bit GLDOKA, B, or C is set, the global load OK bit defined on device level as input to the PMF replaces the function of the related local LDOKA, B, or C bits. The global load OK signal is typically shared between multiple IP blocks with the same double buffer scheme. Software handling must be transferred to the global load OK bit at the chip level.

### 15.4.12.3 Load Frequency

The LDFQ3, LDFQ2, LDFQ1, and LDFQ0 bits in the PWM control register (PMFFQCx) select an integral loading frequency of 1 to 16-PWM reload opportunities. The LDFQ bits take effect at every PWM reload opportunity, regardless the state of the related load okay bit or global load OK. The *half* bit in the PMFFQC register controls half-cycle reloads for center-aligned PWMs. If the *half* bit is set, a reload opportunity occurs at the beginning of every PWM cycle and half cycle when the count equals the modulus. If the half bit is not set, a reload opportunity occurs only at the beginning of every cycle. Reload opportunities can only occur at the beginning of a PWM cycle in edge-aligned mode.

### NOTE

Setting the half bit takes effect immediately. Depending on whether the counter is incrementing or decrementing at this point in time, reloads at even-numbered reload frequencies (every 2, 4, 6,... reload opportunities) will occur only when the counter matches the modulus or only when the counter equals zero, respectively (refer to example of reloading at every two opportunities in Figure 15-74).

### NOTE

Loading a new modulus on a half cycle will force the count to the new modulus value minus one on the next clock cycle. Half cycle reloads are possible only in center-aligned mode. Enabling or disabling half-cycle reloads in edge-aligned mode will have no effect on the reload rate.

Table 15-46. Effects of OUTCTL and OUT Bits on PWM Output Pair in Complementary Mode

| OUTCTL<br>(odd,even) | OUT<br>(odd,even) | PWM<br>(odd) | PWM<br>(even) |
|----------------------|-------------------|--------------|---------------|
| 00                   | ХХ                | PWMgen(even) | PWMgen(even)  |
| 11                   | 10                | OUTB(even)=1 | OUTB(even)=0  |
| 01                   | x0                | 0            | OUTB(even)=0  |

#### The recommended setup is:

```
PMFCFG0[INDEPC,INDEPB,INDEPA] = 0x0; // Complementary mode
PMFCFG1[ENCE] = 1; // Enable commutation event
PMFOUTB = 0x2A; // Set return path pattern, high-side off, low-side on
PMFOUTC = 0x1C; // Branch A->B, "mask" C // 0°
```

The commutation sequence is:

| PMFOUTC = | 0x34; | // | Branch | A->C,   | "mask" | в // | 60°  |
|-----------|-------|----|--------|---------|--------|------|------|
| PMFOUTC = | 0x31; | // | Branch | B->C,   | "mask" | A // | 120° |
| PMFOUTC = | 0x13; | // | Branch | B - >A, | "mask" | C // | 180° |
| PMFOUTC = | 0x07; | 11 | Branch | C - >A, | "mask" | в // | 240° |
| PMFOUTC = | 0x0D; | 11 | Branch | C->B,   | "mask" | A // | 300° |
| PMFOUTC = | 0x1C; | // | Branch | A->B,   | "mask" | C // | 360° |
|           |       |    |        |         |        |      |      |

#### Table 15-47. Unipolar Switching Sequence

| Branch | Channel | <b>0</b> ° | 60°   | <b>120</b> ° | 180° | <b>240</b> ° | <b>300</b> ° |
|--------|---------|------------|-------|--------------|------|--------------|--------------|
| А      | PWM0    | PWN        | /Igen | 0            | (    | )            | 0            |
|        | PWM1    | PWN        | /Igen | 0            |      | 1            | 0            |
| В      | PWM2    | 0          | 0     | PWN          | lgen | 0            | 0            |
|        | PWM3    | 1          | 0     | PWN          | Mgen | 0            | 1            |
| С      | PWM4    | 0          | (     | )            | 0    | PWN          | /Igen        |
|        | PWM5    | 0          |       | 1            | 0    | PWN          | /Igen        |

### 15.8.2.2 Bipolar Switching Mode

Bipolar switching mode uses register bits MSK5-0 and PINVA, B, C to perform commutation.

The recommended setup is:

| PMFCFG0[INDEPC,INDEPB,INDEPA] | = | 0x0;  | // | Complem | nentary | mode  |    |     |     |
|-------------------------------|---|-------|----|---------|---------|-------|----|-----|-----|
| PMFCFG1 [ENCE]                | = | 1;    | 11 | Enable  | commuta | ation | ev | ent |     |
| PMFCFG2 [MSK5:MSK0]           | = | 0x30; | 11 | Branch  | A<->B,  | mask  | С  | 11  | 0 ° |
| PMFCFG3 [PINVC, PINVB, PINVA] | = | 0x2;  | 11 | Invert  | В       |       |    |     |     |
|                               |   |       |    |         |         |       |    |     |     |
| The commutation sequence is:  |   |       |    |         |         |       |    |     |     |

Chapter 16 Serial Communication Interface (S12SCIV6)

# 16.4.5 Transmitter



Figure 16-16. Transmitter Block Diagram

## 16.4.5.1 Transmitter Character Length

The SCI transmitter can accommodate either 8-bit or 9-bit data characters. The state of the M bit in SCI control register 1 (SCICR1) determines the length of data characters. When transmitting 9-bit data, bit T8 in SCI data register high (SCIDRH) is the ninth bit (bit 8).

## 16.4.5.2 Character Transmission

To transmit data, the MCU writes the data bits to the SCI data registers (SCIDRH/SCIDRL), which in turn are transferred to the transmitter shift register. The transmit shift register then shifts a frame out through the TXD pin, after it has prefaced them with a start bit and appended them with a stop bit. The SCI data registers (SCIDRH and SCIDRL) are the write-only buffers between the internal data bus and the transmit shift register.

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

### 19.3.2.6 LIN Status Register (LPSR)



#### 1. Read: Anytime

Write: Never, writes to this register have no effect

#### Table 19-7. LPSR Field Description

| Field | Description                                                                                                                                                                          |
|-------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7     | LIN Transmitter TxD-dominant timeout Status Bit — This read-only bit signals that the LPTxD pin is still                                                                             |
| LPDT  | dominant after a TxD-dominant timeout. As long as the LPTxD is dominant after the timeout the LIN transmitter is shut down and the LPTDIF is set again after attempting to clear it. |
|       | <ul> <li>0 If there was a TxD-dominant timeout, LPTxD has ceased to be dominant after the timeout.</li> <li>1 LPTxD is still dominant after a TxD-dominant timeout.</li> </ul>       |

### **19.3.2.7** LIN Interrupt Enable Register (LPIE)



1. Read: Anytime

Write: Anytime

| Register | Error Bit | Error Condition                                                                     |
|----------|-----------|-------------------------------------------------------------------------------------|
|          | ACCERR    | Set if CCOBIX[2:0] != 000 at command launch                                         |
|          | ACCERK    | Set if command not available in current mode (see Table 20-29)                      |
| FSTAT    | FPVIOL    | Set if any area of the P-Flash or 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 20-46. Erase All Blocks Command Error Handling

### 20.4.7.7.1 Erase All Pin

The functionality of the Erase All Blocks command is also available in an uncommanded fashion from the *soc\_erase\_all\_req* input pin on the Flash module. Refer to the Reference Manual for information on control of *soc\_erase\_all\_req*.

The erase-all function requires the clock divider register FCLKDIV (see Section 20.3.2.1) to be loaded before invoking this function using *soc\_erase\_all\_req* input pin. The FCLKDIV configuration for this feature is described at device level. If FCLKDIV is not properly set the erase-all operation will not execute and the ACCERR flag in FSTAT register will set. After the execution of the erase-all function the FCLKDIV register will be reset and the value of register FCLKDIV must be loaded before launching any other command afterwards.

Before invoking the erase-all function using the *soc\_erase\_all\_req* pin, the ACCERR and FPVIOL flags in the FSTAT register must be clear. When invoked from *soc\_erase\_all\_req* the erase-all function will erase all P-Flash memory and EEPROM memory space regardless of the protection settings. If the posterase verify passes, the routine will then release security by setting the SEC field of the FSEC register to the unsecure state (see Section 20.3.2.2). The security byte in the Flash Configuration Field will be programmed to the unsecure state (see Table 20-9). The status of the erase-all request is reflected in the ERSAREQ bit in the FCNFG register (see Section 20.3.2.5). The ERSAREQ bit in FCNFG will be cleared once the operation has completed and the normal FSTAT error reporting will be available as described inTable 20-47.

At the end of the erase-all sequence Protection will remain configured as it was before executing the eraseall function. If the application requires programming P-Flash and/or EEPROM after the erase-all function completes, the existing protection limits must be taken into account. If protection needs to be disabled the user may need to reset the system right after completing the erase-all function.

| Register | Error Bit | Error Condition                                                                                                                   |
|----------|-----------|-----------------------------------------------------------------------------------------------------------------------------------|
|          | ACCERR    | Set if command not available in current mode (see Table 20-29)                                                                    |
| FSTAT    | MGSTAT1   | Set if any errors have been encountered during the erase verify operation, or during the program verify operation                 |
|          | MGSTAT0   | Set if any non-correctable errors have been encountered during the erase verify operation, or during the program verify operation |

Table 20-47. Erase All Pin Error Handling

• The channel is disabled

In this way, the output of the PWM will always be either the old duty waveform or the new duty waveform, not some variation in between. If the channel is not enabled, then writes to the duty register will go directly to the latches as well as the buffer.

#### NOTE

Reads of this register return the most recent value written. Reads do not necessarily return the value of the currently active duty due to the double buffering scheme.

See Section 22.4.2.3, "PWM Period and Duty" for more information.

### NOTE

Depending on the polarity bit, the duty registers will contain the count of either the high time or the low time. If the polarity bit is one, the output starts high and then goes low when the duty count is reached, so the duty registers contain a count of the high time. If the polarity bit is zero, the output starts low and then goes high when the duty count is reached, so the duty registers contain a count of the low time.

To calculate the output duty cycle (high time as a% of period) for a particular channel:

• Polarity = 0 (PPOL x =0)

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

• Polarity = 1 (PPOLx = 1)

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

For boundary case programming values, please refer to Section 22.4.2.8, "PWM Boundary Cases".

Module Base + 0x001C = PWMDTY0, 0x001D = PWMDTY1, 0x001E = PWMDTY2, 0x001F = PWMDTY3 Module Base + 0x0020 = PWMDTY4, 0x0021 = PWMDTY5, 0x0022 = PWMDTY6, 0x0023 = PWMDTY7

| _      | 7     | 6 | 5 | 4 | 3 | 2 | 1 | 0     |
|--------|-------|---|---|---|---|---|---|-------|
| R<br>W | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| Reset  | 1     | 1 | 1 | 1 | 1 | 1 | 1 | 1     |

Figure 22-14. PWM Channel Duty Registers (PWMDTYx)

<sup>1</sup> This register is available only when the corresponding channel exists and is reserved if that channel does not exist. Writes to a reserved register have no functional effect. Reads from a reserved register return zeroes.

Read: Anytime

Write: Anytime

| NOT         | TES:                                                                                                                                                                      |                                                                                                                                                 |  |  |  |  |  |  |
|-------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|
| 1.          | DIMENSIONS ARE IN MILLIMETERS.                                                                                                                                            |                                                                                                                                                 |  |  |  |  |  |  |
| 2.          | INTERPRET DIMENSIONS AND TOLERANCES PER ASME Y14.5M-1994.                                                                                                                 |                                                                                                                                                 |  |  |  |  |  |  |
| 3.          | DATUMS A, B AND D TO BE DETERMINED AT DA                                                                                                                                  | ATUM PLANE H.                                                                                                                                   |  |  |  |  |  |  |
| 4.          | DIMENSIONS TO BE DETERMINED AT SEATING PLA                                                                                                                                | ANE C.                                                                                                                                          |  |  |  |  |  |  |
| <u>A</u>    | DIMENSION DOES NOT INCLUDE DAMBAR PROTRU<br>SHALL NOT CAUSE THE LEAD WIDTH TO EXCEED<br>THAN 0.08 MM. DAMBAR CANNOT BE LOCATED<br>MINIMUM SPACE BETWEEN PROTRUSION AND AD | JSION. ALLOWABLE DAMBAR PROTRUSION<br>D THE MAXIMUM DIMENSION BY MORE<br>ON THE LOWER RADIUS OR THE FOOT.<br>JACENT LEAD OR PROTRUSION 0.07 MM. |  |  |  |  |  |  |
| Â           | DIMENSIONS DO NOT INCLUDE MOLD PROTRUSION<br>PER SIDE. DIMENSIONS ARE MAXIMUM PLASTIC E<br>MISMATCH.                                                                      | N. ALLOWABLE PROTRUSION IS 0.25 MM<br>BODY SIZE DIMENSIONS INCLUDING MOLD                                                                       |  |  |  |  |  |  |
| $\triangle$ | EXACT SHAPE OF EACH CORNER IS OPTIONAL.                                                                                                                                   |                                                                                                                                                 |  |  |  |  |  |  |
| <u>/8.</u>  | THESE DIMENSIONS APPLY TO THE FLAT SECTION 0.25 MM FROM THE LEAD TIP.                                                                                                     | N OF THE LEAD BETWEEN 0.10 MM AND                                                                                                               |  |  |  |  |  |  |
| <u>/9.</u>  | HATCHED AREA TO BE KEEP OUT ZONE FOR PC                                                                                                                                   | B ROUTING.                                                                                                                                      |  |  |  |  |  |  |
|             |                                                                                                                                                                           |                                                                                                                                                 |  |  |  |  |  |  |
| TITLE:      | LQFP, 10 X 10 X 1.4 PKG,                                                                                                                                                  | CASE NUMBER: 1899-03                                                                                                                            |  |  |  |  |  |  |
|             | 0.5 PITCH, 64LD,<br>61 x 61 EXPOSED PAD                                                                                                                                   | STANDARD: JEDEC MS-026 BCD                                                                                                                      |  |  |  |  |  |  |
|             | U.I X U.I LAFUSED FAD                                                                                                                                                     | SHEET: 4                                                                                                                                        |  |  |  |  |  |  |