



#### 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

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

Email: info@E-XFL.COM

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



Figure 1-2. MC9S12ZVM-Family Global Memory Map. (See Table 1-3 for individual device details)

- 6. Map the sine/cosine input signals to ADC input channels.
- 7. Configure the EVDD1 pin as output.
- 8. Optionally use GDU phase comparators for zero crossing detection to correct dead time distortion.
- 9. Fetch targeted motor speed parameter from external source (e.g. SCI)
- 10. Configure PMF period and duty cycle.
- 11. Start motor by applying startup algorithm.
- 12. Sample the sine/cosine voltages periodically based on PWM cycle to determine motor position.
- 13. Use FOC algorithm to determine back EMF and motor speed.





The device supports the use of an external PNP to supplement the VDDX supply, for reducing on chip power dissipation. In this configuration, most of the current flowing from VRBATP to VDDX, flows through the external PNP, using the BCTL pin for PNP base current control. The configuration can be selected by register bits EXTXON and INTXON.

The maximum current that can be sourced by the voltage regulator without the external PNP is specified as IDDX, for different VSUP ranges, in the electrical parameter appendices. Depending on activity and external loading, an application current may exceed this specification limit. In such cases the external PNP configuration must be used.

A supply for the internal CANPHY is offered via device pins BCTLC and VDDC, whereby BCTLC provides the base current of an external PNP and VDDC is the CANPHY supply (output voltage of the external PNP). This configuration can be enabled by the register bit EXTCON.

Two separate 5V range supplies (VDDS1 and VDDS2) are provided for external (sensor) components. These supplies also use external PNP configurations, whereby the PNP base current is controlled by BCTLS1 and BCTLS2 for VDDS1 and VDDS2 respectively.

The VDDS1 and VDDS2 supplies feature sense inputs SNPS1 and SNPS2, to detect a short circuit or over current condition and subsequently limit the current to avoid damage.

For each ADC instantiation, the ADC register bit VRH\_SEL maps the ADC reference VRH to VDDA or to a VDDS of a tracker regulator. The Figure 1-19 example only shows one ADC to VDDS connection.

# 1.13.8.1 Voltage Domain Monitoring

The BATS module monitors the voltage on the VSUP pin, providing status and flag bits, an interrupt and a connection to the ADC, for accurate measurement of the scaled VSUP level.

The POR circuit monitors the VDD and VDDA domains, ensuring a reset assertion until an adequate voltage level is attained. The LVR circuit monitors the VDD, VDDF and VDDX domains, generating a reset when the voltage in any of these domains drops below the specified assert level. The VDDX LVR monitor is disabled when the VREG is in reduced power mode. A low voltage interrupt circuit monitors the VDDA domain.

The GDU high side drain voltage, pin HD, is monitored within the GDU and mapped to an interrupt. A connection to the ADC is provided for accurate measurement of a scaled HD level.

# 1.13.8.2 FET-Predriver (GDU) Supplies

A dedicated low drop regulator is used to generate the VLS\_OUT voltage from VSUP. The VLS\_OUT voltage is used to supply the low side drivers and can be directly connected to the VLS inputs of each low side driver. For FET-predriver operation at lower VSUP levels, a boost circuit can be enabled by the GBOE register bit. The boost circuit requires Shottky diodes, a coil and capacitors, as shown in Figure 1-18. More detailed information is included in the GDU module description.

## 1.13.8.2.1 Bootstrap Precharge

The FET-predriver high side driver must provide a sufficient gate-source voltage and sufficient charge for the gate capacitance of the external FETs. A bootstrap circuit is used to provide sufficient charge, whereby

### Chapter 2 Port Integration Module (S12ZVMPIMV3)

| Global<br>Address | Register<br>Name   |   | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1 | Bit 0  |
|-------------------|--------------------|---|-------|---|---|---|---|---|---|--------|
| 0x02F8–           | Peserved           | R | 0     | 0 | 0 | 0 | 0 | 0 | 0 | 0      |
| 0x02FC            | Reserved           | W |       |   |   |   |   |   |   |        |
|                   |                    | R | 0     | 0 | 0 | 0 | 0 | 0 | 0 |        |
| 0x02FD            | RDRP               | W |       |   |   |   |   |   |   | RDRP0  |
| 0x02FE-           | Decerved           | R | 0     | 0 | 0 | 0 | 0 | 0 | 0 | 0      |
| 0x0330            | Reserved           | W |       |   |   |   |   |   |   |        |
| 0.0224            | DTII 2             | R | 0     | 0 | 0 | 0 | 0 | 0 | 0 | PTIL0  |
| 0x0331            | PIIL-              | W |       |   |   |   |   |   |   |        |
|                   |                    | R | 0     | 0 | 0 | 0 | 0 | 0 | 0 | 0      |
| 0x0332            | Reserved           | W |       |   |   |   |   |   |   |        |
|                   | DTDOL <sup>2</sup> | R | 0     | 0 | 0 | 0 | 0 | 0 | 0 |        |
| 0x0333            | PIPSL              | W |       |   |   |   |   |   |   | PTPSL0 |
| 0.0004            |                    | R | 0     | 0 | 0 | 0 | 0 | 0 | 0 |        |
| 0x0334            | PPSL <sup>-</sup>  | W |       |   |   |   |   |   |   | PPSL0  |
| 0,0225            | Deserved           | R | 0     | 0 | 0 | 0 | 0 | 0 | 0 | 0      |
| 0x0335            | Reserved           | W |       |   |   |   |   |   |   |        |
|                   | 2                  | R | 0     | 0 | 0 | 0 | 0 | 0 | 0 |        |
| 0x0336 PIE        | PIEL <sup>2</sup>  | W |       |   |   |   |   |   |   | PIEL0  |
| 00007             | DIE! 2             | R | 0     | 0 | 0 | 0 | 0 | 0 | 0 |        |
| UXU337            | PIFL <sup>2</sup>  | w |       |   |   |   |   |   |   | PIFLU  |

| Command<br>Mnemonic     | Command<br>Classification | ACK | Command<br>Structure          | Description                                                                                                                                                                                                                                                                                                                      |
|-------------------------|---------------------------|-----|-------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| DUMP_MEM.sz             | Non-Intrusive             | Yes | (0x32+4 x sz)/dack/rd.sz      | Dump (read) memory based on operand<br>size (sz). Used with READ_MEM to dump<br>large blocks of memory. An initial<br>READ_MEM is executed to set up the<br>starting address of the block and to retrieve<br>the first result. Subsequent DUMP_MEM<br>commands retrieve sequential operands.                                     |
| DUMP_MEM.sz_WS          | Non-Intrusive             | No  | (0x33+4 x sz)/d/ss/rd.sz      | Dump (read) memory based on operand<br>size (sz) and report status. Used with<br>READ_MEM{_WS} to dump large blocks of<br>memory. An initial READ_MEM{_WS} is<br>executed to set up the starting address of<br>the block and to retrieve the first result.<br>Subsequent DUMP_MEM{_WS}<br>commands retrieve sequential operands. |
| FILL_MEM.sz             | Non-Intrusive             | Yes | (0x12+4 x sz)/wd.sz/dack      | Fill (write) memory based on operand size<br>(sz). Used with WRITE_MEM to fill large<br>blocks of memory. An initial WRITE_MEM<br>is executed to set up the starting address of<br>the block and to write the first operand.<br>Subsequent FILL_MEM commands write<br>sequential operands.                                       |
| FILL_MEM.sz_WS          | Non-Intrusive             | No  | (0x13+4 x sz)/wd.sz/d/ss      | Fill (write) memory based on operand size<br>(sz) and report status. Used with<br>WRITE_MEM{_WS} to fill large blocks of<br>memory. An initial WRITE_MEM{_WS} is<br>executed to set up the starting address of<br>the block and to write the first operand.<br>Subsequent FILL_MEM{_WS} commands<br>write sequential operands.   |
| GO                      | Active<br>Background      | Yes | 0x08/dack                     | Resume CPU user code execution                                                                                                                                                                                                                                                                                                   |
| GO_UNTIL <sup>(2)</sup> | Active<br>Background      | Yes | 0x0C/dack                     | Go to user program. ACK is driven upon returning to active background mode.                                                                                                                                                                                                                                                      |
| NOP                     | Non-Intrusive             | Yes | 0x00/dack                     | No operation                                                                                                                                                                                                                                                                                                                     |
| READ_Rn                 | Active<br>Background      | Yes | (0x60+CRN)/dack/rd32          | Read the requested CPU register                                                                                                                                                                                                                                                                                                  |
| READ_MEM.sz             | Non-Intrusive             | Yes | (0x30+4 x sz)/ad24/dack/rd.sz | Read the appropriately-sized (sz) memory value from the location specified by the 24-<br>bit address                                                                                                                                                                                                                             |
| READ_MEM.sz_WS          | Non-Intrusive             | No  | (0x31+4 x sz)/ad24/d/ss/rd.sz | Read the appropriately-sized (sz) memory value from the location specified by the 24-<br>bit address and report status                                                                                                                                                                                                           |
| READ_DBGTB              | Non-Intrusive             | Yes | (0x07)/dack/rd32/dack/rd32    | Read 64-bits of DBG trace buffer                                                                                                                                                                                                                                                                                                 |

## Table 5-8. BDC Command Summary (continued)

### Chapter 5 Background Debug Controller (S12ZBDCV2)

5. Listens to the BKGD pin for the sync response pulse.

Upon detecting the sync request from the host (which is a much longer low time than would ever occur during normal BDC communications), the target:

- 1. Discards any incomplete command
- 2. Waits for BKGD to return to a logic high.
- 3. Delays 16 cycles to allow the host to stop driving the high speed-up pulse.
- 4. Drives BKGD low for 128 BDCSI clock cycles.
- 5. Drives a 1-cycle high speed-up pulse to force a fast rise time on BKGD.
- 6. Removes all drive to the BKGD pin so it reverts to high impedance.
- 7. Clears the OVRRUN flag (if set).

The host measures the low time of this 128-cycle SYNC response pulse and determines the correct speed for subsequent BDC communications. Typically, the host can determine the correct communication speed within a few percent of the actual target speed and the serial protocol can easily tolerate this speed error.

If the SYNC request is detected by the target, any partially executed command is discarded. This is referred to as a soft-reset, equivalent to a timeout in the serial communication. After the SYNC response, the target interprets the next negative edge (issued by the host) as the start of a new BDC command or the start of new SYNC request.

A SYNC command can also be used to abort a pending ACK pulse. This is explained in Section 5.4.8.

# 5.4.4.2 ACK\_DISABLE

Disable host/target handshake protocol

Always Available



Disables the serial communication handshake protocol. The subsequent commands, issued after the ACK\_DISABLE command, do not execute the hardware handshake protocol. This command is not followed by an ACK pulse.

# 5.4.4.3 ACK\_ENABLE

Enable host/target handshake protocol

Always Available

# 6.2.2 **Profiling Output**

The DBG module features a profiling data output signal PDO. The mapping of this signal to a device pin is specified in the device specific documentation. The device pin is enabled for profiling by setting the PDOE bit. The profiling function can be enabled by the PROFILE bit in the DBGTCRL control register. This signal is output only and provides a serial, encoded data stream that can be used by external development tools to reconstruct the internal CPU code flow, as specified in Section 6.4.6. During code profiling the device PDOCLK output is used as a clock signal.

# 6.3 Memory Map and Registers

## 6.3.1 Module Memory Map

A summary of the registers associated with the DBG module is shown in Figure 6-2. Detailed descriptions of the registers and bits are given in the subsections that follow.

| Address | Name    |        | Bit 7    | 6         | 5        | 4      | 3      | 2        | 1       | Bit 0 |
|---------|---------|--------|----------|-----------|----------|--------|--------|----------|---------|-------|
| 0x0100  | DBGC1   | R<br>W | ARM      | 0<br>TRIG | reserved | BDMBP  | BRKCPU | reserved | EE      | VE    |
| 0x0101  | DBGC2   | R      | 0        | 0         | 0        | 0      | CD     | CM       | AB      | CM    |
| 0,0101  | 55002   | W      |          |           |          |        | 00     |          | , 12    |       |
| 0x0102  | DBGTCRH | R<br>W | reserved | TSOURCE   | TRA      | NGE    | TRCI   | MOD      | TAL     | IGN   |
| 0x0103  | DBGTCRL | R<br>W | 0        | 0         | 0        | PREND  | DSTAMP | PDOE     | PROFILE | STAMP |
| 0x0104  | DBGTB   | R      | Bit 15   | Bit 14    | Bit 13   | Bit 12 | Bit 11 | Bit 10   | Bit 9   | Bit 8 |
| 0,0104  | DBGIB   | W      |          |           |          |        |        |          |         |       |
| 0x0105  | DBGTB   | R      | Bit 7    | Bit 6     | Bit 5    | Bit 4  | Bit 3  | Bit 2    | Bit 1   | Bit 0 |
|         |         | vv     |          |           |          |        |        |          |         |       |
| 0x0106  | DBGCNT  | R      | 0        |           |          |        | CNT    |          |         |       |
|         |         | ~      |          |           |          |        |        |          |         |       |
| 0x0107  | DBGSCR1 | к<br>W | C3SC1    | C3SC0     | C2SC1    | C2SC0  | C1SC1  | C1SC0    | C0SC1   | C0SC0 |
| 0x0108  | DBGSCR2 | R<br>W | C3SC1    | C3SC0     | C2SC1    | C2SC0  | C1SC1  | C1SC0    | C0SC1   | C0SC0 |
|         |         | R      |          |           |          |        |        |          |         |       |
| 0x0109  | DBGSCR3 | W      | C3SC1    | C3SC0     | C2SC1    | C2SC0  | C1SC1  | C1SC0    | C0SC1   | C0SC0 |
| 0x010A  | DBGEFR  | R      | PTBOVF   | TRIGF     | 0        | EEVF   | ME3    | ME2      | ME1     | ME0   |
|         |         | W      |          |           |          |        |        |          |         |       |
| 0x010B  | DBGSR   | R      | TBF      | 0         | 0        | PTACT  | 0      | SSF2     | SSF1    | SSF0  |
|         |         | ٧V     |          |           |          |        |        |          |         |       |

Figure 6-2. Quick Reference to DBG Registers

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

# 8.3 Memory Map and Registers

This section provides a detailed description of all registers accessible in the S12CPMU\_UHV\_V10\_V6.

## 8.3.1 Module Memory Map

The S12CPMU\_UHV\_V10\_V6 registers are shown in Figure 8-5.

| Address<br>Offset | Register<br>Name  |        | Bit 7  | 6                           | 5       | 4              | 3           | 2          | 1             | Bit 0          |  |
|-------------------|-------------------|--------|--------|-----------------------------|---------|----------------|-------------|------------|---------------|----------------|--|
| 0×0000            | CPMU              | R      | 0      | 0                           | 0       | 0              | 0           | 0          | 0             | 0              |  |
| 0,0000            | RESERVED00        | W      |        |                             |         |                |             |            |               |                |  |
|                   | RESERVED          | R      | 0      | 0                           | 0       | 0              | U           | U          | U             | U              |  |
| 0x0001            | CPMU<br>VREGTRIM0 | W      |        |                             |         |                |             |            |               |                |  |
|                   | RESERVED          | R      | 0      | 0                           | U       | U              | U           | 0          | 0             | 0              |  |
| 0x0002            | CPMU<br>VREGTRIM1 | W      |        |                             |         |                |             |            |               |                |  |
| 0v0003            |                   | R      | 0      | PORE                        | I.V.R.F | 0              | COPRE       | 0          | OMRE          | PMRF           |  |
| 0,0000            |                   | W      |        | 1 OIG                       | LVIN    |                | oonn        |            | ONIN          |                |  |
| 0x0004            | CPMU<br>SYNR      | R<br>W | VCOFF  | Q[1:0]                      |         |                | SYND        | IV[5:0]    |               |                |  |
|                   | CPMU              | R      |        | <u></u>                     | 0       | 0              |             |            |               |                |  |
| 0x0005            | REFDIV            | W      | REFFR  | Q[1:0]                      |         |                | REFDIV[3:0] |            |               |                |  |
| 0x0006            | CPMU              | R      | 0      | 0                           | 0       |                |             | ΡΟSΤΟΙνία· | 01            |                |  |
| 0,0000            | POSTDIV           | W      |        |                             |         |                |             |            |               |                |  |
| 0x0007            | CPMUIELG          | R      | RTIF   | 0                           | 0       |                | LOCK        | 0          | OSCIE         | UPOSC          |  |
| 0,0001            |                   | W      |        |                             |         | Loona          |             |            |               |                |  |
| 0x0008            | CPMUINT           | R      | RTIF   | 0                           | 0       | I OCKIE        | 0           | 0          | OSCIE         | 0              |  |
|                   |                   | W      |        |                             |         |                |             |            |               |                |  |
| 0x0009            | CPMUCLKS          | R<br>W | PLLSEL | PSTP                        | CSAD    | COP<br>OSCSEL1 | PRE         | PCE        | RTI<br>OSCSEL | COP<br>OSCSEL0 |  |
|                   |                   | R      | 0      | 0                           |         |                | 0           | 0          | 0             | 0              |  |
| 0x000A            | CPMUPLL           | W      |        |                             | FM1     | FM0            |             |            |               |                |  |
| 0.0000            |                   | R      | DTDEO  | DTDC                        | DTD5    | DTD4           |             |            |               | DTDO           |  |
| 0X000B            | CPMURTI           | W      | RIDEC  | RIRO                        | RIRD    | RIR4           | RIRJ        | RIRZ       | RIRI          | RIRU           |  |
| 0x000C            | CPMUCOP           | R      | WCOP   | RSBCK                       | 0       | 0              | 0           | CR2        | CR1           | CR0            |  |
| 0,0000            |                   | W      | 1001   | ROBOR                       | WRTMASK |                |             | 0112       | OIT           |                |  |
| 0x000D            | RESERVED          | R      | 0      | 0                           | 0       | 0              | 0           | 0          | 0             | 0              |  |
|                   | CPMUTEST0         | W      |        |                             |         |                |             |            |               |                |  |
|                   |                   |        |        | = Unimplemented or Reserved |         |                |             |            |               |                |  |

Figure 8-5. CPMU Register Summary

| 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 8-16. COP Watchdog Rates if COPOSCSEL1=1.

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

## 8.3.2.13 Reserved Register CPMUTEST0

## NOTE

This reserved register is designed for factory test purposes only, and is not intended for general user access. Writing to this register when in Special Mode can alter the S12CPMU\_UHV\_V10\_V6's functionality.

Module Base + 0x000D



Figure 8-18. Reserved Register (CPMUTEST0)

Read: Anytime

Write: Only in Special Mode

## 8.3.2.14 Reserved Register CPMUTEST1

NOTE

This reserved register is designed for factory test purposes only, and is not intended for general user access. Writing to this register when in Special Mode can alter the S12CPMU\_UHV\_V10\_V6's functionality.



Figure 8-19. Reserved Register (CPMUTEST1)

Read: Anytime

Write: Only in Special Mode

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

# 8.4.5 External Oscillator

## 8.4.5.1 Enabling the External Oscillator

An example of how to use the oscillator as source of the Bus Clock is shown in Figure 8-44.

### Figure 8-44. Enabling the external oscillator



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

| Address | Name             |         | Bit 7          | 6                 | 5             | 4        | 3         | 2        | 1         | Bit 0    |
|---------|------------------|---------|----------------|-------------------|---------------|----------|-----------|----------|-----------|----------|
| 0x0010  | ADCEOLRI         | R       | CSL_EOL        | RVL_EOL           | 0             | 0        | 0         | 0        | 0         | 0        |
|         |                  | vv<br>R | 0              | 0                 | 0             | 0        | 0         | 0        | 0         | 0        |
| 0x0011  | Reserved         | W       | -              | -                 | -             | -        | -         | -        |           |          |
| 0x0012  | Reserved         | R       | 0              | 0                 | 0             | 0        | 0         | 0        | 0         | 0        |
|         |                  | W       | Reserved       |                   |               | Received |           |          | 0         | 0        |
| 0x0013  | Reserved         | W       | Reserved       |                   |               | Reserved |           |          | 0         | 0        |
| 0v0014  | ADCCMD_0         | R       | CMD            | SEL               | 0             | 0        |           | INTEL G  | SEI [3·0] |          |
| 0,0014  | (V1)             | W       |                |                   |               |          |           |          | _322[3.0] |          |
| 0x0014  | $ADCCMD_0$       | R       | CMD            | SEL               | OPT[          | 1:0]     |           | INTFLG   | _SEL[3:0] |          |
|         | ADCCMD 1         | R       |                |                   |               |          |           |          |           |          |
| 0x0015  | (V1, V2)         | W       | VRH_SEL        | VRL_SEL           |               |          | CH_S      | SEL[5:0] |           |          |
| 0x0015  | ADCCMD_1<br>(V3) | R<br>W  | VRH_S          | EL[1:0]           |               |          | CH_9      | SEL[5:0] |           |          |
| 0x0016  | ADCCMD_2         | R       |                |                   | SMP[4:0]      |          |           | 0        | 0         | Reserved |
|         |                  | W<br>R  |                |                   |               |          |           |          |           |          |
| 0x0016  | (V2, V3)         | W       |                |                   | SMP[4:0]      |          |           | OPT      | [3:2]     | Reserved |
| 0x0017  | ADCCMD_3         | R<br>W  | Reserved       | Reserved Reserved |               |          |           |          |           |          |
| 0x0018  | Reserved         | R<br>W  |                |                   |               | Res      | served    |          |           |          |
| 0x0019  | Reserved         | R<br>W  |                |                   |               | Res      | served    |          |           |          |
| 0x001A  | Reserved         | R<br>W  |                |                   |               | Re       | served    |          |           |          |
| 0x001B  | Reserved         | R<br>W  |                |                   |               | Res      | served    |          |           |          |
| 0x001C  | ADCCIDX          | R       | 0              | 0                 |               |          | CMD_      | IDX[5:0] |           |          |
|         |                  | vv<br>R |                |                   |               |          |           |          |           |          |
| 0x001D  | ADCCBP_0         | W       |                |                   |               | CMD_P    | TR[23:16] |          |           |          |
| 0x001E  | ADCCBP_1         | R<br>W  |                |                   |               | CMD_F    | PTR[15:8] |          |           |          |
| 0x001F  | ADCCBP_2         | R<br>W  |                |                   | CMD_P         | TR[7:2]  |           |          | 0         | 0        |
| 0x0020  | ADCRIDX          | R       | 0              | 0                 |               |          | RES_      | IDX[5:0] |           |          |
| 0 0004  |                  | R       |                |                   |               |          |           |          |           |          |
| 0x0021  | ADCRBP_0         | W       | RES_PTR[19:16] |                   |               |          |           |          |           |          |
| 0x0022  | ADCRBP_1         | R<br>W  |                |                   |               | RES_F    | PTR[15:8] |          |           |          |
| 0x0023  | ADCRBP_2         | R<br>W  |                |                   | RES_P         | TR[7:2]  |           |          | 0         | 0        |
|         |                  |         |                | = Unimplem        | nented or Res | served   |           |          |           |          |

Figure 9-3. ADC12B\_LBA Register Summary (Sheet 2 of 3)

Chapter 9 Analog-to-Digital Converter (ADC12B\_LBA)

## 9.6.3.2.4 The two conversion flow control Mode Configurations

The ADC provides two modes ("Trigger Mode" and "Restart Mode") which are different in the conversion control flow. The "Restart Mode" provides precise timing control about the sample start point but is more complex from the flow control perspective, while the "Trigger Mode" is more simple from flow control point of view but is less controllable regarding conversion sample start.

Following are the key differences:

In "Trigger Mode" configuration, when conversion flow control bit RSTA gets set the bit TRIG gets set automatically. Hence in "Trigger Mode" the applications should not set the bit TRIG and bit RSTA simultaneously (via data bus or internal interface), because it is a flow control failure and the ADC will cease operation.

In "Trigger Mode" configuration, after the execution of the initial Restart Event the current CSL can be executed and controlled via Trigger Events only. Hence, if the "End Of List" command is reached a restart of conversion flow from top of current CSL does not require to set bit RSTA because returning to the top of current CSL is done automatically. Therefore the current CSL can be executed again after the "End Of List" command type is executed by a Trigger Event only.

In "Restart Mode" configuration, the execution of a CSL is controlled via Trigger Events and Restart Events. After execution of the "End Of List" command the conversion flow must be continued by a Restart Event followed by a Trigger Event and the Trigger Event must not occur before the Restart Event has finished.

For more details and examples regarding flow control and application use cases please see following section and Section 9.9.7, "Conversion flow control application information.

## 9.6.3.2.5 The four ADC conversion flow control bits

There are four bits to control conversion flow (execution of a CSL and CSL exchange in double buffer mode). Each bit is controllable via the data bus and internal interface depending on the setting of ACC\_CFG[1:0] bits (see also Figure 9-2). In the following the conversion control event to control the conversion flow is given with the related internal interface signal and corresponding register bit name together with information regarding:

- Function of the conversion control event
- How to request the event
- When is the event finished
- Mandatory requirements to executed the event

A summary of all event combinations is provided by Table 9-11.

## • Trigger Event

Internal Interface Signal: Trigger Corresponding Bit Name: TRIG

### Table 11-2. TIOS Field Descriptions

Note: Writing to unavailable bits has no effect. Reading from unavailable bits return a zero.

| Field           | Description                                                                                                                                                                                                                  |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0<br>IOS[3:0] | <ul><li>Input Capture or Output Compare Channel Configuration</li><li>0 The corresponding implemented channel acts as an input capture.</li><li>1 The corresponding implemented channel acts as an output compare.</li></ul> |

## 11.3.2.2 Timer Compare Force Register (CFORC)

Module Base + 0x0001



Read: Anytime but will always return 0x0000 (1 state is transient)

Write: Anytime

## Table 11-3. CFORC Field Descriptions

Note: Writing to unavailable bits has no effect. Reading from unavailable bits return a zero.

| Field           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0<br>FOC[3:0] | <b>Note:</b> Force Output Compare Action for Channel 3:0 — A write to this register with the corresponding data bit(s) set causes the action which is programmed for output compare "x" to occur immediately. The action taken is the same as if a successful comparison had just taken place with the TCx register except the interrupt flag does not get set. If forced output compare on any channel occurs at the same time as the successful output compare then forced output compare action will take precedence and interrupt flag won't get set. |

# 11.3.2.3 Timer Count Register (TCNT)

Module Base + 0x0004



Figure 11-6. Timer Count Register High (TCNTH)

### Chapter 13 Scalable Controller Area Network (S12MSCANV3)

| Module Base + | + 0x00XF |           |              |             |             |            | Access: Use | r read/write <sup>(1)</sup> |
|---------------|----------|-----------|--------------|-------------|-------------|------------|-------------|-----------------------------|
| _             | 7        | 6         | 5            | 4           | 3           | 2          | 1           | 0                           |
| R             | TSR7     | TSR6      | TSR5         | TSR4        | TSR3        | TSR2       | TSR1        | TSR0                        |
| w             |          |           |              |             |             |            |             |                             |
| Reset:        | х        | х         | х            | Х           | х           | х          | Х           | х                           |
|               |          | Figure 13 | -38. Time St | amp Registe | er — Low By | rte (TSRL) |             |                             |

 Read: or transmit buffers: Anytime when TXEx flag is set (see Section 13.3.2.7, "MSCAN Transmitter Flag Register (CANTFLG)") and the corresponding transmit buffer is selected in CANTBSEL (see Section 13.3.2.11, "MSCAN Transmit Buffer Selection Register (CANTBSEL)"). For receive buffers: Anytime when RXF is set. Write: Unimplemented

### Chapter 17 Serial Peripheral Interface (S12SPIV5)

| SPPR2 | SPPR1 | SPPR0 | SPR2 | SPR1 | SPR0 | Baud Rate<br>Divisor | Baud Rate     |
|-------|-------|-------|------|------|------|----------------------|---------------|
| 1     | 1     | 0     | 1    | 0    | 1    | 448                  | 55.80 kbit/s  |
| 1     | 1     | 0     | 1    | 1    | 0    | 896                  | 27.90 kbit/s  |
| 1     | 1     | 0     | 1    | 1    | 1    | 1792                 | 13.95 kbit/s  |
| 1     | 1     | 1     | 0    | 0    | 0    | 16                   | 1.5625 Mbit/s |
| 1     | 1     | 1     | 0    | 0    | 1    | 32                   | 781.25 kbit/s |
| 1     | 1     | 1     | 0    | 1    | 0    | 64                   | 390.63 kbit/s |
| 1     | 1     | 1     | 0    | 1    | 1    | 128                  | 195.31 kbit/s |
| 1     | 1     | 1     | 1    | 0    | 0    | 256                  | 97.66 kbit/s  |
| 1     | 1     | 1     | 1    | 0    | 1    | 512                  | 48.83 kbit/s  |
| 1     | 1     | 1     | 1    | 1    | 0    | 1024                 | 24.41 kbit/s  |
| 1     | 1     | 1     | 1    | 1    | 1    | 2048                 | 12.21 kbit/s  |

## Table 17-7. Example SPI Baud Rate Selection (25 MHz Bus Clock) (Sheet 3 of 3)

# 17.3.2.4 SPI Status Register (SPISR)

Module Base +0x0003



## Figure 17-6. SPI Status Register (SPISR)

Read: Anytime

Write: Has no effect

## Table 17-8. SPISR Field Descriptions

| Field      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>SPIF  | <ul> <li>SPIF Interrupt Flag — This bit is set after received data has been transferred into the SPI data register. For information about clearing SPIF Flag, please refer to Table 17-9.</li> <li>0 Transfer not yet complete.</li> <li>1 New data copied to SPIDR.</li> </ul>                                                                                                                                                                                                                                    |
| 5<br>SPTEF | <ul> <li>SPI Transmit Empty Interrupt Flag — If set, this bit indicates that the transmit data register is empty. For information about clearing this bit and placing data into the transmit data register, please refer to Table 17-10.</li> <li>O SPI data register not empty.</li> <li>1 SPI data register empty.</li> </ul>                                                                                                                                                                                    |
| 4<br>MODF  | <ul> <li>Mode Fault Flag — This bit is set if the SS input becomes low while the SPI is configured as a master and mode fault detection is enabled, MODFEN bit of SPICR2 register is set. Refer to MODFEN bit description in Section 17.3.2.2, "SPI Control Register 2 (SPICR2)". The flag is cleared automatically by a read of the SPI status register (with MODF set) followed by a write to the SPI control register 1.</li> <li>0 Mode fault has not occurred.</li> <li>1 Mode fault has occurred.</li> </ul> |

### Chapter 17 Serial Peripheral Interface (S12SPIV5)



 $t_{T}$  = Minimum trailing time after the last SCK edge

 $t_1$  = Minimum idling time between transfers (minimum  $\overline{SS}$  high time), not required for back-to-back transfers

Figure 17-15. SPI Clock Format 1 (CPHA = 1), with 16-Bit Transfer Width selected (XFRW = 1)

The  $\overline{SS}$  line can remain active low between successive transfers (can be tied low at all times). This format is sometimes preferred in systems having a single fixed master and a single slave that drive the MISO data line.

• Back-to-back transfers in master mode

In master mode, if a transmission has completed and new data is available in the SPI data register, this data is sent out immediately without a trailing and minimum idle time.

The SPI interrupt request flag (SPIF) is common to both the master and slave modes. SPIF gets set one half SCK cycle after the last SCK edge.

# 17.4.4 SPI Baud Rate Generation

Baud rate generation consists of a series of divider stages. Six bits in the SPI baud rate register (SPPR2, SPPR1, SPPR0, SPR2, SPR1, and SPR0) determine the divisor to the SPI module clock which results in the SPI baud rate.

The SPI clock rate is determined by the product of the value in the baud rate preselection bits (SPPR2–SPPR0) and the value in the baud rate selection bits (SPR2–SPR0). The module clock divisor equation is shown in Equation 17-3.



Figure 20-1. FTMRZ Block Diagram (Single P-Flash Block plus EEPROM block)

### Table 22-4. PWMCLK Field Descriptions

Note: Bits related to available channels have functional significance. Writing to unavailable bits has no effect. Read from unavailable bits return a zero

| Field            | Description                                                                                                                                                                                                                                                                |  |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 7-0<br>PCLK[7:0] | <ul> <li>Pulse Width Channel 7-0 Clock Select</li> <li>0 Clock A or B is the clock source for PWM channel 7-0, as shown in Table 22-5 and Table 22-6.</li> <li>1 Clock SA or SB is the clock source for PWM channel 7-0, as shown in Table 22-5 and Table 22-6.</li> </ul> |  |

The clock source of each PWM channel is determined by PCLKx bits in PWMCLK and PCLKABx bits in PWMCLKAB (see Section 22.3.2.7, "PWM Clock A/B Select Register (PWMCLKAB)). For Channel 0, 1, 4, 5, the selection is shown in Table 22-5; For Channel 2, 3, 6, 7, the selection is shown in Table 22-6.

Table 22-5. PWM Channel 0, 1, 4, 5 Clock Source Selection

| PCLKAB[0,1,4,5] | PCLK[0,1,4,5] | Clock Source Selection |
|-----------------|---------------|------------------------|
| 0               | 0             | Clock A                |
| 0               | 1             | Clock SA               |
| 1               | 0             | Clock B                |
| 1               | 1             | Clock SB               |

Table 22-6. PWM Channel 2, 3, 6, 7 Clock Source Selection

| PCLKAB[2,3,6,7] | PCLK[2,3,6,7] | Clock Source Selection |
|-----------------|---------------|------------------------|
| 0               | 0             | Clock B                |
| 0               | 1             | Clock SB               |
| 1               | 0             | Clock A                |
| 1               | 1             | Clock SA               |

#### 22.3.2.4 **PWM Prescale Clock Select Register (PWMPRCLK)**

This register selects the prescale clock source for clocks A and B independently.

Module Base + 0x0003



Figure 22-6. PWM Prescale Clock Select Register (PWMPRCLK)

Read: Anytime

Write: Anytime

## NOTE

PCKB2-0 and PCKA2-0 register bits can be written anytime. If the clock pre-scale is changed while a PWM signal is being generated, a truncated or stretched pulse can occur during the transition.

#### Appendix D LIN/HV PHY Electrical Specifications

4. At temperatures above 25°C the current may be naturally limited by the driver, in this case the limitation circuit is not engaged and the flag is not set.

# **D.2** Dynamic Electrical Characteristics

### Table D-2. Dynamic electrical characteristics of the LIN/HV PHY

Characteristics noted under conditions  $5.5V \le V_{LINSUP} \le 18 V$  unless otherwise noted<sup>(1) (2) (3)</sup>. Typical values noted reflect the approximate parameter mean at  $T_A = 25^{\circ}C$  under nominal conditions unless otherwise noted. Num С Ratings Symbol Min Тур Max Unit 1 Minimum duration of wake-up pulse generating a 56 72 120 t<sub>WUFR</sub> μS wake-up interrupt TxD-dominant timeout (in IRC clock periods) <sup>(4)</sup> 2 16388 16389 **t**<sub>DTLIM</sub> t<sub>IRC</sub> 3 Propagation delay of receiver 6 t<sub>rx\_pd</sub> μS 4 Symmetry of receiver propagation delay rising edge -2 2 μS t<sub>rx\_sym</sub> w.r.t. falling edge LIN PHYSICAL LAYER: DRIVER CHARACTERISTICS FOR NOMINAL SLEW RATE - 20.0KBIT/S 5 Rising/falling edge time (min to max / max to min) 6.5 t<sub>rise</sub> μS 6 Over-current masking window (IRC trimmed at 1MHz) 15 16 t<sub>OCLIM</sub> μS \_\_\_\_ 7 Μ Duty cycle 1 D1 0.396 (5) T<sub>HRec(max)</sub> = 0.744 x V<sub>LINSUP</sub>  $T_{HDom(max)} = 0.581 \times V_{LINSUP}$ V<sub>LINSUP</sub> = 5.5V...18V t<sub>Bit</sub> = 50us  $D1 = t_{Bus_{rec}(min)} / (2 \times t_{Bit})$ 8 Μ Duty cycle 2 D2 0.5815  $\begin{array}{l} T_{HRec(min)} = 0.422 \text{ x } V_{LINSUP} \\ T_{HDom(min)} = 0.284 \text{ x } V_{LINSUP} \\ V_{LINSUP} = 5.5V...18V \end{array}$ t<sub>Bit</sub> = 50us  $D2 = t_{Bus rec(max)} / (2 \times t_{Bit})$ LIN PHYSICAL LAYER: DRIVER CHARACTERISTICS FOR SLOW SLEW RATE - 10.4KBIT/S 9 Rising/falling edge time (min to max / max to min) 13 t<sub>rise</sub> μS 10 Over-current masking window (IRC trimmed at 1MHz) t<sub>OCLIM</sub> 31 32 μS 0.417<sup>5</sup> 11 Duty cycle 3 D3 Μ T<sub>HRec(max)</sub> = 0.778 x V<sub>LINSUP</sub>  $T_{HDom(max)} = 0.616 \times V_{LINSUP}$  $V_{LINSUP} = 5.5V...18V$ t<sub>Bit</sub> = 96us  $D3 = t_{Bus_{rec}(min)} / (2 \times t_{Bit})$