



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

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

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

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

#### Details

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

Email: info@E-XFL.COM

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

#### Device Overview MC9S12VR-Family

## 1.4.4 Main External Oscillator (XOSCLCP)

- Loop control Pierce oscillator using 4 MHz to 20 MHz crystal
  - Current gain control on amplitude output
  - Signal with low harmonic distortion
  - Low power
  - Good noise immunity
  - Eliminates need for external current limiting resistor
  - Transconductance sized for optimum start-up margin for typical crystals
  - Oscillator pins shared with GPIO functionality

## **1.4.5** Internal RC Oscillator (IRC)

- Factory trimmed internal reference clock
  - 1 MHz internal RC oscillator with  $\pm 1.3\%$  accuracy over rated temperature range

## 1.4.6 Internal Phase-Locked Loop (IPLL)

- Phase-locked-loop clock frequency multiplier
  - No external components required
  - Reference divider and multiplier allow large variety of clock rates
  - Automatic bandwidth control mode for low-jitter operation
  - Automatic frequency lock detector
  - Configurable option to spread spectrum for reduced EMC radiation (frequency modulation)
  - Reference clock sources:
    - Internal 1 MHz RC oscillator (IRC)

### **1.4.7** Clock and Power Management Unit (CPMU)

- Real time interrupt (RTI)
- Clock monitor (CM)
- System reset generation

## **1.4.8** System Integrity Support

- Power-on reset (POR)
- Illegal address detection with reset
- Low-voltage detection with interrupt or reset
- Computer operating properly (COP) watchdog with option to run on internal RC oscillator
  - Configurable as window COP for enhanced failure detection
  - Can be initialized out of reset using option bits located in flash memory

### MC9S12VR Family Reference Manual, Rev. 4.2



Figure 1-2. MC9S12VR-Family Global Memory Map.

MC9S12VR Family Reference Manual, Rev. 4.2

# 1.7.6 Pinout 32-pin LQFP<sup>1</sup>



### Figure 1-4. MC9S12VR 32-pin LQFP pinout

<sup>1.</sup> SPI and SCI1 functionality on PS2, PS3, PT2 and PT3 is not available on MC9S12VR32/16.

# **1.8** Modes of Operation

The MCU can operate in different modes. These are described in 1.8.1 Chip Configuration Summary.

The MCU can operate in different power modes to facilitate power saving when full system performance is not required. These are described in 1.8.2 Low Power Operation.

Some modules feature a software programmable option to freeze the module status whilst the background debug module is active to facilitate debugging.

## **1.8.1** Chip Configuration Summary

The different modes and the security state of the MCU affect the debug features (enabled or disabled).

The operating mode out of reset is determined by the state of the MODC signal during reset (see Table 1-8). The MODC bit in the MODE register shows the current operating mode and provides limited mode switching during operation. The state of the MODC signal is latched into this bit on the rising edge of RESET.

### Table 1-8. Chip Modes

| Chip Modes          | MODC |
|---------------------|------|
| Normal single chip  | 1    |
| Special single chip | 0    |

### 1.8.1.1 Normal Single-Chip Mode

This mode is intended for normal device operation. The opcode from the on-chip memory is being executed after reset (requires the reset vector to be programmed correctly). The processor program is executed from internal memory.

### **1.8.1.2** Special Single-Chip Mode

This mode is used for debugging single-chip operation, boot-strapping, or security related operations. The background debug module BDM is active in this mode. The CPU executes a monitor program located in an on-chip ROM. BDM firmware waits for additional serial commands through the BKGD pin.

## **1.8.2** Low Power Operation

The MC9S12VR-Family has two dynamic-power modes (run and wait) and two static low-power modes stop and pseudo stop). For a detailed description refer to Section Chapter 1 S12 Clock, Reset and Power Management Unit (S12CPMU\_UHV).

- Dynamic power mode: Run
  - Run mode is the main full performance operating mode with the entire device clocked. The user can configure the device operating speed through selection of the clock source and the phase locked loop (PLL) frequency. To save power, unused peripherals must not be enabled.

Port Integration Module (S12VRPIMV3)

| Port | Pin Name                | Pin Function<br>& Priority <sup>1</sup> | I/O | Description                                                                            | Pin Function<br>after Reset |
|------|-------------------------|-----------------------------------------|-----|----------------------------------------------------------------------------------------|-----------------------------|
| Р    | <u>PP5</u>              | IRO                                     | Ι   | Maskable level- or falling edge-sensitive interrupt                                    | GPIO                        |
|      |                         | <u>PWM5</u>                             | 0   | Pulse Width Modulator channel 5                                                        |                             |
|      |                         | ETRIG1                                  | Ι   | ADC external trigger input                                                             |                             |
|      |                         | <u>PTP[5]/</u><br>KWP[5]                | I/O | General-purpose; with pin interrupt and wakeup                                         |                             |
|      | <u>PP4</u>              | <u>PWM4</u>                             | 0   | Pulse Width Modulator channel 4                                                        |                             |
|      |                         | ETRIG0                                  | Ι   | ADC external trigger input                                                             |                             |
|      |                         | <u>PTP[4]/</u><br><u>KWP[4]</u>         | I/O | General-purpose; with pin interrupt and wakeup                                         |                             |
|      | <u>PP3</u>              | <u>PWM3</u>                             | 0   | Pulse Width Modulator channel 3                                                        |                             |
|      |                         | <u>PTP[3]/</u><br>KWP[3]                | I/O | General-purpose; with pin interrupt and wakeup                                         |                             |
|      | PP2 <sup>3</sup>        | PWM2                                    | 0   | Pulse Width Modulator channel 2                                                        |                             |
|      |                         | PTP[2]/<br>KWP[2]/<br>EVDD              | I/O | General-purpose; with pin interrupt and wakeup                                         |                             |
|      | PP1 <sup>4</sup>        | XIRQ                                    | Ι   | Non-maskable level-sensitive interrupt                                                 |                             |
|      |                         | PWM1                                    | 0   | Pulse Width Modulator channel 1                                                        |                             |
|      |                         | PTP[1]/<br>KWP[1]                       | I/O | General-purpose; with interrupt and wakeup                                             |                             |
|      | <u>PP0</u> <sup>4</sup> | <u>PWM0</u>                             | 0   | Pulse Width Modulator channel 0                                                        |                             |
|      |                         | <u>PTP[0]/</u><br><u>KWP[0]</u>         | I/O | General-purpose; with interrupt and wakeup                                             |                             |
| L    | PL3-0                   | PTL[3:0]/<br>KWL[3:0]                   | Ι   | General-purpose high-voltage input (HVI); with interrupt and wakeup; optional ADC link | GPI (HVI)                   |
| AD   | <u>PAD5-2</u>           | <u>AN[5:2]</u>                          | Ι   | ADC analog                                                                             | GPIO                        |
|      |                         | <u>PTAD[5:2]/</u><br>KWAD[5:2]          | I/O | General-purpose; with interrupt and wakeup                                             |                             |
|      | PAD1-0                  | AN[1:0]                                 | Ι   | ADC analog                                                                             |                             |
|      |                         | PTAD[1:0]/<br>KWAD[1:0]                 | I/O | General-purpose; with interrupt and wakeup                                             |                             |

<sup>1</sup> Signals in parentheses denote alternative module routing pins. Signals in **bold underlined** are only available on S12VR64/48.

<sup>2</sup> Function active when  $\overline{\text{RESET}}$  asserted

<sup>3</sup> High current capable high-side output (20mA) with over-current interrupt and protection for all sources (see 2.4.4.3/2-112)

<sup>4</sup> High-current capable output (10 mA)

# 2.3 Memory Map and Register Definition

This section provides a detailed description of all PIM registers.

# 4.3 Memory Map and Registers

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

# 4.3.1 Module Memory Map

The S12CPMU\_UHV\_V8 registers are shown in Figure 4-3.

| Address | Name                  |        | Bit 7       | 6           | 5               | 4              | 3             | 2          | 1             | Bit 0          |
|---------|-----------------------|--------|-------------|-------------|-----------------|----------------|---------------|------------|---------------|----------------|
| 0x0034  | CPMU<br>SYNR          | R<br>W | VCOFRQ[1:0] |             | SYNDIV[5:0]     |                |               |            |               |                |
| 0x0035  | CPMU<br>REFDIV        | R<br>W | REFFR       | REFFRQ[1:0] |                 | 0              | 0 REFDIV[3:0] |            |               |                |
| 0x0036  | CPMU<br>POSTDIV       | R<br>W | 0           | 0           | 0               |                |               | POSTDIV[4: | 0]            |                |
| 0x0037  | CPMUFLG               | R<br>W | RTIF        | PORF        | LVRF            | LOCKIF         | LOCK          | ILAF       | OSCIF         | UPOSC          |
| 0x0038  | CPMUINT               | R<br>W | RTIE        | 0           | 0               | LOCKIE         | 0             | 0          | OSCIE         | <u>PMRF</u>    |
| 0x0039  | CPMUCLKS              | R<br>W | PLLSEL      | PSTP        | CSAD            | COP<br>OSCSEL1 | PRE           | PCE        | RTI<br>OSCSEL | COP<br>OSCSEL0 |
| 0x003A  | CPMUPLL               | R<br>W | 0           | 0           | FM1             | FM0            | 0             | 0          | 0             | 0              |
| 0x003B  | CPMURTI               | R<br>W | RTDEC       | RTR6        | RTR5            | RTR4           | RTR3          | RTR2       | RTR1          | RTR0           |
| 0x003C  | CPMUCOP               | R<br>W | WCOP        | RSBCK       | 0<br>WRTMASK    | 0              | 0             | CR2        | CR1           | CR0            |
| 0x003D  | RESERVED              | R      | 0           | 0           | 0               | 0              | 0             | 0          | 0             | 0              |
| UNUUSE  | CPMUTEST0             | W      |             |             |                 |                |               |            |               |                |
| 0x003E  | RESERVED<br>CPMUTEST1 | R<br>W | 0           | 0           | 0               | 0              | 0             | 0          | 0             | 0              |
| 0v003F  | CPMU                  | R      | 0           | 0           | 0               | 0              | 0             | 0          | 0             | 0              |
| 0x0051  | ARMCOP                | W      | Bit 7       | Bit 6       | Bit 5           | Bit 4          | Bit 3         | Bit 2      | Bit 1         | Bit 0          |
| 0x02F0  | CPMU<br>HTCTL         | R<br>W | 0           | 0           | VSEL            | 0              | HTE           | HTDS       | HTIE          | HTIF           |
| 0x02F1  | CPMU<br>LVCTL         | R<br>W | 0           | 0           | 0               | 0              | 0             | LVDS       | LVIE          | LVIF           |
| 0x02F2  | CPMU<br>APICTL        | R<br>W | APICLK      | 0           | 0               | APIES          | APIEA         | APIFE      | APIE          | APIF           |
|         |                       |        |             | = Unimplem  | nented or Reser | ved            |               |            |               |                |

Figure 4-3. CPMU Register Summary<sup>1</sup>





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

## 4.3.2.19 High Temperature Trimming Register (CPMUHTTR)

The CPMUHTTR register configures the trimming of the S12CPMU\_UHV\_V8 temperature sense.



Read: Anytime

Write: Anytime

| Field            | Description                                                                                                                                                                                                                                                                           |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>HTOE        | <ul> <li>High Temperature Offset Enable Bit — If set the temperature sense offset is enabled.</li> <li>0 The temperature sense offset is disabled. HTTR[3:0] bits don't care.</li> <li>1 The temperature sense offset is enabled. HTTR[3:0] select the temperature offset.</li> </ul> |
| 3–0<br>HTTR[3:0] | High Temperature Trimming Bits — See Table 4-25 for trimming effects.                                                                                                                                                                                                                 |

### Table 4-25. Trimming Effect of HTTR

| HTTR[3:0] | Temperature<br>sensor voltage V <sub>HT</sub> | Interrupt threshold temperatures $T_{\rm HTIA}$ and $T_{\rm HTID}$ |
|-----------|-----------------------------------------------|--------------------------------------------------------------------|
| 0000      | lowest                                        | highest                                                            |
| 0001      |                                               |                                                                    |
|           | increasing                                    | decreasing                                                         |
| 1110      |                                               |                                                                    |
| 1111      | highest                                       | lowest                                                             |

# 4.7.2 Application information for COP and API usage

In many applications the COP is used to check that the program is running and sequencing properly. Often the COP is kept running during Stop Mode and periodic wake-up events are needed to service the COP on time and maybe to check the system status.

For such an application it is recommended to use the ACLK as clock source for both COP and API. This guarantees lowest possible IDD current during Stop Mode. Additionally it eases software implementation using the same clock source for both, COP and API.

The Interrupt Service Routine (ISR) of the Autonomous Periodic Interrupt API should contain the write instruction to the CPMUARMCOP register. The value (byte) written is derived from the "main routine" (alternating sequence of \$55 and \$AA) of the application software.

Using this method, then in the case of a runtime or program sequencing issue the application "main routine" is not executed properly anymore and the alternating values are not provided properly. Hence the COP is written at the correct time (due to independent API interrupt request) but the wrong value is written (alternating sequence of \$55 and \$AA is no longer maintained) which causes a COP reset.

If the COP is stopped during any Stop Mode it is recommended to service the COP shortly before Stop Mode is entered.

#### S12S Debug Module (S12DBGV2)

for a valid match. Similarly the SZE and SZ bits allow the size of access (word or byte) to be considered in the compare. Only comparators A and B feature SZE and SZ.

The TAG bit in each comparator control register is used to determine the match condition. By setting TAG, the comparator qualifies a match with the output of opcode tracking logic and a state sequencer transition occurs when the tagged instruction reaches the CPU execution stage. Whilst tagging the RW, RWE, SZE, and SZ bits and the comparator data registers are ignored; the comparator address register must be loaded with the exact opcode address.

If the TAG bit is clear (forced type match) a comparator match is generated when the selected address appears on the system address bus. If the selected address is an opcode address, the match is generated when the opcode is fetched from the memory, which precedes the instruction execution by an indefinite number of cycles due to instruction pipelining. For a comparator match of an opcode at an odd address when TAG = 0, the corresponding even address must be contained in the comparator register. Thus for an opcode at odd address (n), the comparator register must contain address (n–1).

Once a successful comparator match has occurred, the condition that caused the original match is not verified again on subsequent matches. Thus if a particular data value is verified at a given address, this address may not still contain that data value when a subsequent match occurs.

Match[0, 1, 2] map directly to Comparators [A, B, C] respectively, except in range modes (see Section 6.3.2.4, "Debug Control Register2 (DBGC2)). Comparator channel priority rules are described in the priority section (Section 6.4.3.4, "Channel Priorities).

### 6.4.2.1 Single Address Comparator Match

With range comparisons disabled, the match condition is an exact equivalence of address bus with the value stored in the comparator address registers. Further qualification of the type of access (R/W, word/byte) and databus contents is possible, depending on comparator channel.

### 6.4.2.1.1 Comparator C

Comparator C offers only address and direction (R/W) comparison. The exact address is compared, thus with the comparator address register loaded with address (n) a word access of address (n-1) also accesses (n) but does not cause a match.

| Condition For Valid Match          | Comp C Address       | RWE | RW | Examples                             |
|------------------------------------|----------------------|-----|----|--------------------------------------|
| Read and write accesses of ADDR[n] | ADDR[n] <sup>1</sup> | 0   | Х  | LDAA ADDR[n]<br>STAA #\$BYTE ADDR[n] |
| Write accesses of ADDR[n]          | ADDR[n]              | 1   | 0  | STAA #\$BYTE ADDR[n]                 |
| Read accesses of ADDR[n]           | ADDR[n]              | 1   | 1  | LDAA #\$BYTE ADDR[n]                 |

 Table 6-32. Comparator C Access Considerations

<sup>1</sup> A word access of ADDR[n-1] also accesses ADDR[n] but does not generate a match. The comparator address register must contain the exact address from the code.

#### Pulse-Width Modulator (S12PWM8B8CV2)

Clock Source = bus clock, where bus clock= 10 MHz (100 ns period) PPOLx = 0 PWMPERx = 4 PWMDTYx = 1 PWMx Frequency = 10 MHz/8 = 1.25 MHz PWMx Period = 800 ns PWMx Duty Cycle = 3/4 \*100% = 75%

Shown in Figure 9-20 is the output waveform generated.



Figure 9-20. PWM Center Aligned Output Example Waveform

### 9.4.2.7 PWM 16-Bit Functions

The scalable PWM timer also has the option of generating up to 8-channels of 8-bits or 4-channels of 16-bits for greater PWM resolution. This 16-bit channel option is achieved through the concatenation of two 8-bit channels.

The PWMCTL register contains four control bits, each of which is used to concatenate a pair of PWM channels into one 16-bit channel. Channels 6 and 7 are concatenated with the CON67 bit, channels 4 and 5 are concatenated with the CON45 bit, channels 2 and 3 are concatenated with the CON23 bit, and channels 0 and 1 are concatenated with the CON01 bit.

### NOTE

Change these bits only when both corresponding channels are disabled.

When channels 6 and 7 are concatenated, channel 6 registers become the high order bytes of the double byte channel, as shown in Figure 9-21. Similarly, when channels 4 and 5 are concatenated, channel 4 registers become the high order bytes of the double byte channel. When channels 2 and 3 are concatenated, channel 2 registers become the high order bytes of the double byte channel. When channels 0 and 1 are concatenated, channel 0 registers become the high order bytes of the double byte soft the double byte channel.

When using the 16-bit concatenated mode, the clock source is determined by the low order 8-bit channel clock select control bits. That is channel 7 when channels 6 and 7 are concatenated, channel 5 when channels 4 and 5 are concatenated, channel 3 when channels 2 and 3 are concatenated, and channel 1 when channels 0 and 1 are concatenated. The resulting PWM is output to the pins of the corresponding low order 8-bit channel as also shown in Figure 9-21. The polarity of the resulting PWM output is controlled by the PPOLx bit of the corresponding low order 8-bit channel as well.

## 10.3.2.6 SCI Control Register 2 (SCICR2)



Figure 10-9. SCI Control Register 2 (SCICR2)

### Read: Anytime

### Write: Anytime

### Table 10-10. SCICR2 Field Descriptions

| Field     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>TIE  | <ul> <li>Transmitter Interrupt Enable Bit — TIE enables the transmit data register empty flag, TDRE, to generate interrupt requests.</li> <li>0 TDRE interrupt requests disabled</li> <li>1 TDRE interrupt requests enabled</li> </ul>                                                                                                                                                                                                        |
| 6<br>TCIE | <ul> <li>Transmission Complete Interrupt Enable Bit — TCIE enables the transmission complete flag, TC, to generate interrupt requests.</li> <li>0 TC interrupt requests disabled</li> <li>1 TC interrupt requests enabled</li> </ul>                                                                                                                                                                                                          |
| 5<br>RIE  | <ul> <li>Receiver Full Interrupt Enable Bit — RIE enables the receive data register full flag, RDRF, or the overrun flag, OR, to generate interrupt requests.</li> <li>0 RDRF and OR interrupt requests disabled</li> <li>1 RDRF and OR interrupt requests enabled</li> </ul>                                                                                                                                                                 |
| 4<br>ILIE | Idle Line Interrupt Enable Bit — ILIE enables the idle line flag, IDLE, to generate interrupt requests.         0       IDLE interrupt requests disabled         1       IDLE interrupt requests enabled                                                                                                                                                                                                                                      |
| 3<br>TE   | <ul> <li>Transmitter Enable Bit — TE enables the SCI transmitter and configures the TXD pin as being controlled by the SCI. The TE bit can be used to queue an idle preamble.</li> <li>0 Transmitter disabled</li> <li>1 Transmitter enabled</li> </ul>                                                                                                                                                                                       |
| 2<br>RE   | Receiver Enable Bit — RE enables the SCI receiver.         0       Receiver disabled         1       Receiver enabled                                                                                                                                                                                                                                                                                                                         |
| 1<br>RWU  | <ul> <li>Receiver Wakeup Bit — Standby state</li> <li>0 Normal operation.</li> <li>1 RWU enables the wakeup function and inhibits further receiver interrupt requests. Normally, hardware wakes the receiver by automatically clearing RWU.</li> </ul>                                                                                                                                                                                        |
| 0<br>SBK  | <ul> <li>Send Break Bit — Toggling SBK sends one break character (10 or 11 logic 0s, respectively 13 or 14 logics 0s if BRK13 is set). Toggling implies clearing the SBK bit before the break character has finished transmitting. As long as SBK is set, the transmitter continues to send complete break characters (10 or 11 bits, respectively 13 or 14 bits).</li> <li>No break characters</li> <li>Transmit break characters</li> </ul> |

To determine the value of a data bit and to detect noise, recovery logic takes samples at RT8, RT9, and RT10. Table 10-18 summarizes the results of the data bit samples.

| RT8, RT9, and RT10 Samples | Data Bit Determination | Noise Flag |
|----------------------------|------------------------|------------|
| 000                        | 0                      | 0          |
| 001                        | 0                      | 1          |
| 010                        | 0                      | 1          |
| 011                        | 1                      | 1          |
| 100                        | 0                      | 1          |
| 101                        | 1                      | 1          |
| 110                        | 1                      | 1          |
| 111                        | 1                      | 0          |

 Table 10-18. Data Bit Recovery

### NOTE

The RT8, RT9, and RT10 samples do not affect start bit verification. If any or all of the RT8, RT9, and RT10 start bit samples are logic 1s following a successful start bit verification, the noise flag (NF) is set and the receiver assumes that the bit is a start bit (logic 0).

To verify a stop bit and to detect noise, recovery logic takes samples at RT8, RT9, and RT10. Table 10-19 summarizes the results of the stop bit samples.

| RT8, RT9, and RT10 Samples | Framing Error Flag | Noise Flag |
|----------------------------|--------------------|------------|
| 000                        | 1                  | 0          |
| 001                        | 1                  | 1          |
| 010                        | 1                  | 1          |
| 011                        | 0                  | 1          |
| 100                        | 1                  | 1          |
| 101                        | 0                  | 1          |
| 110                        | 0                  | 1          |
| 111                        | 0                  | 0          |

Table 10-19. Stop Bit Recovery

#### Low-Side Drivers - LSDRV (S12LSDRV1)

The activation of the LSE0 or LSE1 bits enable the related low-side driver. The driver is controlled by the selected source in the Port Integration Module (see PIM chapter).

2. MCU stop mode

During stop mode operation the low-side drivers are shut down, i.e. the low-side drivers are disabled and their drivers are turned off. The bits in the data register which control the drivers (LSDRx) are cleared automatically. After returning from stop mode the drivers are re-enabled. If the data register bits (LSDRx) were chosen as source in PIM module, then the respective low-side driver stays turned off until the software sets the associated bit in the data register (LSDRx). When the timer or PWM were chosen as source, the respective low-side driver is controlled by the timer or PWM without further handling. When it is required that the driver stays turned off after the stop mode for this case (PWM or timer), the software must take the appropriate action to turn off the driver before entering stop mode.

### 15.1.3 Block Diagram

Figure 15-1 shows a block diagram of the LSDRV module. The module consists of a control and an output stage. Internal functions can be routed to control the low-side drivers. See PIM chapter for routing options.



Figure 15-1. LSDRV Block Diagram

## 16.3.2.6 LIN Status Register (LPSR)



<sup>1</sup> Read: Anytime

Write: Never, writes to this register have no effect

### Table 16-7. LPSR Field Description

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

#### 64 KByte Flash Module (S12FTMRG64K512V1) for S12VR64

| Field            | Description                                                                                                                                                                                                                                                                                                                        |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6<br>FDIVLCK     | <ul> <li>Clock Divider Locked</li> <li>FDIV field is open for writing</li> <li>FDIV value is locked and cannot be changed. Once the lock bit is set high, only reset can clear this bit and restore writability to the FDIV field in normal mode.</li> </ul>                                                                       |
| 5–0<br>FDIV[5:0] | <b>Clock Divider Bits</b> — FDIV[5:0] must be set to effectively divide BUSCLK down to 1 MHz to control timed events during Flash program and erase algorithms. Table 18-8 shows recommended values for FDIV[5:0] based on the BUSCLK frequency. Please refer to Section 18.4.4, "Flash Command Operations," for more information. |

### Table 18-7. FCLKDIV Field Descriptions (continued)

| BUSCLK Fre       | quency (MHz)     |           | BUSCLK Fre       | BUSCLK Frequency (MHz) |           |  |  |
|------------------|------------------|-----------|------------------|------------------------|-----------|--|--|
| MIN <sup>1</sup> | MAX <sup>2</sup> | FDIV[5:0] | MIN <sup>1</sup> | MAX <sup>2</sup>       | FDIV[5:0] |  |  |
| 1.0              | 1.6              | 0x00      | 16.6             | 17.6                   | 0x10      |  |  |
| 1.6              | 2.6              | 0x01      | 17.6             | 18.6                   | 0x11      |  |  |
| 2.6              | 3.6              | 0x02      | 18.6             | 19.6                   | 0x12      |  |  |
| 3.6              | 4.6              | 0x03      | 19.6             | 20.6                   | 0x13      |  |  |
| 4.6              | 5.6              | 0x04      | 20.6             | 21.6                   | 0x14      |  |  |
| 5.6              | 6.6              | 0x05      | 21.6             | 22.6                   | 0x15      |  |  |
| 6.6              | 7.6              | 0x06      | 22.6             | 23.6                   | 0x16      |  |  |
| 7.6              | 8.6              | 0x07      | 23.6             | 24.6                   | 0x17      |  |  |
| 8.6              | 9.6              | 0x08      | 24.6             | 25.6                   | 0x18      |  |  |
| 9.6              | 10.6             | 0x09      |                  |                        |           |  |  |
| 10.6             | 11.6             | 0x0A      |                  |                        |           |  |  |
| 11.6             | 12.6             | 0x0B      |                  |                        |           |  |  |
| 12.6             | 13.6             | 0x0C      |                  |                        |           |  |  |
| 13.6             | 14.6             | 0x0D      |                  |                        |           |  |  |
| 14.6             | 15.6             | 0x0E      |                  |                        |           |  |  |
| 15.6             | 16.6             | 0x0F      |                  |                        |           |  |  |

| Table 18-8. | FDIV values | s for various | BUSCLK F | requencies |
|-------------|-------------|---------------|----------|------------|
| 10010 10 0  | IDI Manuch  | , ioi vaiious | DUDUDINI | requencies |

<sup>1</sup> BUSCLK is Greater Than this value.

<sup>2</sup> BUSCLK is Less Than or Equal to this value.

## 18.3.2.2 Flash Security Register (FSEC)

The FSEC register holds all bits associated with the security of the MCU and Flash module.

#### 32 KByte Flash Module (S12FTMRG32K128V1) for S12VR32

| Field            | Description                                                                                                                                                                                                                                                                                                |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2<br>FPLDIS      | Flash Protection Lower Address Range Disable — The FPLDIS bit determines whether there is a protected/unprotected area in a specific region of the P-Flash memory beginning with global address 0x3_8000.         0       Protection/Unprotection enabled         1       Protection/Unprotection disabled |
| 1–0<br>FPLS[1:0] | <b>Flash Protection Lower Address Size</b> — The FPLS bits determine the size of the protected/unprotected area in P-Flash memory as shown in Table 19-20. The FPLS bits can only be written to while the FPLDIS bit is set.                                                                               |

### Table 19-17. FPROT Field Descriptions (continued)

| FPOPEN | FPHDIS | FPLDIS | Function <sup>1</sup>           |
|--------|--------|--------|---------------------------------|
| 1      | 1      | 1      | No P-Flash Protection           |
| 1      | 1      | 0      | Protected Low Range             |
| 1      | 0      | 1      | Protected High Range            |
| 1      | 0      | 0      | Protected High and Low Ranges   |
| 0      | 1      | 1      | Full P-Flash Memory Protected   |
| 0      | 1      | 0      | Unprotected Low Range           |
| 0      | 0      | 1      | Unprotected High Range          |
| 0      | 0      | 0      | Unprotected High and Low Ranges |

#### Table 19-18. P-Flash Protection Function

<sup>1</sup> For range sizes, refer to Table 19-19 and Table 19-20.

### Table 19-19. P-Flash Protection Higher Address Range

| FPHS[1:0] | Global Address Range | Protected Size |
|-----------|----------------------|----------------|
| 00        | 0x3_F800-0x3_FFFF    | 2 Kbytes       |
| 01        | 0x3_F000-0x3_FFFF    | 4 Kbytes       |
| 10        | 0x3_E000-0x3_FFFF    | 8 Kbytes       |
| 11        | 0x3_C000–0x3_FFFF    | 16 Kbytes      |

#### Table 19-20. P-Flash Protection Lower Address Range

| FPLS[1:0] | <b>Global Address Range</b> | Protected Size |
|-----------|-----------------------------|----------------|
| 00        | 0x3_8000-0x3_83FF           | 1 Kbyte        |
| 01        | 0x3_8000-0x3_87FF           | 2 Kbytes       |
| 10        | 0x3_8000-0x3_8FFF           | 4 Kbytes       |
| 11        | 0x3_8000-0x3_9FFF           | 8 Kbytes       |

All possible P-Flash protection scenarios are shown in Figure 19-14Although the protection scheme is loaded from the Flash memory at global address 0x3\_FF0C during the reset sequence, it can be changed by the user. The P-Flash protection scheme can be used by applications requiring reprogramming in Normal Single Chip Mode while providing as much protection as possible if reprogramming is not required.

### Table I-2. Static Electrical Characteristics - Supply Voltage Sense - (BATS).

Characteristics noted under conditions  $5.5V \le VSUP \le 18 \text{ V}$ ,  $-40^{\circ}C \le T_J \le 150^{\circ}C^1$  unless otherwise noted. Typical values noted reflect the approximate parameter mean at  $T_A = 25^{\circ}C^2$  under nominal conditions unless otherwise noted. All parameters in this table assume a in series connected  $R_{VSENSE_R}$  at VSENSE pin unless otherwise noted and are valid on input voltage of  $R_{VSENSE_R}$  and not on VSENSE pin.

| Num | Ratings                                                                        | Symbol                | Min | Тур | Max  | Unit |
|-----|--------------------------------------------------------------------------------|-----------------------|-----|-----|------|------|
| 9   | VSENSE Series Resistor                                                         | R <sub>VSENSE_R</sub> | 9.5 | 10  | 10.5 | kΩ   |
|     | Required to be placed externally at VSENSE pin.                                |                       |     |     |      |      |
| 10  | VSENSE Impedance                                                               | R <sub>VSEN_IMP</sub> | -   | 350 | -    | kΩ   |
|     | If path to ground is enabled. Value at VSENSE pin. $R_{VSENSE_R}$ is excluded. |                       |     |     |      |      |
| 11  | VSENSE Input Capacitance                                                       | C <sub>VSEN_IN</sub>  | _   | 8   | _    | pF   |

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

<sup>2</sup> T<sub>A</sub>: Ambient Temperature

 $^{3}$  V<sub>ADC</sub>: Voltage accessible at the ATD input channel

## I.3 Dynamic Electrical Characteristics

#### Table I-3. Dynamic Electrical Characteristics - Supply Voltage Sense - (BATS).

| Characte<br>reflect th | Characteristics noted under conditions $5.5V \le VSUP \le 18 \text{ V}$ , $-40^{\circ}C \le T_J \le 150^{\circ}C^1$ unless otherwise noted. Typical values noted reflect the approximate parameter mean at $T_A = 25^{\circ}C^2$ under nominal conditions unless otherwise noted. |                     |   |     |   |     |  |  |  |  |
|------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------|---|-----|---|-----|--|--|--|--|
| Num                    | Ratings     Symbol     Min     Typ     Max     U                                                                                                                                                                                                                                  |                     |   |     |   |     |  |  |  |  |
| 1                      | Enable Stabilisation Time                                                                                                                                                                                                                                                         | T <sub>EN_UNC</sub> | _ | 1   | — | μs  |  |  |  |  |
| 2                      | Voltage Warning Low Pass Filter                                                                                                                                                                                                                                                   | $f_{VWLP_filter}$   | Ι | 0.5 | - | MHz |  |  |  |  |

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

<sup>2</sup> T<sub>A</sub>: Ambient Temperature

# P.13 0x0070-0x009F Analog to Digital Converter 10-Bit 6-Channel (ATD) Map

| Address | Name      |             | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2   | Bit 1 | Bit 0 |
|---------|-----------|-------------|-------|-------|-------|-------|-------|---------|-------|-------|
| 0x0074  | ATDCTL4   | R<br>W      | SMP2  | SMP1  | SMP0  | PRS4  | PRS3  | PRS2    | PRS1  | PRS0  |
| 0x0075  | ATDCTL5   | R<br>W      | 0     | SC    | SCAN  | MULT  | CD    | CC      | СВ    | CA    |
| 0x0076  | ATDSTAT0  | R<br>W      | SCF   | 0     | ETORF | FIFOR | CC3   | CC2     | CC1   | CC0   |
| 0x0077  | Reserved  | R<br>W      | 0     | 0     | 0     | 0     | 0     | 0       | 0     | 0     |
| 0x0078  | ATDCMPEH  | R<br>W      | 0     | 0     | 0     | 0     | 0     | 0       | 0     | 0     |
| 0x0079  | ATDCMPEL  | R<br>W      | 0]    | 0     |       |       | CMP   | E[5:0]  |       |       |
| 0x007A  | ATDSTAT2H | R<br>W      |       |       |       |       |       |         |       |       |
| 0x007B  | ATDSTAT2L | R<br>W      | 0     | 0     |       |       | CCF   | [5:0]   |       |       |
| 0x007C  | ATDDIENH  | R<br>W      | 0     | 0     | 0     | 0     | 0     | 0       | 0     | 0     |
| 0x007D  | ATDDIENL  | R<br>W      | 0     | 0     |       |       |       |         |       |       |
| 0x007E  | ATDCMPHTH | R<br>W      | 0     | 0     | 0     | 0     | 0     | 0       | 0     | 0     |
| 0x007F  | ATDCMPHTL | R<br>W      | 0     | 0     |       |       | СМРН  | [T[5:0] |       |       |
| 0x0080  | ATDDR0H   | R<br>W      | Bit15 | 14    | 13    | 12    | 11    | 10      | 9     | Bit8  |
| 0x0081  | ATDDR0L   | R<br>W      | Bit7  | Bit6  | 0     | 0     | 0     | 0       | 0     | 0     |
| 0x0082  | ATDDR1H   | R<br>W      | Bit15 | 14    | 13    | 12    | 11    | 10      | 9     | Bit8  |
| 0x0083  | ATDDR1L   | R<br>W      | Bit7  | Bit6  | 0     | 0     | 0     | 0       | 0     | 0     |
| 0x0084  | ATDDR2H   | R<br>W      | Bit15 | 14    | 13    | 12    | 11    | 10      | 9     | Bit8  |
| 0x0085  | ATDDR2L   | R           | Bit7  | Bit6  | 0     | 0     | 0     | 0       | 0     | 0     |
| 0x0086  | ATDDR3H   | R<br>W      | Bit15 | 14    | 13    | 12    | 11    | 10      | 9     | Bit8  |
| 0x0087  | ATDDR3L   | W<br>R      | Bit7  | Bit6  | 0     | 0     | 0     | 0       | 0     | 0     |
| 0x0088  | ATDDR4H   | W<br>R      | Bit15 | 14    | 13    | 12    | 11    | 10      | 9     | Bit8  |
| 0x0089  | ATDDR4L   | w<br>R<br>W | Bit7  | Bit6  | 0     | 0     | 0     | 0       | 0     | 0     |

MC9S12VR Family Reference Manual, Rev. 4.2

# P.19 0x0100-0x0113 NVM Contol Register (FTMRG) Map

| Address      | Name   |   | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|--------------|--------|---|-------|-------|-------|-------|-------|-------|-------|-------|
| Ov0111 EDSV5 | FRSV5  | R | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| 040111       |        | W |       |       |       |       |       |       |       |       |
| 0.0110 ED    | EDGM   | R | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| 0X0112       | FKSVO  | W |       |       |       |       |       |       |       |       |
| 0x0113 FI    | EDSV7  | R | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
|              | 1'K3V/ | W |       |       |       |       |       |       |       |       |

# P.20 0x0114-0x011F Reserved

| Address               | Name     |   | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-----------------------|----------|---|-------|-------|-------|-------|-------|-------|-------|-------|
| 0x0114-<br>0x011F Res | Pasaruad | R | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
|                       | Reserveu | W |       |       |       |       |       |       |       |       |

# P.21 0x0120 Interrupt Vector Base Register

| Address | Name | Bit 7  | Bit 6         | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|------|--------|---------------|-------|-------|-------|-------|-------|-------|
| 0x0120  | IVBR | R<br>W | IVB_ADDR[7:0] |       |       |       |       |       |       |

# P.22 0x0121-0x013F Reserved

| Address           | Name     |   | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|-------------------|----------|---|-------|-------|-------|-------|-------|-------|-------|-------|
| 0x0121-<br>0x013F | Reserved | R | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
|                   |          | W |       |       |       |       |       |       |       |       |