



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

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

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

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

#### Details

| Product Status             | Active                                                                  |
|----------------------------|-------------------------------------------------------------------------|
| Core Processor             | S12Z                                                                    |
| Core Size                  | 16-Bit                                                                  |
| Speed                      | 32MHz                                                                   |
| Connectivity               | CANbus, I <sup>2</sup> C, IrDA, LINbus, SCI, SPI, UART/USART            |
| Peripherals                | LVD, POR, PWM, WDT                                                      |
| Number of I/O              | 19                                                                      |
| Program Memory Size        | 128KB (128K x 8)                                                        |
| Program Memory Type        | FLASH                                                                   |
| EEPROM Size                | 512 x 8                                                                 |
| RAM Size                   | 1K x 8                                                                  |
| Voltage - Supply (Vcc/Vdd) | 5.5V ~ 18V                                                              |
| Data Converters            | A/D 6x10b                                                               |
| Oscillator Type            | Internal                                                                |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                       |
| Mounting Type              | Surface Mount                                                           |
| Package / Case             | 32-LQFP                                                                 |
| Supplier Device Package    | 32-LQFP (7x7)                                                           |
| Purchase URL               | https://www.e-xfl.com/product-detail/nxp-semiconductors/s912zvl12f0clcr |

Email: info@E-XFL.COM

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

|      | 10.6.2 Analog Sub-Block                                                          | 330 |
|------|----------------------------------------------------------------------------------|-----|
|      | 10.6.3 Digital Sub-Block                                                         | 331 |
| 10.7 | Resets                                                                           | 344 |
| 10.8 | Interrupts                                                                       | 344 |
|      | 10.8.1 ADC Conversion Interrupt                                                  | 344 |
|      | 10.8.2 ADC Sequence Abort Done Interrupt                                         | 344 |
|      | 10.8.3 ADC Error and Conversion Flow Control Issue Interrupt                     | 345 |
| 10.9 | Use Cases and Application Information                                            | 346 |
|      | 10.9.1 List Usage — CSL single buffer mode and RVL single buffer mode            | 346 |
|      | 10.9.2 List Usage — CSL single buffer mode and RVL double buffer mode            | 346 |
|      | 10.9.3 List Usage — CSL double buffer mode and RVL double buffer mode            | 347 |
|      | 10.9.4 List Usage — CSL double buffer mode and RVL single buffer mode            | 347 |
|      | 10.9.5 List Usage — CSL double buffer mode and RVL double buffer mode            | 348 |
|      | 10.9.6 RVL swapping in RVL double buffer mode and related registers ADCIMDRI and |     |
|      | ADCEOLRI 348                                                                     |     |
|      | 10.9.7 Conversion flow control application information                           | 350 |
|      | 10.9.8 Continuous Conversion                                                     | 352 |
|      | 10.9.9 Triggered Conversion — Single CSL                                         | 353 |
|      | 10.9.10Fully Timing Controlled Conversion                                        | 354 |

# Chapter 11 Digital Analog Converter (DAC\_8B5V\_V2)

| 11.1 | Revision History                                        |  |
|------|---------------------------------------------------------|--|
| 11.2 | Introduction                                            |  |
|      | 11.2.1 Features                                         |  |
|      | 11.2.2 Modes of Operation                               |  |
|      | 11.2.3 Block Diagram                                    |  |
| 11.3 | External Signal Description                             |  |
|      | 11.3.1 DACU Output Pin                                  |  |
|      | 11.3.2 AMP Output Pin                                   |  |
|      | 11.3.3 AMPP Input Pin                                   |  |
|      | 11.3.4 AMPM Input Pin                                   |  |
| 11.4 | Memory Map and Register Definition                      |  |
|      | 11.4.1 Register Summary                                 |  |
|      | 11.4.2 Register Descriptions                            |  |
| 11.5 | Functional Description                                  |  |
|      | 11.5.1 Functional Overview                              |  |
|      | 11.5.2 Mode "Off"                                       |  |
|      | 11.5.3 Mode "Operational Amplifier"                     |  |
|      | 11.5.4 Mode "Internal DAC only"                         |  |
|      | 11.5.5 Mode "Unbuffered DAC"                            |  |
|      | 11.5.6 Mode "Unbuffered DAC with Operational Amplifier" |  |
|      | 11.5.7 Mode "Buffered DAC"                              |  |
|      | 11.5.8 Analog output voltage calculation                |  |
|      |                                                         |  |

| Command Type      | Secure<br>Status      | BDC<br>Status          | CPU Status                   | Command Set                                                                                                                                                                                                                                                                                                                                                                        |
|-------------------|-----------------------|------------------------|------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Always-available  | Secure or<br>Unsecure | Enabled or<br>Disabled | _                            | <ul> <li>Read/write access to BDCCSR</li> <li>Mass erase flash memory using ERASE_FLASH</li> <li>SYNC</li> <li>ACK enable/disable</li> </ul>                                                                                                                                                                                                                                       |
| Non-intrusive     | Unsecure              | Enabled                | Code<br>execution<br>allowed | <ul> <li>Read/write access to BDCCSR</li> <li>Memory access</li> <li>Memory access with status</li> <li>Mass erase flash memory using ERASE_FLASH</li> <li>Debug register access</li> <li>BACKGROUND</li> <li>SYNC</li> <li>ACK enable/disable</li> </ul>                                                                                                                          |
| Active background | Unsecure              | Active                 | Code<br>execution<br>halted  | <ul> <li>Read/write access to BDCCSR</li> <li>Memory access</li> <li>Memory access with status</li> <li>Mass erase flash memory using ERASE_FLASH</li> <li>Debug register access</li> <li>Read or write CPU registers</li> <li>Single-step the application</li> <li>Exit active BDM to return to the application program (GO)</li> <li>SYNC</li> <li>ACK enable/disable</li> </ul> |

#### Table 5-7. BDC Command Types

Non-intrusive commands are used to read and write target system memory locations and to enter active BDM. Target system memory includes all memory and registers within the global memory map, including external memory.

Active background commands are used to read and write all memory locations and CPU resources. Furthermore they allow single stepping through application code and to exit from active BDM.

Non-intrusive commands can only be executed when the BDC is enabled and the device unsecure. Active background commands can only be executed when the system is not secure and is in active BDM.

Non-intrusive commands do not require the system to be in active BDM for execution, although, they can still be executed in this mode. When executing a non-intrusive command with the ACK pulse handshake protocol disabled, the BDC steals the next bus cycle for the access. If an operation requires multiple cycles, then multiple cycles can be stolen. Thus if stolen cycles are not free cycles, the application code execution is delayed. The delay is negligible because the BDC serial transfer rate dictates that such accesses occur infrequently.

For data read commands, the external host must wait at least 16 BDCSI clock cycles after sending the address before attempting to obtain the read data. This is to be certain that valid data is available in the BDC shift register, ready to be shifted out. For write commands, the external host must wait 16 bdcsi cycles after sending the data to be written before attempting to send a new command. This is to avoid disturbing the BDC shift register before the write has been completed. The external host must wait at least for 16 bdcsi cycles after a control command before starting any new serial command.

#### Background Debug Controller (S12ZBDCV2)

drive at the latest after 6 clock cycles, before the target drives a brief high speedup pulse seven target clock cycles after the perceived start of the bit time. The host should sample the bit level about 10 target clock cycles after it started the bit time.



Figure 5-7. BDC Target-to-Host Serial Bit Timing (Logic 1)

Figure 5-8 shows the host receiving a logic 0 from the target. The host initiates the bit time but the target finishes it. Since the target wants the host to receive a logic 0, it drives the BKGD pin low for 13 target clock cycles then briefly drives it high to speed up the rising edge. The host samples the bit level about 10 target clock cycles after starting the bit time.

#### Background Debug Controller (S12ZBDCV2)

The handshake protocol is enabled by the ACK\_ENABLE command. The BDC sends an ACK pulse when the ACK\_ENABLE command has been completed. This feature can be used by the host to evaluate if the target supports the hardware handshake protocol. If an ACK pulse is issued in response to this command, the host knows that the target supports the hardware handshake protocol.

Unlike the normal bit transfer, where the host initiates the transmission by issuing a negative edge on the BKGD pin, the serial interface ACK handshake pulse is initiated by the target MCU by issuing a negative edge on the BKGD pin. Figure 5-9 specifies the timing when the BKGD pin is being driven. The host must follow this timing constraint in order to avoid the risk of an electrical conflict at the BKGD pin.

When the handshake protocol is enabled, the STEAL bit in BDCCSR selects if bus cycle stealing is used to gain immediate access. If STEAL is cleared, the BDC is configured for low priority bus access using free cycles, without stealing cycles. This guarantees that BDC accesses remain truly non-intrusive to not affect the system timing during debugging. If STEAL is set, the BDC gains immediate access, if necessary stealing an internal bus cycle.

#### NOTE

If bus steals are disabled then a loop with no free cycles cannot allow access. In this case the host must recognize repeated NORESP messages and then issue a BACKGROUND command to stop the target and access the data.

Figure 5-10 shows the ACK handshake protocol without steal in a command level timing diagram. The READ\_MEM.B command is used as an example. First, the 8-bit command code is sent by the host, followed by the address of the memory location to be read. The target BDC decodes the command. Then an internal access is requested by the BDC. When a free bus cycle occurs the READ\_MEM.B operation is carried out. If no free cycle occurs within 512 core clock cycles then the access is aborted, the NORESP flag is set and the target generates a Long-ACK pulse.

Having retrieved the data, the BDC issues an ACK pulse to the host controller, indicating that the addressed byte is ready to be retrieved. After detecting the ACK pulse, the host initiates the data read part of the command.



Figure 5-10. Handshake Protocol at Command Level

Alternatively, setting the STEAL bit configures the handshake protocol to make an immediate internal access, independent of free bus cycles.

# 7.4.3.1 Comparator Match Events

### 7.4.3.1.1 Opcode Address Comparator Match

The comparator is loaded with the address of the selected instruction and the comparator control register INST bit is set. When the opcode reaches the execution stage of the instruction queue a match occurs just before the instruction executes, allowing a breakpoint immediately before the instruction boundary. The comparator address register must contain the address of the first opcode byte for the match to occur. Opcode address matches are data independent thus the RWE and RW bits are ignored. CPU compares are disabled when BDM becomes active.

### 7.4.3.1.2 Data Access Comparator Match

Data access matches are generated when an access occurs at the address contained in the comparator address register. The match can be qualified by the access data and by the access type (read/write). The breakpoint occurs a maximum of 2 instructions after the access in the CPU flow. Note, if a COF occurs between access and breakpoint, the opcode address of the breakpoint can be elsewhere in the memory map.

Opcode fetches are not classed as data accesses. Thus data access matches are not possible on opcode fetches.

# 7.4.3.2 External Event

The DBGEEV input signal can force a state sequencer transition, independent of internal comparator matches. The DBGEEV is an input signal mapped directly to a device pin and configured by the EEVE field in DBGC1. The external events can change the state sequencer state.

If configured to change the state sequencer state, then the external match is mapped to DBGSCRx bits C3SC[1:0]. The DBGEFR bit EEVF is set when an external event occurs.

# 7.4.3.3 Setting The TRIG Bit

Independent of comparator matches it is possible to initiate a breakpoint by writing the TRIG bit in DBGC1 to a logic "1". This forces the state sequencer into the Final State. the transition to Final State is followed immediately by a transition to State0.

Breakpoints, if enabled, are issued on the transition to State0.

### 7.4.3.4 Event Priorities

If simultaneous events occur, the priority is resolved according to Table 7-31. Lower priority events are suppressed. It is thus possible to miss a lower priority event if it occurs simultaneously with an event of a higher priority. The event priorities dictate that in the case of simultaneous matches, the match on the higher comparator channel number (3,1,0) has priority.

If a write access to DBGC1 with the ARM bit position set occurs simultaneously to a hardware disarm from an internal event, then the ARM bit is cleared due to the hardware disarm.

- Enable the external oscillator (OSCE bit).
- Wait for oscillator to start up (UPOSC=1).
- Select the Oscillator Clock (OSCCLK) as source of the Bus Clock (PLLSEL=0).
- The PLLCLK is on and used to qualify the external oscillator clock.

### 9.1.2.2 Wait Mode

For S12CPMU\_UHV Wait Mode is the same as Run Mode.

### 9.1.2.3 Stop Mode

Stop mode can be entered by executing the CPU STOP instruction. See device level specification for more details.

The voltage regulator is in Reduced Performance Mode (RPM).

### NOTE

The voltage regulator output voltage may degrade to a lower value than in Full Performance Mode (FPM), additionally the current sourcing capability is substantially reduced (see also Appendix for VREG electrical parameters). Only clock source ACLK is available and the Power On Reset (POR) circuitry is functional. The Low Voltage Interrupt (LVI) and Low Voltage Reset (LVR) are disabled.

The API is available.

The Phase Locked Loop (PLL) is off.

The Internal Reference Clock (IRC1M) is off.

Core Clock and Bus Clock are stopped.

Depending on the setting of the PSTP and the OSCE bit, Stop Mode can be differentiated between Full Stop Mode (PSTP = 0 or OSCE=0) and Pseudo Stop Mode (PSTP = 1 and OSCE=1). In addition, the behavior of the COP in each mode will change based on the clocking method selected by COPOSCSEL[1:0].

### • Full Stop Mode (PSTP = 0 or OSCE=0)

External oscillator (XOSCLCP) is disabled.

— If COPOSCSEL1=0:

The COP and RTI counters halt during Full Stop Mode.

After wake-up from Full Stop Mode the Core Clock and Bus Clock are running on PLLCLK (PLLSEL=1). COP and RTI are running on IRCCLK (COPOSCSEL0=0, RTIOSCSEL=0).

— If COPOSCSEL1=1:

The clock for the COP is derived from ACLK (trimmable internal RC-Oscillator clock). During Full Stop Mode the ACLK for the COP can be stopped (COP static) or running (COP active) depending on the setting of bit CSAD. When bit CSAD is set the ACLK clock source for the

| CR2 | CR1 | CR0 | COPCLK<br>Cycles to time-out<br>(COPCLK is ACLK divided by 2) |
|-----|-----|-----|---------------------------------------------------------------|
| 0   | 0   | 0   | COP disabled                                                  |
| 0   | 0   | 1   | 2 <sup>7</sup>                                                |
| 0   | 1   | 0   | 2 <sup>9</sup>                                                |
| 0   | 1   | 1   | 2 <sup>11</sup>                                               |
| 1   | 0   | 0   | 2 <sup>13</sup>                                               |
| 1   | 0   | 1   | 2 <sup>15</sup>                                               |
| 1   | 1   | 0   | 2 <sup>16</sup>                                               |
| 1   | 1   | 1   | 2 <sup>17</sup>                                               |

Table 9-16. COP Watchdog Rates if COPOSCSEL1=1.

| TCTRIM[4:0] | IRC1M Indicative relative TC variation | IRC1M indicative frequency drift for relative<br>TC variation |  |
|-------------|----------------------------------------|---------------------------------------------------------------|--|
| 00000       | 0 (nominal TC of the IRC)              | 0%                                                            |  |
| 00001       | -0.27%                                 | -0.5%                                                         |  |
| 00010       | -0.54%                                 | -0.9%                                                         |  |
| 00011       | -0.81%                                 | -1.3%                                                         |  |
| 00100       | -1.08%                                 | -1.7%                                                         |  |
| 00101       | -1.35%                                 | -2.0%                                                         |  |
| 00110       | -1.63%                                 | -2.2%                                                         |  |
| 00111       | -1.9%                                  | -2.5%                                                         |  |
| 01000       | -2.20%                                 | -3.0%                                                         |  |
| 01001       | -2.47%                                 | -3.4%                                                         |  |
| 01010       | -2.77%                                 | -3.9%                                                         |  |
| 01011       | -3.04                                  | -4.3%                                                         |  |
| 01100       | -3.33%                                 | -4.7%                                                         |  |
| 01101       | -3.6%                                  | -5.1%                                                         |  |
| 01110       | -3.91%                                 | -5.6%                                                         |  |
| 01111       | -4.18%                                 | -5.9%                                                         |  |
| 10000       | 0 (nominal TC of the IRC)              | 0%                                                            |  |
| 10001       | +0.27%                                 | +0.5%                                                         |  |
| 10010       | +0.54%                                 | +0.9%                                                         |  |
| 10011       | +0.81%                                 | +1.3%                                                         |  |
| 10100       | +1.07%                                 | +1.7%                                                         |  |
| 10101       | +1.34%                                 | +2.0%                                                         |  |
| 10110       | +1.59%                                 | +2.2%                                                         |  |
| 10111       | +1.86%                                 | +2.5%                                                         |  |
| 11000       | +2.11%                                 | +3.0%                                                         |  |
| 11001       | +2.38%                                 | +3.4%                                                         |  |
| 11010       | +2.62%                                 | +3.9%                                                         |  |
| 11011       | +2.89%                                 | +4.3%                                                         |  |
| 11100       | +3.12%                                 | +4.7%                                                         |  |
| 11101       | +3.39%                                 | +5.1%                                                         |  |
| 11110       | +3.62%                                 | +5.6%                                                         |  |
| 11111       | +3.89%                                 | +5.9%                                                         |  |

| Table 9-28. TC trimmine | a of the frequenc | v of the IRC1M at a | ambient temperature |
|-------------------------|-------------------|---------------------|---------------------|
|                         |                   | ,                   |                     |

### NOTE

Since the IRC1M frequency is not a linear function of the temperature, but more like a parabola, the above relative variation is only an indication and should be considered with care.

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

# 9.5.4 PLL Clock Monitor Reset

In case of loss of PLL clock oscillation or the PLL clock frequency is below the failure assert frequency  $f_{PMFA}$  (see device electrical characteristics for values), the S12CPMU\_UHV generates a PLL Clock Monitor Reset. In Full Stop Mode the PLL and the PLL clock monitor are disabled.

# 9.5.5 Computer Operating Properly Watchdog (COP) Reset

The COP (free running watchdog timer) enables the user to check that a program is running and sequencing properly. When the COP is being used, software is responsible for keeping the COP from timing out. If the COP times out it is an indication that the software is no longer being executed in the intended sequence; thus COP reset is generated.

The clock source for the COP is either ACLK, IRCCLK or OSCCLK depending on the setting of the COPOSCSEL0 and COPOSCSEL1 bit.

Depending on the COP configuration there might be a significant latency time until COP is active again after exit from Stop Mode due to clock domain crossing synchronization. This latency time occurs if COP clock source is ACLK and the CSAD bit is set (please refer to CSAD bit description for details)

Table 9-35 gives an overview of the COP condition (run, static) in Stop Mode depending on legal configuration and status bit settings:

| COPOSCSEL1 | CSAD | PSTP | PCE | COPOSCSEL0 | OSCE | UPOSC | COP counter behavior in Stop Mode<br>(clock source) |
|------------|------|------|-----|------------|------|-------|-----------------------------------------------------|
| 1          | 0    | x    | x   | ×          | x    | x     | Run (ACLK)                                          |
| 1          | 1    | x    | x   | x          | x    | x     | Static (ACLK)                                       |
| 0          | x    | 1    | 1   | 1          | 1    | 1     | Run (OSCCLK)                                        |
| 0          | x    | 1    | 1   | 0          | 0    | x     | Static (IRCCLK)                                     |
| 0          | x    | 1    | 1   | 0          | 1    | x     | Static (IRCCLK)                                     |
| 0          | x    | 1    | 0   | 0          | x    | x     | Static (IRCCLK)                                     |
| 0          | x    | 1    | 0   | 1          | 1    | 1     | Static (OSCCLK)                                     |
| 0          | х    | 0    | 1   | 1          | 1    | 1     | Static (OSCCLK)                                     |
| 0          | х    | 0    | 1   | 0          | 1    | x     | Static (IRCCLK)                                     |
| 0          | х    | 0    | 1   | 0          | 0    | 0     | Static (IRCCLK)                                     |
| 0          | х    | 0    | 0   | 1          | 1    | 1     | Satic (OSCCLK)                                      |
| 0          | х    | 0    | 0   | 0          | 1    | 1     | Static (IRCCLK)                                     |
| 0          | х    | 0    | 0   | 0          | 1    | 0     | Static (IRCCLK)                                     |
| 0          | х    | 0    | 0   | 0          | 0    | 0     | Static (IRCCLK)                                     |

Table 9-35. COP condition (run, static) in Stop Mode



CSL\_SEL = 1'b0 (forced by CSL\_BMOD)

Note: Address register names in () are not absolute addresses instead they are a sample offset or sample index

#### Figure 10-32. Command Sequence List Schema in Single Buffer Mode

While the ADC is enabled, one CSL is active (indicated by bit CSL\_SEL) and the corresponding list should not be modified anymore. At the same time the alternative CSL can be modified to prepare the ADC for new conversion sequences in CSL double buffered mode. When the ADC is enabled, the command address registers (ADCCBP, ADCCROFF\_0/2, ADCCIDX) are read only and register ADCCIDX is under control of the ADC.

#### Analog-to-Digital Converter (ADC12B\_LBA)



RVL\_SEL = 1'b0 (forced by bit RVL\_BMOD)

Note: Address register names in () are not absolute addresses instead they are a sample offset or sample index

#### Figure 10-34. Result Value List Schema in Single Buffer Mode

While ADC is enabled, one Result Value List is active (indicated by bit RVL\_SEL). The conversion Result Value List can be read anytime. When the ADC is enabled the conversion result address registers (ADCRBP, ADCCROFF\_0/1, ADCRIDX) are read only and register ADCRIDX is under control of the ADC.

A conversion result is always stored as 16bit entity in unsigned data representation. Left and right justification inside the entity is selected via the DJM control bit. Unused bits inside an entity are stored zero.

| Conversion Resolution<br>(SRES[1:0]) | Left Justified Result<br>(DJM = 1'b0) | Right Justified Result<br>(DJM = 1'b1) |
|--------------------------------------|---------------------------------------|----------------------------------------|
| 8 bit                                | {Result[7:0],8'b00000000}             | {8'b0000000,Result[7:0]}               |
| 10 bit                               | {Result[9:0],6'b000000}               | {6'b000000,Result[9:0]}                |
| 12 bit                               | {Result[11:0],4'b0000}                | {4'b0000,Result[11:0]}                 |

#### Table 10-33. Conversion Result Justification Overview

# 10.6.3.2.6 Conversion flow control in case of conversion sequence control bit overrun scenarios

#### Restart Request Overrun:

If a legal Restart Request is detected and no Restart Event is in progress, the RSTA bit is set due to the request. The set RSTA bit indicates that a Restart Request was detected and the Restart Event is in process. In case further Restart Requests occur while the RSTA bit is set, this is defined a overrun situation. This scenario is likely to occur when bit STR\_SEQA is set or when a Restart Event causes a Sequence Abort Event. The request overrun is captured in a background register that always stores the last detected overrun request. Hence if the overrun situation occurs more than once while a Restart Event is in progress, only the latest overrun request is pending. When the RSTA bit is cleared, the latest overrun request is processed and RSTA is set again one cycle later.

#### LoadOK Overrun:

Simultaneously at any Restart Request overrun situation the LoadOK input is evaluated and the status is captured in a background register which is alternated anytime a Restart Request Overrun occurs while Load OK Request is asserted. The Load OK background register is cleared as soon as the pending Restart Request gets processed.

#### Trigger Overrun:

If a Trigger occurs whilst bit TRIG is already set, this is defined as a Trigger overrun situation and causes the ADC to cease conversion at the next conversion boundary and to set bit TRIG\_EIF. A overrun is also detected if the Trigger Event occurs automatically generated by hardware in "Trigger Mode" due to a Restart Event and simultaneously a Trigger Event is generated via data bus or internal interface. In this case the ADC ceases operation before conversion begins to sample. In "Trigger Mode" a Restart Request Overrun does not cause a Trigger Overrun (bit TRIG\_EIF not set).

#### Sequence Abort Request Overrun:

If a Sequence Abort Request occurs whilst bit SEQA is already set, this is defined as a Sequence Abort Request Overrun situation and the overrun request is ignored.

Programmable Gain Amplifier (PGAV1)

### 2. CPU stop mode

During stop mode the PGA module is disabled. From the module PGA side no special handling to enter test mode is required. The content of the configuration registers is unchanged.

NOTE

After enabling and after return from CPU stop mode, the PGA module needs a settling time  $t_{PGA settling}$  to get fully operational.

### 12.2.3 Block Diagram



Figure 12-1. PGA Block Diagram

# 12.2.4 External Signal Description

This section lists the name and description of all external ports.

### 12.2.5 Amplifier Inputs

For correct operation all amplifier input pins must be within the common voltage input range V<sub>CM</sub>.

### 12.2.5.1 PGA\_REF0 Pin

This analog pin is used as reference voltage and amplifier minus input voltage if the associated control register bit is set.

### 12.2.5.2 PGA\_REF1 Pin

This analog pin is used as reference voltage and amplifier minus input voltage if the associated control register bit is set.

### 12.2.5.3 PGA\_IN0 Pin

This analog pin is used as amplifier plus input voltage if the associated control register bit is set.

### 12.2.5.4 PGA\_IN1 Pin

This analog pin is used as amplifier plus input voltage if the associated control register bit is set.

### 12.2.6 PGA\_OUT Pin

This analog pin provides the analog amplifier output voltage of the PGA as a function of the gain, offset and the reference voltage.

### 12.3 Memory Map and Register Definition

This sections provides the detailed information of all registers for the PGA module.

### 12.3.1 Register Summary

Figure 12-2 shows the summary of all implemented registers inside the PGA module.

NOTE

Register Address = Module Base Address + Address Offset, where the Module Base Address is defined at the MCU level and the Address Offset is defined at the module level.







| Field            | Description                                                                                                                                                                           |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6–4<br>PCKB[2:0] | <b>Prescaler Select for Clock B</b> — Clock B is one of two clock sources which can be used for all channels. These three bits determine the rate of clock B, as shown in Table 17-8. |
| 2–0<br>PCKA[2:0] | <b>Prescaler Select for Clock A</b> — Clock A is one of two clock sources which can be used for all channels. These three bits determine the rate of clock A, as shown in Table 17-8. |

#### Table 17-7. PWMPRCLK Field Descriptions

#### Table 17-8. Clock A or Clock B Prescaler Selects

| PCKA/B2 | PCKA/B1 | PCKA/B0 | Value of Clock A/B |
|---------|---------|---------|--------------------|
| 0       | 0       | 0       | bus clock          |
| 0       | 0       | 1       | bus clock / 2      |
| 0       | 1       | 0       | bus clock / 4      |
| 0       | 1       | 1       | bus clock / 8      |
| 1       | 0       | 0       | bus clock / 16     |
| 1       | 0       | 1       | bus clock / 32     |
| 1       | 1       | 0       | bus clock / 64     |
| 1       | 1       | 1       | bus clock / 128    |

### 17.3.2.5 PWM Center Align Enable Register (PWMCAE)

The PWMCAE register contains eight control bits for the selection of center aligned outputs or left aligned outputs for each PWM channel. If the CAEx bit is set to a one, the corresponding PWM output will be center aligned. If the CAEx bit is cleared, the corresponding PWM output will be left aligned. See Section 17.4.2.5, "Left Aligned Outputs" and Section 17.4.2.6, "Center Aligned Outputs" for a more detailed description of the PWM output modes.

Module Base + 0x0004



Figure 17-7. PWM Center Align Enable Register (PWMCAE)

Read: Anytime

Write: Anytime

#### NOTE

Write these bits only when the corresponding channel is disabled.

# 21.4 Functional Description

# 21.4.1 General

The S12LINPHYV2 module implements the physical layer of the LIN interface. This physical layer can be driven by the SCI (Serial Communication Interface) module or directly through the LPDR register.

# 21.4.2 Slew Rate and LIN Mode Selection

The slew rate can be selected for Electromagnetic Compatibility (EMC) optimized operation at 10.4 kbit/s and 20 kbit/s as well as at fast baud rate (up to 250 kbit/s) for test and programming. The slew rate can be chosen with the bits LPSLR[1:0] in the LIN Slew Rate Mode Register (LPSLRM). The default slew rate corresponds to 20 kbit/s.

The LIN Physical Layer can also be configured to be used for non-LIN applications (for example, to transmit a PWM pulse) by disabling the TxD-dominant timeout (LPDTDIS=1).

Changing the slew rate (LPSLRM Register) during transmission is not allowed in order to avoid unwanted effects. To change the register, the LIN Physical Layer must first be disabled (LPE=0). Once it is updated the LIN Physical Layer can be enabled again.

### NOTE

For 20 kbit/s and Fast Mode communication speeds, the corresponding slew rate *MUST* be set; otherwise, the communication is not guaranteed (violation of the specified LIN duty cycles). For 10.4 kbit/s, the 20 kbit/s slew rate *can* be set but the EMC performance is worse. The up to 250 kbit/s slew rate must be chosen *ONLY* for fast mode, not for any of the 10.4 kbit/s or 20 kbit/s LIN compliant communication speeds.

### 21.4.2.1 10.4 kbit/s and 20 kbit/s

When the slew rate is chosen for 10.4 kbit/s or 20 kbit/s communication, a control loop is activated within the module to make the rise and fall times of the LIN bus independent from VLINSUP and the load on the bus.

# 21.4.2.2 Fast Mode (not LIN compliant)

Choosing this slew rate allows baud rates up to 250 kbit/s by having much steeper edges (please refer to electricals). As for the 10.4 kbit/s and 20 kbit/s modes, the slope control loop is also engaged. This mode is used for fast communication only, and the LIN electricals are not supported (for example, the LIN duty cycles).

A stronger external pullup resistor might be necessary to sustain communication speeds up to **250 kbit/s.** The LIN signal (and therefore the receive LPRxD signal) might not be symmetrical for high baud rates with high loads on the bus.

#### Flash Module (S12ZFTMRZ)

During the reset sequence, fields DPOPEN and DPS of the DFPROT register are loaded with the contents of the EEPROM protection byte in the Flash configuration field at global address 0xFF\_FE0D located in P-Flash memory (see Table 22-3) as indicated by reset condition F in Table 22-24. To change the EEPROM protection that will be loaded during the reset sequence, the P-Flash sector containing the EEPROM protection byte must be unprotected, then the EEPROM protection byte must be programmed. If a double bit fault is detected while reading the P-Flash phrase containing the EEPROM protection byte must be to leave the EEPROM protection byte must be programmed. If a double bit fault is detected while reading the P-Flash phrase containing the EEPROM protection byte must be memory fully protected.

Trying to alter data in any protected area in the EEPROM memory will result in a protection violation error and the FPVIOL bit will be set in the FSTAT register. Block erase of the EEPROM memory is not possible if any of the EEPROM sectors are protected.

| Field           | Description                                                                                                                         |
|-----------------|-------------------------------------------------------------------------------------------------------------------------------------|
| 7               | EEPROM Protection Control                                                                                                           |
| DPOPEN          | 0 Enables EEPROM memory protection from program and erase with protected address range defined by DPS bits                          |
|                 | 1 Disables EEPROM memory protection from program and erase                                                                          |
| 6–0<br>DPS[6:0] | <b>EEPROM Protection Size</b> — The DPS bits determine the size of the protected area in the EEPROM memory as shown in Table 22-24. |

| DPS[6:0]                                                                                | Global Address Range  | Protected Size |  |  |  |
|-----------------------------------------------------------------------------------------|-----------------------|----------------|--|--|--|
| 0000000                                                                                 | 0x10_0000 - 0x10_001F | 32 bytes       |  |  |  |
| 0000001                                                                                 | 0x10_0000 - 0x10_003F | 64 bytes       |  |  |  |
| 0000010                                                                                 | 0x10_0000 - 0x10_005F | 96 bytes       |  |  |  |
| 0000011                                                                                 | 0x10_0000 – 0x10_007F | 128 bytes      |  |  |  |
| 0000100                                                                                 | 0x10_0000 - 0x10_009F | 160 bytes      |  |  |  |
| The Protection Size goes on enlarging in step of 32 bytes, for each DPS value increment |                       |                |  |  |  |
|                                                                                         |                       |                |  |  |  |
|                                                                                         |                       |                |  |  |  |
| 0001111                                                                                 | 0x10_0000 – 0x10_01FF | 512 bytes      |  |  |  |
| 0011111                                                                                 | 0x10_0000 – 0x10_03FF | 1K byte        |  |  |  |
| 0111111                                                                                 | 0x10_0000 – 0x10_07FF | 2K bytes       |  |  |  |
| 1111111                                                                                 | 0x10_0000 - 0x10_0FFF | 4K bytes       |  |  |  |

#### Table 22-24. EEPROM Protection Address Range

The number of DPS bits depends on the size of the implemented EEPROM. The whole implemented EEPROM range can always be protected. Each DPS value increment increases the size of the protected range by 32-bytes. Thus to protect a 1 KB range DPS[4:0] must be set (protected range of 32 x 32 bytes).

# Appendix J PIM Electrical Specifications

# J.1 High-Voltage Inputs (HVI) Electrical Characteristics

| approxi | oproximate parameter mean at $T_A = 25^{\circ}C^2$ under nominal conditions unless otherwise noted.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                               |                   |                                                                    |                                                          |                       |  |  |  |
|---------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------|-------------------|--------------------------------------------------------------------|----------------------------------------------------------|-----------------------|--|--|--|
| Num     | Ratings                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | Symbol                                                                                        | Min               | Тур                                                                | Max                                                      | Unit                  |  |  |  |
| 1       | Digital Input Threshold<br>• $V_{SUP} > 6.5V$ , $V_{DDX}$ =5V selected<br>• $5.5V \le V_{SUP} \le 6.5V$ , $V_{DDX}$ =5V selected<br>• $V_{SUP} > 5.5V$ , $V_{DDX}$ =3.3V selected                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | V <sub>TH_HVI</sub>                                                                           | 2.8<br>2.0<br>0.8 | 3.5<br>2.5<br>1.8                                                  | 4.5<br>3.8<br>2.7                                        | V<br>V<br>V           |  |  |  |
| 2       | Input Hysteresis                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | V <sub>HYS_HVI</sub>                                                                          | Ι                 | 250                                                                | -                                                        | mV                    |  |  |  |
| 3       | Pin Input Divider Ratio with external series $R_{EXT_HVI}$ Ratio = $V_{HVI} / V_{Internal(ADC)}$                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Ratio <sub>L_HVI</sub><br>Ratio <sub>H_HVI</sub><br>Ratio <sub>12_HVI</sub>                   | -<br>-<br>-       | 2<br>6<br>12                                                       | -<br>-<br>-                                              |                       |  |  |  |
| 4       | Analog Input Matching                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |                                                                                               |                   |                                                                    |                                                          |                       |  |  |  |
|         | $ \begin{array}{l} \mbox{Absolute Error on $V_{ADC}$^3$} \\ & \mbox{Compared to $V_{HVI}$ / Ratio_{\_HVI}$} \\ (1V < V_{HVI} < 7V), $V_{DDX}$=5V selected$\\ (1V < V_{HVI} < 2.8V), $V_{DDX}$=3.3V selected$\\ & \mbox{Compared to $V_{HVI}$ / Ratio_{H_{}HVI}$} \\ (3V < V_{HVI} < 21V), $V_{DDX}$=5V selected$\\ (5V < V_{HVI} < 18V), $V_{DDX}$=5V selected$\\ (3V < V_{HVI} < 8.4V), $V_{DDX}$=3.3V selected$\\ & \mbox{Compared to $V_{HVI}$ / Ratio_{12\_HVI}$} \\ (6V < V_{HVI} < 28V), $V_{DDX}$=5V selected$\\ (6V < V_{HVI} < 14.8V), $V_{DDX}$=3.3V selected$\\ & \mbox{Direct Mode (PTADIRL=1)$} \\ (0.5V < V_{HVI} < 3.5V), $V_{DDX}$=5V selected$\\ (0.5V < V_{HVI} < 1.4V), $V_{DDX}$=3.3V selected$\\ \hline \end{array} $ | AIM <sub>L_HVI</sub><br>AIM <sub>H_HVI</sub><br>AIM <sub>12_HVI</sub><br>AIM <sub>D_HVI</sub> |                   | + 2<br>+ 3<br>+ 2<br>+ 2<br>+ 3<br>+ 3<br>+ 3<br>+ 3<br>+ 2<br>+ 2 | ±5<br>±7<br>±5<br>±3<br>±7<br>±7<br>±7<br>±7<br>±5<br>±5 | %<br>%<br>%<br>%<br>% |  |  |  |
| 5       | High Voltage Input Series Resistor<br><b>Note:</b> Always required externally at HVI pins.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | R <sub>EXT_HVI</sub>                                                                          | -                 | 10                                                                 | -                                                        | kΩ                    |  |  |  |
| 6       | Enable Uncertainty Time                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    | t <sub>UNC_HVI</sub>                                                                          | -                 | 1                                                                  | _                                                        | μS                    |  |  |  |
| 7       | Input capacitance                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | C <sub>IN_HVI</sub>                                                                           | -                 | 8                                                                  | _                                                        | pF                    |  |  |  |
| 8       | Current Injection                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | I <sub>IC_HVI</sub>                                                                           | s                 | 4                                                                  | -                                                        |                       |  |  |  |

#### Table J-1. Static Electrical Characteristics - High Voltage Input Pins - Port L

 $Characteristics \ are \ 5.5V \leq V_{SUP} \leq 18V, \ -40^{\circ}C \leq T_J \leq 175^{\circ}C^1 \ unless \ otherwise \ noted. \ Typical \ values \ noted \ reflect \ the the the term of term of$ 

<sup>1</sup> T<sub>J</sub>: Junction Temperature

<sup>2</sup>  $T_A$ : Ambient Temperature

 $^{3}$  Outside of the given V<sub>HVI</sub> range the error is significant. The ratio can be changed, if outside of the given range

# O.9 0x0480-x04AF PWM0 (continued)

| Address  | Name       |        | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
|----------|------------|--------|-------|---|---|---|---|---|---|-------|
| 0x048A - |            | R      | 0     | 0 | 0 | 0 | 0 | 0 | 0 | 0     |
| 0x048B   | 48B        | W      |       |   |   |   |   |   |   |       |
| 0.0400   |            | R      | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| UXU48C   | PWWCNTU    | W      | 0     | 0 | 0 | 0 | 0 | 0 | 0 | 0     |
| 0.0400   |            | R      | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| 0X048D   | PWMCNTT    | W      | 0     | 0 | 0 | 0 | 0 | 0 | 0 | 0     |
| 0.0405   | DIAMAONITO | R      | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| 0x048E   | PWMCN12    | W      | 0     | 0 | 0 | 0 | 0 | 0 | 0 | 0     |
| 0.0405   |            | R      | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| 0X048F   | PWMCN13    | W      | 0     | 0 | 0 | 0 | 0 | 0 | 0 | 0     |
| 00400    |            | R      | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| 0x0490   | PWMCN14    | W      | 0     | 0 | 0 | 0 | 0 | 0 | 0 | 0     |
| 00404    | DWARONITE  | R      | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| 0x0491   | PWMCN15    | W      | 0     | 0 | 0 | 0 | 0 | 0 | 0 | 0     |
| 0.0400   |            | R      | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| 0x0492   | PWWCN16    | W      | 0     | 0 | 0 | 0 | 0 | 0 | 0 | 0     |
| 0.0402   |            | R      | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| 0x0493   | PWWGNT     | W      | 0     | 0 | 0 | 0 | 0 | 0 | 0 | 0     |
| 0x0494   | PWMPER0    | R<br>W | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| 0x0495   | PWMPER1    | R      | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
|          |            | W      | -     |   |   |   |   |   |   |       |
| 0x0496   | PWMPER2    | R<br>W | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| 0x0497   | PWMPER3    | R<br>W | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| 0x0498   | PWMPER4    | R<br>W | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| 0x0499   | PWMPER5    | R<br>W | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| 0x049A   | PWMPER6    | R<br>W | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| 0x049B   | PWMPER7    | R<br>W | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |

| Address  | Name     | -      | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
|----------|----------|--------|-------|---|---|---|---|---|---|-------|
| 0x049C   | PWMDTY0  | R<br>W | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| 0x049D   | PWMDTY1  | R<br>W | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| 0x049E   | PWMDTY2  | R<br>W | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| 0x049F   | PWMDTY32 | R<br>W | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| 0x04A0   | PWMDTY42 | R<br>W | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| 0x04A1   | PWMDTY52 | R<br>W | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| 0x04A2   | PWMDTY62 | R<br>W | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| 0x04A3   | PWMDTY72 | R<br>W | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0 |
| 0x04A4 - |          | R      | 0     | 0 | 0 | 0 | 0 | 0 | 0 | 0     |
| 0x04AF   |          | W      |       |   |   |   |   |   |   |       |

# O.9 0x0480-x04AF PWM0 (continued)

# O.10 0x0500-x052F PWM1

| Address | Name         | _      | Bit 7   | 6       | 5       | 4       | 3       | 2       | 1       | Bit 0   |
|---------|--------------|--------|---------|---------|---------|---------|---------|---------|---------|---------|
| 0x0500  | PWME         | R<br>W | PWME7   | PWME6   | PWME5   | PWME4   | PWME3   | PWME2   | PWME1   | PWME0   |
| 0x0501  | PWMPOL       | R<br>W | PPOL7   | PPOL6   | PPOL5   | PPOL4   | PPOL3   | PPOL2   | PPOL1   | PPOL0   |
| 0x05022 | PWMCLK       | R<br>W | PCLK7   | PCLKL6  | PCLK5   | PCLK4   | PCLK3   | PCLK2   | PCLK1   | PCLK0   |
| 0x0503  | PWMPRCL<br>K | R<br>W | 0       | PCKB2   | PCKB1   | PCKB0   | 0       | PCKA2   | PCKA1   | PCKA0   |
| 0x0504  | PWMCAE       | R<br>W | CAE7    | CAE6    | CAE5    | CAE4    | CAE3    | CAE2    | CAE1    | CAE0    |
| 0x0505  | PWMCTL       | R<br>W | CON67   | CON45   | CON23   | CON01   | PSWAI   | PFRZ    | 0       | 0       |
|         |              | ••     |         |         |         |         |         |         |         |         |
| 0x0506  | PWMCLKA<br>B | R<br>W | PCLKAB7 | PCLKAB6 | PCLKAB5 | PCLKAB4 | PCLKAB3 | PCLKAB2 | PCLKAB1 | PCLKAB0 |