# E·XFL



#### Datalla

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

Email: info@E-XFL.COM

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

| 1.1 | Introduction                                              | 21   |
|-----|-----------------------------------------------------------|------|
| 1.2 | Features                                                  | 21   |
|     | 1.2.1 MC9S12ZVC-Family Comparison                         | 22   |
| 1.3 | Chip-Level Features                                       | 23   |
| 1.4 | Module Features                                           | 23   |
|     | 1.4.1 S12Z Central Processor Unit (CPU)                   | 24   |
|     | 1.4.2 Embedded Memory                                     | 25   |
|     | 1.4.3 Clocks, Reset and Power Management Unit (CPMU)      | 25   |
|     | 1.4.4 Main External Oscillator (XOSCLCP)                  | 26   |
|     | 1.4.5 Timer (TIM0 and TIM1)                               | 27   |
|     | 1.4.6 Pulse Width Modulation Module (PWM0 and PWM1)       | 27   |
|     | 1.4.7 Inter-IC Module (IIC)                               | 27   |
|     | 1.4.8 CAN Physical Layer (CANPHY)                         | 27   |
|     | 1.4.9 Multi-Scalable Controller Area Network (MSCAN)      | 27   |
|     | 1.4.10 SENT Transmitter (SENT TX)                         | 28   |
|     | 1.4.11 Serial Communication Interface Module (SCI)        | 28   |
|     | 1.4.12 Serial Peripheral Interface Module (SPI)           | 29   |
|     | 1.4.13 Analog-to-Digital Converter Module (ADC)           | 29   |
|     | 1.4.14 Digital-to-Analog Converter Module (DAC)           | 29   |
|     | 1.4.15 Analog Comparator Module (ACMP)                    | 29   |
|     | 1.4.16 Supply Voltage Sensor (BATS)                       | 30   |
|     | 1.4.17 On-Chip Voltage Regulator system (VREG)            | 30   |
| 1.5 | Block Diagram                                             | 31   |
| 1.6 | Family Memory Map                                         | 32   |
|     | 1.6.1 Part ID Assignments                                 | 35   |
| 1.7 | Signal Description and Device Pinouts                     | 35   |
|     | 1.7.1 Pin Assignment Overview                             | 36   |
|     | 1.7.2 Detailed Signal Descriptions                        | 36   |
|     | 1.7.3 MODC — Mode C signal                                | 36   |
|     | 1.7.4 PAD[15:0] / KWAD[15:0] — Port AD, input pins of ADC | 36   |
|     | 1.7.5 PE[1:0] — Port E I/O signals                        | 37   |
|     | 1.7.6 PJ[1:0] — Port J I/O signals                        | . 37 |
|     | 1.7.7 PL[1:0] / KWL[1:0] — Port L input signals           | 37   |
|     | 1.7.8 PP[7:0] / KWP[7:0] — Port P I/O signals             | 37   |
|     | 1.7.9 PS[7:0] / KWS[7:0] — Port S I/O signals             | 37   |
|     | 1.7.10 PT[7:0] — Port T I/O signals                       | 37   |
|     | 1.7.11 AN[15:0] — ADC input signals                       | 37   |
|     | 1.7.12 ACMP Signals                                       | 37   |
|     | 1.7.13 DAC Signals                                        | 38   |
|     | 1.7.14 VRH 0, VRH 1, VRL 0, VRL 1 — ADC reference signals | 38   |
|     | 1.7.15 ETRIGO — External ADC trigger signal               | 38   |
|     | 1.7.16 SPI signals                                        | 38   |
|     | 1.7.17 SCI signals                                        | 39   |
|     | -                                                         |      |

# Chapter 1 Device Overview MC9S12ZVC-Family

Chapter 1 Device Overview MC9S12ZVC-Family

# 1.11.3 Operation of the Secured Microcontroller

By securing the device, unauthorized access to the EEPROM and Flash memory contents is prevented. Secured operation has the following effects on the microcontroller:

## 1.11.3.1 Normal Single Chip Mode (NS)

- Background debug controller (BDC) operation is completely disabled.
- Execution of Flash and EEPROM commands is restricted (described in flash block description).

# 1.11.3.2 Special Single Chip Mode (SS)

- Background debug controller (BDC) commands are restricted
- Execution of Flash and EEPROM commands is restricted (described in flash block description).

In special single chip mode the device is in active BDM after reset. In special single chip mode on a secure device, only the BDC mass erase and BDC control and status register commands are possible. BDC access to memory mapped resources is disabled. The BDC can only be used to erase the EEPROM and Flash memory without giving access to their contents.

# 1.11.4 Unsecuring the Microcontroller

Unsecuring the microcontroller can be done using three different methods:

- 1. Backdoor key access
- 2. Reprogramming the security bits
- 3. Complete memory erase

# 1.11.4.1 Unsecuring the MCU Using the Backdoor Key Access

In normal single chip mode, security can be temporarily disabled using the backdoor key access method. This method requires that:

- The backdoor key has been programmed to a valid value
- The KEYEN[1:0] bits within the Flash options/security byte select 'enabled'.
- The application program programmed into the microcontroller has the capability to write to the backdoor key locations

The backdoor key values themselves would not normally be stored within the application data, which means the application program would have to be designed to receive the backdoor key values from an external source (e.g. through a serial port)

The backdoor key access method allows debugging of a secured microcontroller without having to erase the Flash This is particularly useful for failure analysis.

### NOTE

No backdoor key word is allowed to have the value 0x0000 or 0xFFFF.

Chapter 3 Background Debug Controller (S12ZBDCV2)

## 3.4.4.12 READ\_DBGTB

#### Read DBG trace buffer

Non-intrusive



This command is only available on devices, where the DBG module includes a trace buffer. Attempted use of this command on devices without a traace buffer return 0x00.

Read 64 bits from the DBG trace buffer. Refer to the DBG module description for more detailed information. If enabled an ACK pulse is generated before each 32-bit longword is ready to be read by the host. After issuing the first ACK a timeout is still possible whilst accessing the second 32-bit longword, since this requires separate internal accesses. The first 32-bit longword corresponds to trace buffer line bits[31:0]; the second to trace buffer line bits[63:32]. If ACK handshaking is disabled, the host must wait 16 clock cycles (DLY) after completing the first 32-bit read before starting the second 32-bit read.

# 3.4.4.13 READ\_SAME.sz, READ\_SAME.sz\_WS

#### READ\_SAME

Read same location specified by previous READ\_MEM{\_WS}

Non-intrusive

| 0x54                      |                  | Data[15-8]                | Data[7-0]                 |
|---------------------------|------------------|---------------------------|---------------------------|
| $host \rightarrow target$ | D<br>A<br>C<br>K | target $\rightarrow$ host | target $\rightarrow$ host |

#### READ\_SAME\_WS

Read same location specified by previous READ\_MEM{\_WS}

Non-intrusive

| 0x55                      |             | BDCCSRL                   | Data [15-8]               | Data [7-0]       |
|---------------------------|-------------|---------------------------|---------------------------|------------------|
| $host \rightarrow target$ | D<br>L<br>Y | $target \rightarrow host$ | target $\rightarrow$ host | target →<br>host |

Read from location defined by the previous READ\_MEM. The previous READ\_MEM command defines the address, subsequent READ\_SAME commands return contents of same address. The example shows the sequence for reading a 16-bit word size. Byte alignment details are described in Section 3.4.5.2, "BDC Access Of Device Memory Mapped Resources". If enabled, an ACK pulse is driven before the data bytes are transmitted.

### NOTE

When disarming the DBG by clearing ARM with software, the contents of bits[5:0] are not affected by the write, since up until the write operation, ARM = 1 preventing these bits from being written. These bits must be cleared using a second write if required.

### Table 6-3. DBGC1 Field Descriptions

| Field       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>ARM    | <ul> <li>Arm Bit — The ARM bit controls whether the DBG module is armed. This bit can be set and cleared by register writes and is automatically cleared when the state sequencer returns to State0 on completing a debugging session. On setting this bit the state sequencer enters State1.</li> <li>0 Debugger disarmed. No breakpoint is generated when clearing this bit by software register writes.</li> <li>1 Debugger armed</li> </ul> |
| 6<br>TRIG   | <ul> <li>Immediate Trigger Request Bit — This bit when written to 1 requests an immediate transition to final state independent of comparator status. This bit always reads back a 0. Writing a 0 to this bit has no effect.</li> <li>0 No effect.</li> <li>1 Force state sequencer immediately to final state.</li> </ul>                                                                                                                      |
| 4<br>BDMBP  | <ul> <li>Background Debug Mode Enable — This bit determines if a CPU breakpoint causes the system to enter Background Debug Mode (BDM) or initiate a Software Interrupt (SWI). If this bit is set but the BDC is not enabled, then no breakpoints are generated.</li> <li>0 Breakpoint to Software Interrupt if BDM inactive. Otherwise no breakpoint.</li> <li>1 Breakpoint to BDM, if BDC enabled. Otherwise no breakpoint.</li> </ul>        |
| 3<br>BRKCPU | <ul> <li>CPU Breakpoint Enable — The BRKCPU bit controls whether the debugger requests a breakpoint to CPU upon transitions to State0. Please refer to Section 6.4.5, "Breakpoints for further details.</li> <li>0 Breakpoints disabled</li> <li>1 Breakpoints enabled</li> </ul>                                                                                                                                                               |
| 1<br>EEVE1  | <ul> <li>External Event Enable — The EEVE1 bit enables the external event function.</li> <li>0 External event function disabled.</li> <li>1 External event is mapped to the state sequencer, replacing comparator channel 3</li> </ul>                                                                                                                                                                                                          |

# 6.3.2.2 Debug Control Register2 (DBGC2)

Address: 0x0101





Read: Anytime.

Write: Anytime the module is disarmed.

This register configures the comparators for range matching.

| NDB | DBGADM | Comment                                     |
|-----|--------|---------------------------------------------|
| 0   | 0      | Do not compare data bus bit.                |
| 0   | 1      | Compare data bus bit. Match on equivalence. |
| 1   | 0      | Do not compare data bus bit.                |
| 1   | 1      | Compare data bus bit. Match on difference.  |

#### Table 6-30. NDB and MASK bit dependency

### 6.4.2.4 Range Comparisons

Range comparisons are accurate to byte boundaries. Thus for data access comparisons a match occurs if at least one byte of the access is in the range (inside range) or outside the range (outside range). For opcode comparisons only the address of the first opcode byte is compared with the range.

When using the AB comparator pair for a range comparison, the data bus can be used for qualification by using the comparator A data and data mask registers. The DBGACTL RW and RWE bits can be used to qualify the range comparison on either a read or a write access. The corresponding DBGBCTL bits are ignored. The DBGACTL COMPE/INST bits are used for range comparisons. The DBGBCTL COMPE/INST bits are ignored in range modes.

### 6.4.2.4.1 Inside Range (CompA\_Addr ≤ address ≤ CompB\_Addr)

In the Inside Range comparator mode, comparator pair A and B can be configured for range comparisons by the control register (DBGC2). The match condition requires a simultaneous valid match for both comparators. A match condition on only one comparator is not valid.

### 6.4.2.4.2 Outside Range (address < CompA\_Addr or address > CompB\_Addr)

In the Outside Range comparator mode, comparator pair A and B can be configured for range comparisons. A single match condition on either of the comparators is recognized as valid. Outside range mode in combination with opcode address matches can be used to detect if opcodes are from an unexpected range.

### NOTE

When configured for data access matches, an outside range match would typically occur at any interrupt vector fetch or register access. This can be avoided by setting the upper or lower range limit to \$FFFFFF or \$000000 respectively. Interrupt vector fetches do not cause opcode address matches.

### 6.4.3 Events

Events are used as qualifiers for a state sequencer change of state. The state control register for the current state determines the next state for each event. An event can immediately initiate a transition to the next state sequencer state whereby the corresponding flag in DBGSR is set.

- Frequency trimming (A factory trim value for 1MHz is loaded from Flash Memory into the IRCTRIM register after reset, which can be overwritten by application if required)
- Temperature Coefficient (TC) trimming. (A factory trim value is loaded from Flash Memory into the IRCTRIM register to turn off TC trimming after reset. Application can trim the TC if required by overwriting the IRCTRIM register).

Other features of the S12CPMU\_UHV\_V7 include

- Oscillator clock monitor to detect loss of crystal
- Autonomous periodical interrupt (API)
- Bus Clock Generator
  - Clock switch to select either PLLCLK or external crystal/resonator as source of the Bus Clock
  - PLLCLK divider to adjust system speed
- System Reset generation from the following possible sources:
  - Power-on reset (POR)
  - Low-voltage reset (LVR)
  - COP system watchdog, COP reset on time-out, windowed COP
  - Loss of oscillation (Oscillator clock monitor fail)
  - Loss of PLL clock (PLL clock monitor fail)
  - External pin RESET

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

|            |                  |                           |                           | RTR[                      | 6:4] =                    |                           |                           |                           |
|------------|------------------|---------------------------|---------------------------|---------------------------|---------------------------|---------------------------|---------------------------|---------------------------|
| RTR[3:0]   | 000<br>(OFF)     | 001<br>(2 <sup>10</sup> ) | 010<br>(2 <sup>11</sup> ) | 011<br>(2 <sup>12</sup> ) | 100<br>(2 <sup>13</sup> ) | 101<br>(2 <sup>14</sup> ) | 110<br>(2 <sup>15</sup> ) | 111<br>(2 <sup>16</sup> ) |
| 0000 (÷1)  | OFF <sup>1</sup> | 2 <sup>10</sup>           | 2 <sup>11</sup>           | 2 <sup>12</sup>           | 2 <sup>13</sup>           | 2 <sup>14</sup>           | 2 <sup>15</sup>           | 2 <sup>16</sup>           |
| 0001 (÷2)  | OFF              | 2x2 <sup>10</sup>         | 2x2 <sup>11</sup>         | 2x2 <sup>12</sup>         | 2x2 <sup>13</sup>         | 2x2 <sup>14</sup>         | 2x2 <sup>15</sup>         | 2x2 <sup>16</sup>         |
| 0010 (÷3)  | OFF              | 3x2 <sup>10</sup>         | 3x2 <sup>11</sup>         | 3x2 <sup>12</sup>         | 3x2 <sup>13</sup>         | 3x2 <sup>14</sup>         | 3x2 <sup>15</sup>         | 3x2 <sup>16</sup>         |
| 0011 (÷4)  | OFF              | 4x2 <sup>10</sup>         | 4x2 <sup>11</sup>         | 4x2 <sup>12</sup>         | 4x2 <sup>13</sup>         | 4x2 <sup>14</sup>         | 4x2 <sup>15</sup>         | 4x2 <sup>16</sup>         |
| 0100 (÷5)  | OFF              | 5x2 <sup>10</sup>         | 5x2 <sup>11</sup>         | 5x2 <sup>12</sup>         | 5x2 <sup>13</sup>         | 5x2 <sup>14</sup>         | 5x2 <sup>15</sup>         | 5x2 <sup>16</sup>         |
| 0101 (÷6)  | OFF              | 6x2 <sup>10</sup>         | 6x2 <sup>11</sup>         | 6x2 <sup>12</sup>         | 6x2 <sup>13</sup>         | 6x2 <sup>14</sup>         | 6x2 <sup>15</sup>         | 6x2 <sup>16</sup>         |
| 0110 (÷7)  | OFF              | 7x2 <sup>10</sup>         | 7x2 <sup>11</sup>         | 7x2 <sup>12</sup>         | 7x2 <sup>13</sup>         | 7x2 <sup>14</sup>         | 7x2 <sup>15</sup>         | 7x2 <sup>16</sup>         |
| 0111 (÷8)  | OFF              | 8x2 <sup>10</sup>         | 8x2 <sup>11</sup>         | 8x2 <sup>12</sup>         | 8x2 <sup>13</sup>         | 8x2 <sup>14</sup>         | 8x2 <sup>15</sup>         | 8x2 <sup>16</sup>         |
| 1000 (÷9)  | OFF              | 9x2 <sup>10</sup>         | 9x2 <sup>11</sup>         | 9x2 <sup>12</sup>         | 9x2 <sup>13</sup>         | 9x2 <sup>14</sup>         | 9x2 <sup>15</sup>         | 9x2 <sup>16</sup>         |
| 1001 (÷10) | OFF              | 10x2 <sup>10</sup>        | 10x2 <sup>11</sup>        | 10x2 <sup>12</sup>        | 10x2 <sup>13</sup>        | 10x2 <sup>14</sup>        | 10x2 <sup>15</sup>        | 10x2 <sup>16</sup>        |
| 1010 (÷11) | OFF              | 11x2 <sup>10</sup>        | 11x2 <sup>11</sup>        | 11x2 <sup>12</sup>        | 11x2 <sup>13</sup>        | 11x2 <sup>14</sup>        | 11x2 <sup>15</sup>        | 11x2 <sup>16</sup>        |
| 1011 (÷12) | OFF              | 12x2 <sup>10</sup>        | 12x2 <sup>11</sup>        | 12x2 <sup>12</sup>        | 12x2 <sup>13</sup>        | 12x2 <sup>14</sup>        | 12x2 <sup>15</sup>        | 12x2 <sup>16</sup>        |
| 1100 (÷13) | OFF              | 13x2 <sup>10</sup>        | 13x2 <sup>11</sup>        | 13x2 <sup>12</sup>        | 13x2 <sup>13</sup>        | 13x2 <sup>14</sup>        | 13x2 <sup>15</sup>        | 13x2 <sup>16</sup>        |
| 1101 (÷14) | OFF              | 14x2 <sup>10</sup>        | 14x2 <sup>11</sup>        | 14x2 <sup>12</sup>        | 14x2 <sup>13</sup>        | 14x2 <sup>14</sup>        | 14x2 <sup>15</sup>        | 14x2 <sup>16</sup>        |
| 1110 (÷15) | OFF              | 15x2 <sup>10</sup>        | 15x2 <sup>11</sup>        | 15x2 <sup>12</sup>        | 15x2 <sup>13</sup>        | 15x2 <sup>14</sup>        | 15x2 <sup>15</sup>        | 15x2 <sup>16</sup>        |
| 1111 (÷16) | OFF              | 16x2 <sup>10</sup>        | 16x2 <sup>11</sup>        | 16x2 <sup>12</sup>        | 16x2 <sup>13</sup>        | 16x2 <sup>14</sup>        | 16x2 <sup>15</sup>        | 16x2 <sup>16</sup>        |

<sup>1</sup> Denotes the default value out of reset. This value should be used to disable the RTI to ensure future backwards compatibility.





| Interrupt | Offset | Vector | Priority | Source                        | Description                                   |
|-----------|--------|--------|----------|-------------------------------|-----------------------------------------------|
| C[7:0]F   | —      | _      | —        | Timer Channel 7–0             | Active high timer channel interrupts 7–0      |
| PAOVI     | —      | _      | —        | Pulse Accumulator Input       | Active high pulse accumulator input interrupt |
| PAOVF     | _      | _      | —        | Pulse Accumulator<br>Overflow | Pulse accumulator overflow interrupt          |
| TOF       | _      | —      | —        | Timer Overflow                | Timer Overflow interrupt                      |

 Table 11-25. TIM16B8CV3 Interrupts

The TIM16B8CV3 could use up to 11 interrupt vectors. The interrupt vector offsets and interrupt numbers are chip dependent.

# 11.6.1 Channel [7:0] Interrupt (C[7:0]F)

This active high outputs will be asserted by the module to request a timer channel 7-0 interrupt. The TIM block only generates the interrupt and does not service it. Only bits related to implemented channels are valid.

# 11.6.2 Pulse Accumulator Input Interrupt (PAOVI)

This active high output will be asserted by the module to request a timer pulse accumulator input interrupt. The TIM block only generates the interrupt and does not service it.

# 11.6.3 Pulse Accumulator Overflow Interrupt (PAOVF)

This active high output will be asserted by the module to request a timer pulse accumulator overflow interrupt. The TIM block only generates the interrupt and does not service it.

# 11.6.4 Timer Overflow Interrupt (TOF)

This active high output will be asserted by the module to request a timer overflow interrupt. The TIM block only generates the interrupt and does not service it.

# Chapter 12 Timer Module (TIM16B4CV3) Block Description

Table 12-1.

| V03.00 | Jan. 28, 2009 |                                                                                                                                  | Initial version                                                                                                                                                                                                                                                                                                                              |
|--------|---------------|----------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| V03.01 | Aug. 26, 2009 | 12.1.2/12-388<br>Figure 1-4./1-8<br>1.3.2.15/1-18<br>12.3.2.2/12-391,<br>1.3.2.3/1-8,<br>Chapter 12/12-38<br>7,<br>12.4.3/12-403 | <ul> <li>Correct typo: TSCR -&gt;TSCR1;</li> <li>Correct typo: ECTxxx-&gt;TIMxxx</li> <li>Correct reference: Figure 1-25 -&gt; Figure 12-22</li> <li>Add description, "a counter overflow when TTOV[7] is set", to be the condition of channel 7 override event.</li> <li>Phrase the description of OC7M to make it more explicit</li> </ul> |
| V03.02 | Apri,12,2010  | 12.3.2.6/12-394<br>12.3.2.9/12-396<br>12.4.3/12-403                                                                              | -Add Table 1-10<br>-update TCRE bit description<br>-add Figure 1-31                                                                                                                                                                                                                                                                          |
| V03.03 | Jan,14,2013   |                                                                                                                                  | -single source generate different channel guide                                                                                                                                                                                                                                                                                              |

# 12.1 Introduction

The basic scalable timer consists of a 16-bit, software-programmable counter driven by a flexible programmable prescaler.

This timer can be used for many purposes, including input waveform measurements while simultaneously generating an output waveform.

This timer could contain up to 4 input capture/output compare channels. The input capture function is used to detect a selected transition edge and record the time. The output compare function is used for generating output signals or for timer software delays.

A full access for the counter registers or the input capture/output compare registers should take place in one clock cycle. Accessing high byte and low byte separately for all of these registers may not yield the same result as accessing them in one word.

# 12.1.1 Features

The TIM16B4CV3 includes these distinctive features:

- Up to 4 channels available. (refer to device specification for exact number)
- All channels have same input capture/output compare functionality.
- Clock prescaling.



Figure 13-21. PWM 16-Bit Mode

Once concatenated mode is enabled (CONxx bits set in PWMCTL register), enabling/disabling the corresponding 16-bit PWM channel is controlled by the low order PWMEx bit. In this case, the high order bytes PWMEx bits have no effect and their corresponding PWM output is disabled.

Chapter 18 Scalable Controller Area Network (S12MSCANV3)

# 18.2 External Signal Description

The MSCAN uses two external pins.

### NOTE

On MCUs with an integrated CAN physical interface (transceiver) the MSCAN interface is connected internally to the transceiver interface. In these cases the external availability of signals TXCAN and RXCAN is optional.

# 18.2.1 RXCAN — CAN Receiver Input Pin

RXCAN is the MSCAN receiver input pin.

# **18.2.2 TXCAN** — **CAN Transmitter Output Pin**

TXCAN is the MSCAN transmitter output pin. The TXCAN output pin represents the logic level on the CAN bus:

- 0 = Dominant state
- 1 =Recessive state

# 18.2.3 CAN System

A typical CAN system with MSCAN is shown in Figure 18-2. Each CAN station is connected physically to the CAN bus lines through a transceiver device. The transceiver is capable of driving the large current needed for the CAN bus and has current protection against defective CAN or defective stations.



Figure 18-2. CAN System

# **18.3** Memory Map and Register Definition

This section provides a detailed description of all registers accessible in the MSCAN.

# 18.3.1 Module Memory Map

Figure 18-3 gives an overview on all registers and their individual bits in the MSCAN memory map. The *register address* results from the addition of *base address* and *address offset*. The *base address* is determined at the MCU level and can be found in the MCU memory map description. The *address offset* is defined at the module level.

The MSCAN occupies 64 bytes in the memory space. The base address of the MSCAN module is determined at the MCU level when the MCU is defined. The register decode map is fixed and begins at the first address of the module address offset.

The detailed register descriptions follow in the order they appear in the register map.

#### Chapter 22 192 KB Flash Module (S12ZFTMRZ192K2KV2)

| Global Address          | Size<br>(Bytes) | Field Description                                                       |
|-------------------------|-----------------|-------------------------------------------------------------------------|
| 0x1F_C000 - 0x1F_C007   | 8               | Reserved                                                                |
| 0x1F_C008 - 0x1F_C0B5   | 174             | Reserved                                                                |
| 0x1F_C0B6 - 0x1F_C0B7   | 2               | Version ID <sup>1</sup>                                                 |
| $0x1F_C0B8 - 0x1F_C0BF$ | 8               | Reserved                                                                |
| 0x1F_C0C0 - 0x1F_C0FF   | 64              | Program Once Field<br>Refer to Section 22.4.7.6, "Program Once Command" |

### Table 22-4. Program IFR Fields

<sup>1</sup> Used to track firmware patch versions, see <st-blue>Section 22.4.2 IFR Version ID Word

### Table 22-5. Memory Controller Resource Fields (NVM Resource Area<sup>1</sup>)

| Global Address              | Size<br>(Bytes) | Description                  |  |
|-----------------------------|-----------------|------------------------------|--|
| $0x1F_{4000} - 0x1F_{41}FF$ | 512             | Reserved                     |  |
| $0x1F_4200 - 0x1F_7FFF$     | 15,872          | Reserved                     |  |
| 0x1F_8000 - 0x1F_97FF       | 6,144           | Reserved                     |  |
| 0x1F_9800 - 0x1F_BFFF       | 10,240          | Reserved                     |  |
| 0x1F_C000 - 0x1F_C0FF       | 256             | P-Flash IFR (see Table 22-4) |  |
| 0x1F_C100 - 0x1F_C1FF       | 256             | Reserved.                    |  |
| 0x1F_C200 - 0x1F_FFFF       | 15,872          | Reserved.                    |  |

<sup>1</sup> See <st-blue>Section 22.4.4 Internal NVM resource for NVM Resources Area description.

#### Chapter 22 192 KB Flash Module (S12ZFTMRZ192K2KV2)

| Protection Update<br>Selection code [1:0] | Protection register selection                                                                                                         |  |  |  |  |
|-------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| bit 0                                     | Update P-Flash protection<br>0 - keep unchanged (do not update)<br>1 - update P-Flash protection with new FPROT value loaded on FCCOB |  |  |  |  |
| bit 1                                     | Update EEPROM protection<br>0 - keep unchanged (do not update)<br>1 - update EEPROM protection with new DFPROT value loaded on FCCOB  |  |  |  |  |

| Table 22-00. I folection Over flue selection description | Table 22-68. | Protection | Override | selection | description |
|----------------------------------------------------------|--------------|------------|----------|-----------|-------------|
|----------------------------------------------------------|--------------|------------|----------|-----------|-------------|

If the comparison key successfully matches the key programmed in the Flash Configuration Field the Protection Override command will preserve the current values of registers FPROT and DFPROT stored in an internal area and will override these registers as selected by the Protection Update Selection field with the value(s) loaded on FCCOB parameters. The new values loaded into FPROT and/or DFPROT can reconfigure protection without any restriction (by increasing, decreasing or disabling protection limits). If the command executes successfully the FPSTAT FPOVRD bit will set.

If the comparison key does not match the key programmed in the Flash Configuration Field, or if the key loaded on FCCOB is 16'hFFFF, the value of registers FPROT and DFPROT will be restored to their original contents before executing the Protection Override command and the FPSTAT FPOVRD bit will be cleared. If the contents of the Protection Override Comparison Key in the Flash Configuration Field is left in the erased state (i.e. 16'hFFFF) the Protection Override feature is permanently disabled. If the command execution is flagged as an error (ACCERR being set for incorrect command launch) the values of FPROT and DFPROT will not be modified.

The Protection Override command can be called multiple times and every time it is launched it will preserve the current values of registers FPROT and DFPROT in a single-entry buffer to be restored later; when the Protection Override command is launched to restore FPROT and DFPROT these registers will assume the values they had before executing the Protection Override command on the last time. If contents of FPROT and/or DFPROT registers were modified by direct register writes while protection is overrideen these modifications will be lost. Running Protection Override command to restore the contents of registers FPROT and DFPROT will not force them to the reset values.

## A.1.7 **Power Dissipation and Thermal Characteristics**

Power dissipation and thermal characteristics are closely related. The user must assure that the maximum operating junction temperature is not exceeded. The average chip-junction temperature  $(T_J)$  in °C can be obtained from:

$$T_{J} = T_{A} + (P_{D} \bullet \Theta_{JA})$$

 $T_{I}$  = Junction Temperature, [°C]

 $T_A = Ambient Temperature, [°C]$ 

 $P_{D}$  = Total Chip Power Dissipation, [W]

 $\Theta_{IA}$  = Package Thermal Resistance, [°C/W]

The total power dissipation  $P_D$  can be calculated from the equation below. Table A-6 below lists the power dissipation components. Table A-6 gives an overview of the supply currents.

 $P_{D} = P_{VSUP} + P_{BCTL} + P_{INT} - P_{GPIO} + P_{CANPHY}$ 

| Power Component                                           | Description                                                                                                                                                                                                                       |
|-----------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| $P_{VSUP} = V_{SUP} I_{SUP}$                              | Internal Power through VSUP pin                                                                                                                                                                                                   |
| $P_{BCTL} = V_{BCTL} I_{BCTL}$                            | Internal Power through BCTL pin                                                                                                                                                                                                   |
| $P_{INT} = V_{DDX} I_{VDDX} + V_{DDA} I_{VDDA}$           | Internal Power through VDDX/A pins.                                                                                                                                                                                               |
| $P_{GPIO} = V_{I/O} I_{I/O}$                              | Power dissipation of external load driven by GPIO Port.<br>Assuming the load is connected between GPIO and ground.<br>This power component is included in $P_{INT}$ and is subtracted<br>from overall MCU power dissipation $P_D$ |
| $P_{CANPHY} = [V_{DDC} - (V_{CANH} - V_{CANL})] I_{VDDC}$ | Power dissipation of CANPHY                                                                                                                                                                                                       |

#### **Table A-6. Power Dissipation Components**





In Figure D-5. the timing diagram for slave mode with transmission format CPHA=1 is depicted.



Figure D-5. SPI Slave Timing (CPHA=1)





# N.10 0x0500-0x052F PWM1

| Address        | Name    |        | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1     | Bit 0 |
|----------------|---------|--------|-------|---|---|---|---|---|-------|-------|
| 0x050C PWMCNT0 | PWMCNTO | R      | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1     | Bit 0 |
|                | W       | 0      | 0     | 0 | 0 | 0 | 0 | 0 | 0     |       |
| 0x050D PWMCNT1 | R       | Bit 7  | 6     | 5 | 4 | 3 | 2 | 1 | Bit 0 |       |
|                | W       | 0      | 0     | 0 | 0 | 0 | 0 | 0 | 0     |       |
| 0.0505         |         | R      | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1     | Bit 0 |
| 0x050E         | PWMCN12 | W      | 0     | 0 | 0 | 0 | 0 | 0 | 0     | 0     |
| 0.0505         |         | R      | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1     | Bit 0 |
| 0x050F         | PWMCN13 | w      | 0     | 0 | 0 | 0 | 0 | 0 | 0     | 0     |
| 0.0510         |         | R      | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1     | Bit 0 |
| 0x0510         | PWMCN14 | W      | 0     | 0 | 0 | 0 | 0 | 0 | 0     | 0     |
| 0.0511         |         | R      | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1     | Bit 0 |
| 0x0511         | PWMCN15 | W      | 0     | 0 | 0 | 0 | 0 | 0 | 0     | 0     |
| 0.0510         |         | R      | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1     | Bit 0 |
| 0x0512         | PWMCN16 | W      | 0     | 0 | 0 | 0 | 0 | 0 | 0     | 0     |
| 0.0510         |         | R      | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1     | Bit 0 |
| 0x0513         | PWMCN17 | W      | 0     | 0 | 0 | 0 | 0 | 0 | 0     | 0     |
| 0x0514         | PWMPER0 | R<br>W | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1     | Bit 0 |
| 0x0515         | PWMPER1 | R<br>W | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1     | Bit 0 |
| 0x0516         | PWMPER2 | R<br>W | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1     | Bit 0 |
| 0x0517         | PWMPER3 | R<br>W | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1     | Bit 0 |
| 0x0518         | PWMPER4 | R<br>W | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1     | Bit 0 |
| 0x0519         | PWMPER5 | R<br>W | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1     | Bit 0 |
| 0x051A         | PWMPER6 | R<br>W | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1     | Bit 0 |
| 0x051B         | PWMPER7 | R<br>W | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1     | Bit 0 |
| 0x051C         | PWMDTY0 | R<br>W | Bit 7 | 6 | 5 | 4 | 3 | 2 | 1     | Bit 0 |

# N.12 0x0600-0x063F ADC0 (continued)

| Address | Name        |        | Bit 7                       | 6                           | 5        | 4        | 3        | 2             | 1        | Bit 0    |  |
|---------|-------------|--------|-----------------------------|-----------------------------|----------|----------|----------|---------------|----------|----------|--|
| 0x0608  | ADC0EiF     | R<br>W | IA_EIF                      | CMD_EIF                     | EOL_EIF  | Reserved | TRIG_EIF | RSTAR_EI<br>F | LDOK_EIF | 0        |  |
| 0x0609  | ADC0IF      | R<br>W | SEQAD_IF                    | CONIF_OI                    | Reserved | 0        | 0        | 0             | 0        | 0        |  |
| 0x060A  | ADC0CONIE_0 | R<br>W |                             | CON_IE[15:8]                |          |          |          |               |          |          |  |
| 0x060B  | ADC0CONIE_1 | R<br>W |                             | CON_IE[7:1] EOI             |          |          |          |               |          |          |  |
| 0x060C  | ADC0CONIF_0 | R<br>W |                             | CON_IF[15:8]                |          |          |          |               |          |          |  |
| 0x060D  | ADC0CONIF_1 | R<br>W |                             | CON_IF[7:1] EC              |          |          |          |               |          |          |  |
| 0x060E  | ADC0IMDRI_0 | R      | CSL_IMD                     | RVL_IMD                     | 0        | 0        | 0        | 0             | 0        | 0        |  |
| 0x060F  | ADC0IMDRI_1 | R<br>W | 0                           | 0 RIDX_IMD                  |          |          |          |               |          |          |  |
| 0x0610  | ADC0EOLRI   | R<br>W | CSL_EOL                     | RVL_EOL                     | 0        | 0        | 0        | 0             | 0        | 0        |  |
| 0x0611  | Reserved    | R<br>W | 0                           | 0                           | 0        | 0        | 0        | 0             | 0        | 0        |  |
| 0x0612  | Reserved    | R<br>W | 0                           | 0                           | 0        | 0        | 0        | 0             | 0        | 0        |  |
| 0x0613  | Reserved    | R<br>W | Reserved 0                  |                             |          |          |          |               |          |          |  |
| 0x0614  | ADC0CMD_0   | R<br>W | CMD_SEL 0 0 INTFLG_SEL[3:0] |                             |          |          |          |               |          |          |  |
| 0x0615  | ADC0CMD_1   | R<br>W | VRH_SEL                     | VRH_SEL VRL_SEL CH_SEL[5:0] |          |          |          |               |          |          |  |
| 0x0616  | ADC0CMD_2   | R<br>W | SMP[4:0] 0 0 R              |                             |          |          |          |               |          | Reserved |  |
| 0x0617  | ADC0CMD_3   | R<br>W | Reserved                    | Reserved Reserved           |          |          |          |               |          |          |  |
| 0x0618  | Reserved    | R<br>W | Reserved                    |                             |          |          |          |               |          |          |  |
| 0x0619  | Reserved    | R<br>W | Reserved                    |                             |          |          |          |               |          |          |  |
| 0x061A  | Reserved    | R<br>W | Reserved                    |                             |          |          |          |               |          |          |  |
| 0x061B  | Reserved    | R<br>W |                             | Reserved                    |          |          |          |               |          |          |  |
| 0x061C  | ADC0CIDX    | R<br>W | 0 0 CMD_IDX[5:0]            |                             |          |          |          |               |          |          |  |
| 0x061D  | ADC0CBP_0   | R<br>W | CMD_PTR[23:16]              |                             |          |          |          |               |          |          |  |
| 0x061E  | ADC0CBP_1   | R<br>W | CMD_PTR[15:8]               |                             |          |          |          |               |          |          |  |
| 0x061F  | ADC0CBP_2   | R<br>W | CMD_PTR[7:2] 0              |                             |          |          |          |               | 0        | 0        |  |