# E·XFL



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

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

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

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

#### Details

| Product Status             | Obsolete                                                                |
|----------------------------|-------------------------------------------------------------------------|
| Core Processor             | S12Z                                                                    |
| Core Size                  | 16-Bit                                                                  |
| Speed                      | 50MHz                                                                   |
| Connectivity               | 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 ~ 105°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/s912zvml12f2vkh |

Email: info@E-XFL.COM

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

# 1.6 Device Memory Map

Table 1-5 shows the device register memory map. All modules that can be instantiated more than once on S12 devices are listed with an index number, even if they are only instantiated once on this device family.

| Address                      | Module                         | Size<br>(Bytes) |
|------------------------------|--------------------------------|-----------------|
| 0x0000–0x0003                | Part ID Register Section 1.6.2 | 4               |
| 0x0004-0x000F                | Reserved                       | 12              |
| 0x0010-0x001F                | INT                            | 16              |
| 0x0020-0x006F                | Reserved                       | 80              |
| 0x0070–0x008F                | MMC                            | 32              |
| 0x0090-0x00FF                | MMC Reserved                   | 112             |
| 0x0100–0x017F                | DBG                            | 128             |
| 0x0180–0x01FF                | Reserved                       | 128             |
| 0x0200-0x033F                | PIM                            | 320             |
| 0x0340-0x037F                | Reserved                       | 64              |
| 0x0380-0x039F                | FTMRZ                          | 32              |
| 0x03A0-0x03BF                | Reserved                       | 32              |
| 0x03C0-0x03CF                | RAM ECC                        | 16              |
| 0x03D0-0x03FF                | Reserved                       | 48              |
| 0x0400–0x043F                | TIM1 (ZVMC256 only)            | 64              |
| 0x0440–0x047F                | Reserved                       | 64              |
| 0x0480-0x04AF                | PWM0 (ZVMC256 only)            | 48              |
| 0x04B0-0x04FF                | Reserved <sup>(1)</sup>        | 80              |
| 0x0500–0x053F                | PMF                            | 64              |
| 0x0540–0x057F                | Reserved                       | 64              |
| 0x0580–0x059F                | PTU                            | 32              |
| 0x05A0-0x05BF                | Reserved                       | 32              |
| 0x05C0-0x05EF                | TIMO                           | 48              |
| 0x05F0-0x05FF                | Reserved                       | 16              |
| 0x0600–0x063F                | ADC0                           | 64              |
| 0x0640-0x067F                | ADC1                           | 64              |
| 0x0680-0x069F                | Reserved                       | 32              |
| <sup>(2)</sup> 0x06A0-0x06BF | GDU                            | 32              |
| 0x06C0-0x06DF                | CPMU                           | 32              |

Table 1-5. Module Register Address Ranges

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



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

# Chapter 2 Port Integration Module (S12ZVMPIMV3)

| Rev. No.<br>(Item No.) | Date        | Sections<br>Affected                                                        | Substantial Change(s)                               |
|------------------------|-------------|-----------------------------------------------------------------------------|-----------------------------------------------------|
| V03.08                 | 9 Jan 2015  | Table 2-5<br>Table 2-6<br>Table 2-7<br>2.3.1/116<br>Table 2-9<br>Table 2-11 | Corrections                                         |
| V03.09                 | 22 Jan 2015 |                                                                             | Minor changes in wording                            |
| V03.10                 | 23 Jan 2015 | Figure 2-5<br>Table 2-13                                                    | Corrected T0IC3RR1-0 description                    |
| V03.11                 | 27 Jan 2015 | 2.3.1/116<br>2.3.2.3/128                                                    | Changed T0C2RR1-0 specification                     |
| V03.12                 | 10 Feb 2015 | 2.1.1/104<br>Table 2-5<br>Table 2-6                                         | Added TIM1     Changed PWM0 routing                 |
| V03.13                 | 16 Feb 2015 | 2.1.1/104                                                                   | Fixed typos and formatting                          |
| V03.14                 | 19 Feb 2015 | 2.1.1/104<br>2.1.2/107<br>2.2/108<br>Table 2-39<br>Table 2-41               | Fixed typos and formatting                          |
| V03.15                 | 16 Mar 2015 | 2.1.1/104<br>2.2/108                                                        | Format updates                                      |
| V03.16                 | 22 Apr 2015 | 2.1.1/104                                                                   | Fixed typos and formatting                          |
| V03.17                 | 12 Oct 2015 | 2.3.4/140                                                                   | Fixed typos and formatting                          |
| V03.18                 | 12 Dec 2015 | 2.3.2.3/128                                                                 | Added bit description for T1IC0RR (MODRR2 register) |

### Table 2-1. Revision History

#### Chapter 2 Port Integration Module (S12ZVMPIMV3)

| Global<br>Address | Register<br>Name    |          | Bit 7 | 6 | 5 4                |                    | 3     | 2                  | 1     | Bit 0             |      |      |
|-------------------|---------------------|----------|-------|---|--------------------|--------------------|-------|--------------------|-------|-------------------|------|------|
| 0x02D6            | PIES                | R<br>W   | 0     | 0 | PIES5 <sup>5</sup> | PIES4 <sup>5</sup> | PIES3 | PIES2              | PIES1 | PIES0             |      |      |
| 0x02D7            | PIFS                |          | 0     | 0 | PIFS5 <sup>5</sup> | PIFS4 <sup>5</sup> | PIFS3 | PIFS2              | PIFS1 | PIFS0             |      |      |
| 0x02D8–<br>0x02DE | Reserved            | R<br>W   | 0     | 0 | 0                  | 0                  | 0     | 0                  | 0     | 0                 |      |      |
| 0x02DF            | WOMS                | R<br>W   | 0     | 0 | WOMS5 <sup>5</sup> | WOMS4 <sup>5</sup> | WOMS3 | WOMS2              | WOMS1 | WOMS0             |      |      |
| 0x02E0–<br>0x02EF | Reserved            | R<br>W   | 0     | 0 | 0                  | 0                  | 0     | 0                  | 0     | 0                 |      |      |
| 0x02F0            | 0 PTP               |          | ) PTP |   | 0                  | 0                  | 0     | 0                  | 0     | PTP2 <sup>5</sup> | PTP1 | PTP0 |
| 0x02F1            | PTIP                | R<br>W   | 0     | 0 | 0                  | 0                  | 0     | PTIP2 <sup>5</sup> | PTIP1 | PTIP0             |      |      |
| 0x02F2            | DDRP                | R 0<br>W |       | 0 | 0                  | 0                  | 0     | DDRP2 <sup>5</sup> | DDRP1 | DDRP0             |      |      |
| 0x02F3            | PERP                | R<br>W   | 0     | 0 | 0                  | 0                  | 0     | PERP2 <sup>5</sup> | PERP1 | PERP0             |      |      |
| 0x02F4            | <sup>:</sup> 4 PPSP |          | 0     | 0 | 0                  | 0                  | 0     | PPSP2 <sup>5</sup> | PPSP1 | PPSP0             |      |      |
| 0x02F5            | Reserved            | R<br>W   | 0     | 0 | 0                  | 0                  | 0     | 0                  | 0     | 0                 |      |      |
| 0x02F6            | PIEP                | R<br>W   | OCIE1 | 0 | 0                  | 0                  | 0     | PIEP2 <sup>5</sup> | PIEP1 | PIEP0             |      |      |
| 0x02F7            | PIFP                | R<br>W   | OCIF1 | 0 | 0                  | 0                  | 0     | PIFP2 <sup>5</sup> | PIFP1 | PIFP0             |      |      |

External pulldown device (Figure 2-38):

- 1. Enable analog function on HVI in non-direct mode (PTAENL[PTAENL0]=1, PTAENL[PTADIRL0]=0)
- 2. Select internal pullup device on HVI (PTPSL[PTPSL0]=1)
- 3. Enable function to force input buffer active on HVI in analog mode (PTTEL[PTTEL0]=1)
- 4. Verify PTIL=0 for a connected external pulldown device; read PTIL=1 for an open input



Figure 2-38. Digital Input Read with Pullup Enabled

External pullup device (Figure 2-39):

- 1. Enable analog function on HVI in non-direct mode (PTAENL[PTAENL0]=1, PTADIRL[PTADIRL0]=0)
- 2. Select internal pulldown device on HVI (PTPSL[PTPSL0]=0)
- 3. Enable function to force input buffer active on HVI in analog mode (PTTEL[PTTEL0]=1)
- 4. Verify PTIL0=1 for a connected external pullup device; read PTIL0=0 for an open input

# 3.4.2 Illegal Accesses

The S12ZMMC module monitors all memory traffic for illegal accesses. See Table 3-9 for a complete list of all illegal accesses.

|                                                             |                | S12ZCPU                   | S12ZBDC         | ADCs and PTU    |  |  |
|-------------------------------------------------------------|----------------|---------------------------|-----------------|-----------------|--|--|
| Register                                                    | Read access    | ok                        | ok              | illegal access  |  |  |
| space                                                       | Write access   | ok                        | ok              | illegal access  |  |  |
|                                                             | Code execution | illegal access            |                 |                 |  |  |
| RAM                                                         | Read access    | ok                        | ok              | ok              |  |  |
|                                                             | Write access   | ok                        | ok              | ok              |  |  |
|                                                             | Code execution | ok                        |                 |                 |  |  |
| EEPROM                                                      | Read access    | ok <sup>(1)</sup>         | ok <sup>1</sup> | ok <sup>1</sup> |  |  |
|                                                             | Write access   | illegal access            | illegal access  | illegal access  |  |  |
|                                                             | Code execution | ok <sup>1</sup>           |                 | ·               |  |  |
| Reserved                                                    | Read access    | ok                        | ok              | illegal access  |  |  |
| Space -                                                     | Write access   | only permitted in SS mode | ok              | illegal access  |  |  |
|                                                             | Code execution | illegal access            |                 | ·               |  |  |
| (<br>Reserved<br>Read-only                                  | Read access    | ok                        | ok              | illegal access  |  |  |
| Read-only<br>Space                                          | Write access   | illegal access            | illegal access  | illegal access  |  |  |
|                                                             | Code execution | illegal access            |                 |                 |  |  |
| NVM IFR                                                     | Read access    | ok <sup>1</sup>           | ok <sup>1</sup> | illegal access  |  |  |
|                                                             | Write access   | illegal access            | illegal access  | illegal access  |  |  |
|                                                             | Code execution | illegal access            |                 |                 |  |  |
| Program NVM                                                 | Read access    | ok <sup>1</sup>           | ok <sup>1</sup> | ok <sup>1</sup> |  |  |
|                                                             | Write access   | illegal access            | illegal access  | illegal access  |  |  |
|                                                             | Code execution | ok <sup>1</sup>           |                 | ·               |  |  |
| Unmapped                                                    | Read access    | illegal access            | illegal access  | illegal access  |  |  |
| EEPROM EEPROM Reserved Space NVM IFR NVM IFR Unmapped Space | Write access   | illegal access            | illegal access  | illegal access  |  |  |
|                                                             | Code execution | illegal access            |                 |                 |  |  |

| Table 3-9. Illega | I memory | accesses |
|-------------------|----------|----------|
|-------------------|----------|----------|

1. Unsupported NVM accesses during NVM command execution ("collisions"), are treated as illegal accesses.

Illegal accesses are reported in several ways:

- All illegal accesses performed by the S12ZCPU trigger machine exceptions.
- All illegal accesses performed through the S12ZBDC interface, are captured in the ILLACC bit of the BDCCSRL register.

| Field         | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|---------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6<br>TSOURCE  | Trace Control Bits — The TSOURCE enables the tracing session.0 No CPU tracing/profiling selected1 CPU tracing/profiling selected                                                                                                                                                                                                                                                                                                                            |
| 5–4<br>TRANGE | <b>Trace Range Bits</b> — The TRANGE bits allow filtering of trace information from a selected address range when tracing from the CPU in Detail mode. These bits have no effect in other tracing modes. To use a comparator for range filtering, the corresponding COMPE bit must remain cleared. If the COMPE bit is set then the comparator is used to generate events and the TRANGE bits have no effect. See Table 6-10 for range boundary definition. |
| 3–2<br>TRCMOD | <b>Trace Mode Bits</b> — See Section 6.4.5.2 for detailed Trace Mode descriptions. In Normal Mode, change of flow information is stored. In Loop1 Mode, change of flow information is stored but redundant entries into trace memory are inhibited. In Detail Mode, address and data for all memory and register accesses is stored. See Table 6-11.                                                                                                        |
| 1–0<br>TALIGN | <b>Trigger Align Bits</b> — These bits control whether the trigger is aligned to the beginning, end or the middle of a tracing or profiling session. See Table 6-12.                                                                                                                                                                                                                                                                                        |

#### Table 6-10. TRANGE Trace Range Encoding

| TRANGE | Tracing Range                                             |  |  |  |  |  |  |
|--------|-----------------------------------------------------------|--|--|--|--|--|--|
| 00     | Trace from all addresses (No filter)                      |  |  |  |  |  |  |
| 01     | Trace only in address range from \$00000 to Comparator D  |  |  |  |  |  |  |
| 10     | Trace only in address range from Comparator C to \$FFFFFF |  |  |  |  |  |  |
| 11     | Trace only in range from Comparator C to Comparator D     |  |  |  |  |  |  |

#### Table 6-11. TRCMOD Trace Mode Bit Encoding

| TRCMOD | Description |
|--------|-------------|
| 00     | Normal      |
| 01     | Loop1       |
| 10     | Detail      |
| 11     | Pure PC     |

### Table 6-12. TALIGN Trace Alignment Encoding

| TALIGN            | Description                           |
|-------------------|---------------------------------------|
| 00                | Trigger ends data trace               |
| 01                | Trigger starts data trace             |
| 10                | 32 lines of data trace follow trigger |
| 11 <sup>(1)</sup> | Reserved                              |

1. Tracing/Profiling disabled.

### 6.3.2.14 Debug Comparator A Data Register (DBGAD)

|        | 31     | 30     | 29     | 28     | 27     | 26     | 25     | 24     | 23     | 22     | 21     | 20     | 19     | 18     | 17     | 16     |
|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|--------|
| R<br>W | Bit 31 | Bit 30 | Bit 29 | Bit 28 | Bit 27 | Bit 26 | Bit 25 | Bit 24 | Bit 23 | Bit 22 | Bit 21 | Bit 20 | Bit 19 | Bit 18 | Bit 17 | Bit 16 |
| Reset  | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |
|        | 15     | 14     | 13     | 12     | 11     | 10     | 9      | 8      | 7      | 6      | 5      | 4      | 3      | 2      | 1      | 0      |
| R<br>W | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9  | Bit 8  | Bit 7  | Bit 6  | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1  | Bit 0  |
| Reset  | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |

Address: 0x0118, 0x0119, 0x011A, 0x011B

Figure 6-16. Debug Comparator A Data Register (DBGAD)

Read: Anytime.

Write: If DBG not armed and PTACT is clear.

This register can be accessed with a byte resolution, whereby DBGAD0, DBGAD1, DBGAD2, DBGAD3 map to DBGAD[31:0] respectively.

#### Table 6-29. DBGAD Field Descriptions

| Field                                       | Description                                                                                                                                                                                                                                                                                                                                                      |
|---------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 31–16<br>Bits[31:16]<br>(DBGAD0,<br>DBGAD1) | <ul> <li>Comparator Data Bits — These bits control whether the comparator compares the data bus bits to a logic one or logic zero. The comparator data bits are only used in comparison if the corresponding data mask bit is logic 1.</li> <li>Compare corresponding data bit to a logic zero</li> <li>Compare corresponding data bit to a logic one</li> </ul> |
| 15–0<br>Bits[15:0]<br>(DBGAD2,<br>DBGAD3)   | <ul> <li>Comparator Data Bits — These bits control whether the comparator compares the data bus bits to a logic one or logic zero. The comparator data bits are only used in comparison if the corresponding data mask bit is logic 1.</li> <li>Compare corresponding data bit to a logic zero</li> <li>Compare corresponding data bit to a logic one</li> </ul> |

# 6.3.2.15 Debug Comparator A Data Mask Register (DBGADM)



Address: 0x011C, 0x011D, 0x011E, 0x011F

Read: Anytime.

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

Table 6-35. Read or Write Comparison Logic Table

| RWE Bit | RW Bit | RW Signal | Comment    |
|---------|--------|-----------|------------|
| 1       | 1      | 1         | Read match |

### 6.3.2.19 Debug Comparator C Address Register (DBGCAH, DBGCAM, DBGCAL)



Figure 0-21. Debug Comparator C Address Re

Read: Anytime.

Write: If DBG not armed and PTACT is clear.

#### Table 6-36. DBGCAH, DBGCAM, DBGCAL Field Descriptions

| Field                     | Description                                                                                                                                                                                                                                                                                                 |
|---------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 23–16<br>DBGCA<br>[23:16] | <ul> <li>Comparator Address Bits [23:16]— These comparator address bits control whether the comparator compares the address bus bits [23:16] to a logic one or logic zero.</li> <li>Compare corresponding address bit to a logic zero</li> <li>Compare corresponding address bit to a logic one</li> </ul>  |
| 15–0<br>DBGCA<br>[15:0]   | <ul> <li>Comparator Address Bits[15:0]— These comparator address bits control whether the comparator compares the address bus bits [15:0] to a logic one or logic zero.</li> <li>0 Compare corresponding address bit to a logic zero</li> <li>1 Compare corresponding address bit to a logic one</li> </ul> |

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

### 8.3.2.25 S12CPMU\_UHV\_V10\_V6 Protection Register (CPMUPROT)

This register protects the clock configuration registers from accidental overwrite:

# CPMUSYNR, CPMUREFDIV, CPMUCLKS, CPMUPLL, CPMUIRCTRIMH/L, CPMUOSC and CPMUOSC2

Module Base + 0x001B



Figure 8-36. S12CPMU\_UHV\_V10\_V6 Protection Register (CPMUPROT)

### Read: Anytime

Write: Anytime

| Field | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PROT  | <ul> <li>Clock Configuration Registers Protection Bit — This bit protects the clock configuration registers from accidental overwrite (see list of protected registers above): Writing 0x26 to the CPMUPROT register clears the PROT bit, other write accesses set the PROT bit.</li> <li>Protection of clock configuration registers is disabled.</li> <li>Protection of clock configuration registers is enabled. (see list of protected registers above).</li> </ul> |

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

### 8.3.2.27 Voltage Regulator Control Register (CPMUVREGCTL)

The CPMUVREGCTL allows to enable or disable certain parts of the voltage regulator. This register must be configured after system startup.

Module Base + 0x001D





1. Only available in V10

Read: Anytime

Write: VRH2EN, VRH1EN, EXTS2ON, EXTS1ON anytime Write: EXTCON, EXTXON, INTXON once in normal modes, anytime in special modes Table 8-30. Effects of writing the EXTXON and INTXON bits

| value of<br>EXTXON<br>to be written | value of<br>INTXON<br>to be written | Write Access       |
|-------------------------------------|-------------------------------------|--------------------|
| 0                                   | 0                                   | blocked, no effect |
| 0                                   | 1                                   | legal access       |
| 1                                   | 0                                   | legal access       |
| 1                                   | 1                                   | blocked, no effect |

#### Table 8-31. CPMUVREGCTL Field Descriptions

| Field        | Description                                                                                                                                                                                                                                                                |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>VRH2EN  | <ul> <li>VRH2 Enable Bit — This bits switches VDDS2 pin to VRH2 of ADC.</li> <li>0 VRH2 of ADC disconnected (open)</li> <li>1 VRH2 of ADC connected to VDDS2.</li> <li>In RPM VRH2 is always disconnected from VDDS2 regardless of the value of the VRH2EN bit.</li> </ul> |
| 6<br>VRH1EN  | <ul> <li>VRH1 Enable Bit — This bits switches VDDS1 pin to VRH1 of ADC.</li> <li>0 VRH1 of ADC disconnected (open)</li> <li>1 VRH1 of ADC connected to VDDS1.</li> <li>In RPM VRH1 is always disconnected from VDDS1 regardless of the value of the VRH1EN bit.</li> </ul> |
| 5<br>EXTS2ON | <ul> <li>External voltage regulator Enable Bit for VDDS2 domain — Should be enabled after system startup if VDDS2 is used.</li> <li>0 VDDS2 domain disabled</li> <li>1 VDDS2 domain enabled. BCTLS2 pin is active.</li> </ul>                                              |

# 11.3.2.13 Output Compare Pin Disconnect Register(OCPD)

Module Base + 0x002C



#### Figure 11-20. Output Compare Pin Disconnect Register (OCPD)

### Read: Anytime

Write: Anytime

All bits reset to zero.

### Table 11-15. OCPD Field Description

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

| Field     | Description                                                                                                                                  |
|-----------|----------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0       | Output Compare Pin Disconnect Bits                                                                                                           |
| OCPD[3:0] | 0 Enables the timer channel port. Output Compare action will occur on the channel pin. These bits do not affect the input capture .          |
|           | 1 Disables the timer channel port. Output Compare action will not occur on the channel pin, but the output<br>compare flag still become set. |

### 11.3.2.14 Precision Timer Prescaler Select Register (PTPSR)

Module Base + 0x002E

|        | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|--------|-------|-------|-------|-------|-------|-------|-------|-------|
| R<br>W | PTPS7 | PTPS6 | PTPS5 | PTPS4 | PTPS3 | PTPS2 | PTPS1 | PTPS0 |
| Reset  | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |



Read: Anytime

Write: Anytime

All bits reset to zero.

### NOTE

The IPOL*x* bits take effect at the beginning of the next PWM cycle, regardless of the state of the LDOK bit or global load OK. Select top/bottom software correction by writing 01 to the current select bits, ISENS[1:0], in the PWM control register. Reading the IPOL*x* bits read the buffered value and not necessarily the value currently in effect.

### 15.3.2.14 PMF Value 0-5 Register (PMFVAL0-PMFVAL5)



#### Table 15-22. PMFVALn Field Descriptions

| Field                   | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15–0<br>PMFVAL <i>n</i> | <ul> <li>PMF Value n Bits — The 16-bit signed value in this buffered register is the pulse width in PWM clock periods. A value less than or equal to zero deactivates the PWM output for the entire PWM period. A value greater than, or equal to the modulus, activates the PWM output for the entire PWM period. See Table 15-40. The terms activate and deactivate refer to the high and low logic states of the PWM output.</li> <li>Note: PMFVAL<i>n</i> is buffered. The value written does not take effect until the related or global load OK bit is set and the next PWM load cycle begins. Reading PMFVAL<i>n</i> returns the value in the buffer and not necessarily the value the PWM generator is currently using.</li> <li><i>n</i> is 0, 1, 2, 3, 4 and 5.</li> </ul> |

# 15.3.2.15 PMF Reload Overrun Interrupt Enable Register (PMFROIE)



Chapter 15 Pulse Width Modulator with Fault Protection (PMF15B6CV4)



Figure 15-62. Asymmetric Waveform - Phase Shift PWM Output

### 15.4.8 Variable Edge Placement PWM Output

In complementary edge-aligned mode, the timing of both edges of the PWM output can be controlled using the PECx bits in the PMFICCTL register and the CINVn bits in the PMFCINV register.

The edge-aligned signal created by the even value register and the associated CINV*n* bit is ANDed with the signal created by the odd value register and its associated CINV*n* bit. The resulting signal can optionally be negated by PINV*x* and is then fed into the complement and deadtime logic (Figure 15-63). If the value of the inverted register exceeds the non-inverted register value, no output pulse is generated (0% or 100% duty cycle). See right half of Figure 15-64.

In contrast to asymmetric PWM output mode, the PWM phase shift can pass the PWM cycle boundary.



Figure 15-63. Logic AND Function with Signal Inversions

In Figure 16-22 the verification samples RT3 and RT5 determine that the first low detected was noise and not the beginning of a start bit. The RT clock is reset and the start bit search begins again. The noise flag is not set because the noise occurred before the start bit was found.



In Figure 16-23, verification sample at RT3 is high. The RT3 sample sets the noise flag. Although the perceived bit time is misaligned, the data samples RT8, RT9, and RT10 are within the bit time and data recovery is successful.



#### Chapter 20 Flash Module (S12ZFTMRZ)

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).

### 20.3.2.11 Flash Option Register (FOPT)

The FOPT register is the Flash option register.



1. Loaded from Flash configuration field, during reset sequence.

All bits in the FOPT register are readable but can only be written in special mode.

During the reset sequence, the FOPT register is loaded from the Flash nonvolatile byte in the Flash configuration field at global address 0xFF\_FE0E located in P-Flash memory (see Table 20-4) as indicated by reset condition F in Figure 20-16. If a double bit fault is detected while reading the P-Flash phrase containing the Flash nonvolatile byte during the reset sequence, all bits in the FOPT register will be set.

Table 20-26. FOPT Field Descriptions

| Field          | Description                                                                                                                               |
|----------------|-------------------------------------------------------------------------------------------------------------------------------------------|
| 7–0<br>NV[7:0] | <b>Nonvolatile Bits</b> — The NV[7:0] bits are available as nonvolatile bits. Refer to the device overview for proper use of the NV bits. |

# 20.3.2.12 Flash Reserved1 Register (FRSV1)

This Flash register is reserved for factory testing.



All bits in the FRSV1 register read 0 and are not writable.

#### Chapter 20 Flash Module (S12ZFTMRZ)



### Write: Anytime

#### Table 22-2. PWME 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<br>PWME7 | <ul> <li>Pulse Width Channel 7 Enable</li> <li>0 Pulse width channel 7 is disabled.</li> <li>1 Pulse width channel 7 is enabled. The pulse modulated signal becomes available at PWM output bit 7 when its clock source begins its next cycle.</li> </ul>                                                                          |
| 6<br>PWME6 | <ul> <li>Pulse Width Channel 6 Enable</li> <li>Pulse width channel 6 is disabled.</li> <li>Pulse width channel 6 is enabled. The pulse modulated signal becomes available at PWM output bit 6 when<br/>its clock source begins its next cycle. If CON67=1, then bit has no effect and PWM output line 6 is disabled.</li> </ul>    |
| 5<br>PWME5 | <ul> <li>Pulse Width Channel 5 Enable</li> <li>0 Pulse width channel 5 is disabled.</li> <li>1 Pulse width channel 5 is enabled. The pulse modulated signal becomes available at PWM output bit 5 when its clock source begins its next cycle.</li> </ul>                                                                          |
| 4<br>PWME4 | <ul> <li>Pulse Width Channel 4 Enable</li> <li>0 Pulse width channel 4 is disabled.</li> <li>1 Pulse width channel 4 is enabled. The pulse modulated signal becomes available at PWM, output bit 4 when its clock source begins its next cycle. If CON45 = 1, then bit has no effect and PWM output line 4 is disabled.</li> </ul> |
| 3<br>PWME3 | <ul> <li>Pulse Width Channel 3 Enable</li> <li>0 Pulse width channel 3 is disabled.</li> <li>1 Pulse width channel 3 is enabled. The pulse modulated signal becomes available at PWM, output bit 3 when its clock source begins its next cycle.</li> </ul>                                                                         |
| 2<br>PWME2 | <ul> <li>Pulse Width Channel 2 Enable</li> <li>0 Pulse width channel 2 is disabled.</li> <li>1 Pulse width channel 2 is enabled. The pulse modulated signal becomes available at PWM, output bit 2 when its clock source begins its next cycle. If CON23 = 1, then bit has no effect and PWM output line 2 is disabled.</li> </ul> |
| 1<br>PWME1 | <ul> <li>Pulse Width Channel 1 Enable</li> <li>Pulse width channel 1 is disabled.</li> <li>Pulse width channel 1 is enabled. The pulse modulated signal becomes available at PWM, output bit 1 when its clock source begins its next cycle.</li> </ul>                                                                             |
| 0<br>PWME0 | <ul> <li>Pulse Width Channel 0 Enable</li> <li>0 Pulse width channel 0 is disabled.</li> <li>1 Pulse width channel 0 is enabled. The pulse modulated signal becomes available at PWM, output bit 0 when its clock source begins its next cycle. If CON01 = 1, then bit has no effect and PWM output line 0 is disabled.</li> </ul> |

### 22.3.2.2 PWM Polarity Register (PWMPOL)

The starting polarity of each PWM channel waveform is determined by the associated PPOLx bit in the PWMPOL register. If the polarity bit is one, the PWM channel output is high at the beginning of the cycle and then goes low when the duty count is reached. Conversely, if the polarity bit is zero, the output starts low and then goes high when the duty count is reached.

# M.4 0x0100-0x017F S12ZDBG

| Address           | Name        | _      | Bit 7        | 6   | 5    | 4  | 3  | 2   | 1        | Bit 0  |
|-------------------|-------------|--------|--------------|-----|------|----|----|-----|----------|--------|
| 0x011C            | DBGADM0     | R<br>W | Bit 31       | 30  | 29   | 28 | 27 | 26  | 25       | Bit 24 |
| 0x011D            | DBGADM1     | R<br>W | Bit 23       | 22  | 21   | 20 | 19 | 18  | 17       | Bit 16 |
| 0x011E            | DBGADM2     | R<br>W | Bit 15       | 14  | 13   | 12 | 11 | 10  | 9        | Bit 8  |
| 0x011F            | DBGADM3     | R<br>W | Bit 7        | 6   | 5    | 4  | 3  | 2   | 1        | Bit 0  |
| 0x0120            | DBGBCTL     | R<br>W | 0            | 0   | INST | 0  | RW | RWE | reserved | COMPE  |
| 0x0121-<br>0x0124 | Reserved    | R<br>W | 0            | 0   | 0    | 0  | 0  | 0   | 0        | 0      |
| 0x0125            | DBGBAH      | R<br>W | DBGBA[23:16] |     |      |    |    |     |          |        |
| 0x0126            | DBGBAM      | R<br>W | DBGBA[15:8]  |     |      |    |    |     |          |        |
| 0x0127            | DBGBAL      | R<br>W | DBGBA[7:0]   |     |      |    |    |     |          |        |
| 0x0128-<br>0x012F | Reserved    | R<br>W | 0            | 0   | 0    | 0  | 0  | 0   | 0        | 0      |
| 0x0130            | DBGCCTL     | R<br>W | 0            | NDB | INST | 0  | RW | RWE | reserved | COMPE  |
| 0x0131-<br>0x0134 | Reserved    | R<br>W | 0            | 0   | 0    | 0  | 0  | 0   | 0        | 0      |
| 0x0135            | DBGCAH      | R<br>W | DBGCA[23:16] |     |      |    |    |     |          |        |
| 0x0136            | DBGCAM      | R<br>W | DBGCA[15:8]  |     |      |    |    |     |          |        |
| 0x0137            | DBGCAL      | R<br>W | DBGCA[7:0]   |     |      |    |    |     |          |        |
| 0x0138            | DBGCD0      | R<br>W | Bit 31       | 30  | 29   | 28 | 27 | 26  | 25       | Bit 24 |
| 0x0139            | DBGCD1      | R<br>W | Bit 23       | 22  | 21   | 20 | 19 | 18  | 17       | Bit 16 |
| 0x013A            | DBGCD2<br>2 | R<br>W | Bit 15       | 14  | 13   | 12 | 11 | 10  | 9        | Bit 8  |
| 0x013B            | DBGCD3      | R<br>W | Bit 7        | 6   | 5    | 4  | 3  | 2   | 1        | Bit 0  |