



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

Email: info@E-XFL.COM

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

# 1.7.3.1 VDDX[3:1]/VDDX, VSSX[3:1]/VSSX— Power and Ground Pins for I/O Drivers

External power and ground for I/O drivers. Bypass requirements depend on how heavily the MCU pins are loaded. All VDDX pins are connected together internally. All VSSX pins are connected together internally.

### NOTE

Not all VDDX[3:1]/VDDX and VSSX[3:1]VSSX pins are available on all packages. Refer to section 1.8 Device Pinouts for further details.

## 1.7.3.2 VDDR — Power Pin for Internal Voltage Regulator

Power supply input to the internal voltage regulator.

### NOTE

On some packages VDDR is bonded to VDDX and the pin is named VDDXR. Refer to section 1.8 Device Pinouts for further details.

## 1.7.3.3 VSS — Core Ground Pin

The voltage supply of nominally 1.8V is derived from the internal voltage regulator. The return current path is through the VSS pin.

# 1.7.3.4 VDDA, VSSA — Power Supply Pins for DAC,ACMP, RVA, ADC and Voltage Regulator

These are the power supply and ground input pins for the digital-to-analog converter, the analog comparator, the reference voltage attenuator, the analog-to-digital converter and the voltage regulator.

### NOTE

On some packages VDDA is connected with VDDXR and the common pin is named VDDXRA.

On some packages the VSSA is connected to VSSX and the common pin is named VSSXA. See section Section 1.8, "Device Pinouts" for further details.

## 1.7.3.5 VRH — Reference Voltage Input Pin

 $V_{RH}$  is the reference voltage input pin for the digital-to-analog converter and the analog-to-digital converter. Refer to Section 1.18, "ADC VRH/VRL Signal Connection" for further details.

On some packages VRH is tied to VDDA or VDDXRA. Refer to section 1.8 Device Pinouts for further details.

#### S12S Debug Module (S12SDBGV2)

| SZE | SZ | DBGADHM,<br>DBGADLM | Access<br>DH=DBGADH, DL=DBGADL                                         | Comment                           |
|-----|----|---------------------|------------------------------------------------------------------------|-----------------------------------|
| 0   | Х  | \$FF00              | Byte, data(ADDR[n])=DH<br>Word, data(ADDR[n])=DH, data(ADDR[n+1])=X    | Match data( ADDR[n])              |
| 0   | Х  | \$00FF              | Word, data(ADDR[n])=X, data(ADDR[n+1])=DL                              | Match data( ADDR[n+1])            |
| 0   | Х  | \$00FF              | Byte, data(ADDR[n])=X, data(ADDR[n+1])=DL Possible unintended match    |                                   |
| 0   | Х  | \$FFFF              | Word, data(ADDR[n])=DH, data(ADDR[n+1])=DL Match data( ADDR[n], ADDR[r |                                   |
| 0   | Х  | \$FFFF              | Byte, data(ADDR[n])=DH, data(ADDR[n+1])=DL                             | Possible unintended match         |
| 1   | 0  | \$0000              | Word                                                                   | No databus comparison             |
| 1   | 0  | \$00FF              | Word, data(ADDR[n])=X, data(ADDR[n+1])=DL                              | Match only data at ADDR[n+1]      |
| 1   | 0  | \$FF00              | Word, data(ADDR[n])=DH, data(ADDR[n+1])=X                              | Match only data at ADDR[n]        |
| 1   | 0  | \$FFFF              | Word, data(ADDR[n])=DH, data(ADDR[n+1])=DL                             | Match data at ADDR[n] & ADDR[n+1] |
| 1   | 1  | \$0000              | Byte                                                                   | No databus comparison             |
| 1   | 1  | \$FF00              | Byte, data(ADDR[n])=DH                                                 | Match data at ADDR[n]             |

### 8.4.2.1.4 Comparator A Data Bus Comparison NDB Dependency

Comparator A features an NDB control bit, which allows data bus comparators to be configured to either trigger on equivalence or trigger on difference. This allows monitoring of a difference in the contents of an address location from an expected value.

When matching on an equivalence (NDB=0), each individual data bus bit position can be masked out by clearing the corresponding mask bit (DBGADHM/DBGADLM) so that it is ignored in the comparison. A match occurs when all data bus bits with corresponding mask bits set are equivalent. If all mask register bits are clear, then a match is based on the address bus only, the data bus is ignored.

When matching on a difference, mask bits can be cleared to ignore bit positions. A match occurs when any data bus bit with corresponding mask bit set is different. Clearing all mask bits, causes all bits to be ignored and prevents a match because no difference can be detected. In this case address bus equivalence does not cause a match.

| NDB | DBGADHM[n] /<br>DBGADLM[n] | 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 8-35. NDB and MASK bit dependency

## 8.4.2.2 Range Comparisons

Using the AB comparator pair for a range comparison, the data bus can also be used for qualification by using the comparator A data registers. Furthermore 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 SZE and SZ control bits are ignored in range mode. The comparator A TAG bit is used to tag

### Write: Anytime

| Table 10-16. CPMUAPICTL Field Descriptior |
|-------------------------------------------|
|-------------------------------------------|

| Field       | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>APICLK | <ul> <li>Autonomous Periodical Interrupt Clock Select Bit — Selects the clock source for the API. Writable only if APIFE = 0. APICLK cannot be changed if APIFE is set by the same write operation.</li> <li>0 Autonomous Clock (ACLK) used as source.</li> <li>1 Bus Clock used as source.</li> </ul>                                                                                                                                                                                                                                                                     |
| 4<br>APIES  | <ul> <li>Autonomous Periodical Interrupt External Select Bit — Selects the waveform at the external pin API_EXTCLK as shown in Figure 10-18. See device level specification for connectivity of API_EXTCLK pin.</li> <li>If APIEA and APIFE are set, at the external pin API_EXTCLK periodic high pulses are visible at the end of every selected period with the size of half of the minimum period (APIR=0x0000 in Table 10-20).</li> <li>If APIEA and APIFE are set, at the external pin API_EXTCLK a clock is visible with 2 times the selected API Period.</li> </ul> |
| 3<br>APIEA  | <ul> <li>Autonomous Periodical Interrupt External Access Enable Bit — If set, the waveform selected by bit APIES can be accessed externally. See device level specification for connectivity.</li> <li>Waveform selected by APIES can not be accessed externally.</li> <li>Waveform selected by APIES can be accessed externally, if APIFE is set.</li> </ul>                                                                                                                                                                                                              |
| 2<br>APIFE  | <ul> <li>Autonomous Periodical Interrupt Feature Enable Bit — Enables the API feature and starts the API timer when set.</li> <li>0 Autonomous periodical interrupt is disabled.</li> <li>1 Autonomous periodical interrupt is enabled and timer starts running.</li> </ul>                                                                                                                                                                                                                                                                                                |
| 1<br>APIE   | Autonomous Periodical Interrupt Enable Bit<br>0 API interrupt request is disabled.<br>1 API interrupt will be requested whenever APIF is set.                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 0<br>APIF   | <ul> <li>Autonomous Periodical Interrupt Flag — After each time-out of the API (time-out rate is configured in the CPMUAPIRH/L registers) the interrupt flag APIF is set to 1. This flag can only be cleared by writing a 1. Writing a 0 has no effect. If enabled (APIE = 1), APIF causes an interrupt request.</li> <li>0 API time-out has not yet occurred.</li> <li>1 API time-out has occurred.</li> </ul>                                                                                                                                                            |

Figure 10-18. Waveform selected on API\_EXTCLK pin (APIEA=1, APIFE=1)



#### Analog-to-Digital Converter (ADC10B12CV2)

<sup>1</sup>If only AN0 should be converted use MULT=0.

# 13.3.2.2 ATD Control Register 1 (ATDCTL1)

Writes to this register will abort current conversion sequence.

Module Base + 0x0001



Figure 13-4. ATD Control Register 1 (ATDCTL1)

Read: Anytime

Write: Anytime

| Table 13-3. | ATDCTL1 | Field | Descriptions |
|-------------|---------|-------|--------------|
|             | AIDOILI | 11010 | Descriptions |

| Field               | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>ETRIGSEL       | <b>External Trigger Source Select</b> — This bit selects the external trigger source to be either one of the AD channels or one of the ETRIG3-0 inputs. See device specification for availability and connectivity of ETRIG3-0 inputs. If a particular ETRIG3-0 input option is not available, writing a 1 to ETRISEL only sets the bit but has no effect, this means that one of the AD channels (selected by ETRIGCH3-0) is configured as the source for external trigger. The coding is summarized in Table 13-5. |
| 6–5<br>SRES[1:0]    | <b>A/D Resolution Select</b> — These bits select the resolution of A/D conversion results. See Table 13-4 for coding.                                                                                                                                                                                                                                                                                                                                                                                                |
| 4<br>SMP_DIS        | <ul> <li>Discharge Before Sampling Bit</li> <li>No discharge before sampling.</li> <li>The internal sample capacitor is discharged before sampling the channel. This adds 2 ATD clock cycles to the sampling time. This can help to detect an open circuit instead of measuring the previous sampled channel.</li> </ul>                                                                                                                                                                                             |
| 3–0<br>ETRIGCH[3:0] | <b>External Trigger Channel Select</b> — These bits select one of the AD channels or one of the ETRIG3-0 inputs as source for the external trigger. The coding is summarized in Table 13-5.                                                                                                                                                                                                                                                                                                                          |

| SRES1 | SRES0 | A/D Resolution |  |
|-------|-------|----------------|--|
| 0     | 0     | 8-bit data     |  |
| 0     | 1     | 10-bit data    |  |
| 1     | 0     | Reserved       |  |
| 1     | 1     | Reserved       |  |

| ETRIGSEL | ETRIGCH3 | ETRIGCH2 | ETRIGCH1 | ETRIGCH0 | External trigger source is |
|----------|----------|----------|----------|----------|----------------------------|
| 0        | 0        | 0        | 0        | 0        | AN0                        |
| 0        | 0        | 0        | 0        | 1        | AN1                        |
| 0        | 0        | 0        | 1        | 0        | AN2                        |
| 0        | 0        | 0        | 1        | 1        | AN3                        |
| 0        | 0        | 1        | 0        | 0        | AN4                        |
| 0        | 0        | 1        | 0        | 1        | AN5                        |
| 0        | 0        | 1        | 1        | 0        | AN6                        |
| 0        | 0        | 1        | 1        | 1        | AN7                        |
| 0        | 1        | 0        | 0        | 0        | AN8                        |
| 0        | 1        | 0        | 0        | 1        | AN9                        |
| 0        | 1        | 0        | 1        | 0        | AN10                       |
| 0        | 1        | 0        | 1        | 1        | AN11                       |
| 0        | 1        | 1        | 0        | 0        | AN11                       |
| 0        | 1        | 1        | 0        | 1        | AN11                       |
| 0        | 1        | 1        | 1        | 0        | AN11                       |
| 0        | 1        | 1        | 1        | 1        | AN11                       |
| 1        | 0        | 0        | 0        | 0        | ETRIG0 <sup>1</sup>        |
| 1        | 0        | 0        | 0        | 1        | ETRIG1 <sup>1</sup>        |
| 1        | 0        | 0        | 1        | 0        | ETRIG2 <sup>1</sup>        |
| 1        | 0        | 0        | 1        | 1        | ETRIG3 <sup>1</sup>        |
| 1        | 0        | 1        | Х        | Х        | Reserved                   |
| 1        | 1        | Х        | Х        | Х        | Reserved                   |

Table 13-5. External Trigger Channel Select Coding

<sup>1</sup> Only if ETRIG3-0 input option is available (see device specification), else ETRISEL is ignored, that means external trigger source is still on one of the AD channels selected by ETRIGCH3-0

# 13.3.2.3 ATD Control Register 2 (ATDCTL2)

Writes to this register will abort current conversion sequence.

Module Base + 0x0002





Read: Anytime

Write: Anytime

| Input Signal<br>VRL = 0 Volts<br>VRH = 5.12 Volts | 8-Bit<br>Codes<br>(resolution=20mV) | 10-Bit<br>Codes<br>(resolution=5mV) | Reserved |
|---------------------------------------------------|-------------------------------------|-------------------------------------|----------|
| 5.120 Volts                                       | 255                                 | 1023                                | Reserved |
| <br>0.022<br>0.020<br>0.018                       | <br>1<br>1<br>1                     | <br>4<br>4<br>4                     |          |
| 0.016                                             | 1                                   | 3                                   |          |
| 0.014                                             | 1                                   | 3                                   |          |
| 0.012                                             | 1                                   | 2                                   |          |
| 0.010                                             | 1                                   | 2                                   |          |
| 0.008                                             | 0                                   | 2                                   |          |
| 0.006                                             | 0                                   | 1                                   |          |
| 0.004                                             | 0                                   | 1                                   |          |
| 0.003                                             | 0                                   | 1                                   |          |
| 0.002                                             | 0                                   | 0                                   |          |
| 0.000                                             | 0                                   | 0                                   |          |

### Table 15-10. Conversion Sequence Length Coding

| S8C | S4C | S2C | S1C | Number of Conversions per Sequence |
|-----|-----|-----|-----|------------------------------------|
| 0   | 0   | 0   | 0   | 16                                 |
| 0   | 0   | 0   | 1   | 1                                  |
| 0   | 0   | 1   | 0   | 2                                  |
| 0   | 0   | 1   | 1   | 3                                  |
| 0   | 1   | 0   | 0   | 4                                  |
| 0   | 1   | 0   | 1   | 5                                  |
| 0   | 1   | 1   | 0   | 6                                  |
| 0   | 1   | 1   | 1   | 7                                  |
| 1   | 0   | 0   | 0   | 8                                  |
| 1   | 0   | 0   | 1   | 9                                  |
| 1   | 0   | 1   | 0   | 10                                 |
| 1   | 0   | 1   | 1   | 11                                 |
| 1   | 1   | 0   | 0   | 12                                 |
| 1   | 1   | 0   | 1   | 13                                 |
| 1   | 1   | 1   | 0   | 14                                 |
| 1   | 1   | 1   | 1   | 15                                 |

| Table 15-11. | <b>ATD Behavior</b> | in Freeze I | Mode ( | (Breakpoint) |
|--------------|---------------------|-------------|--------|--------------|
|--------------|---------------------|-------------|--------|--------------|

| FRZ1 | FRZ0 | Behavior in Freeze Mode |
|------|------|-------------------------|
| 0    | 0    | Continue conversion     |

#### Analog-to-Digital Converter (ADC10B16CV2)

| FRZ1 | FRZ0 | Behavior in Freeze Mode                |
|------|------|----------------------------------------|
| 0    | 1    | Reserved                               |
| 1    | 0    | Finish current conversion, then freeze |
| 1    | 1    | Freeze Immediately                     |

Table 15-11. ATD Behavior in Freeze Mode (Breakpoint)

### 15.3.2.5 ATD Control Register 4 (ATDCTL4)

Writes to this register will abort current conversion sequence.

Module Base + 0x0004



Read: Anytime

Write: Anytime

Table 15-12. ATDCTL4 Field Descriptions

| Field           | Description                                                                                                                                                                                                                                                                          |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–5<br>SMP[2:0] | <b>Sample Time Select</b> — These three bits select the length of the sample time in units of ATD conversion clock cycles. Note that the ATD conversion clock period is itself a function of the prescaler value (bits PRS4-0). Table 15-13 lists the available sample time lengths. |
| 4–0<br>PRS[4:0] | <b>ATD Clock Prescaler</b> — These 5 bits are the binary prescaler value PRS. The ATD conversion clock frequency is calculated as follows:                                                                                                                                           |
|                 | $f_{ATDCLK} = \frac{f_{BUS}}{2 \times (PRS + 1)}$                                                                                                                                                                                                                                    |
|                 | Refer to Device Specification for allowed frequency range of f <sub>ATDCLK</sub> .                                                                                                                                                                                                   |

#### Table 15-13. Sample Time Select

| SMP2 | SMP1 | SMP0 | Sample Time<br>in Number of<br>ATD Clock Cycles |
|------|------|------|-------------------------------------------------|
| 0    | 0    | 0    | 4                                               |
| 0    | 0    | 1    | 6                                               |
| 0    | 1    | 0    | 8                                               |
| 0    | 1    | 1    | 10                                              |
| 1    | 0    | 0    | 12                                              |
| 1    | 0    | 1    | 16                                              |
| 1    | 1    | 0    | 20                                              |
| 1    | 1    | 1    | 24                                              |

MC9S12G Family Reference Manual Rev.1.27

# 15.3.2.10 ATD Input Enable Register (ATDDIEN)

Module Base + 0x000C



Figure 15-12. ATD Input Enable Register (ATDDIEN)

### Read: Anytime

Write: Anytime

### Table 15-19. ATDDIEN Field Descriptions

| Field             | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
|-------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 15–0<br>IEN[15:0] | <ul> <li>ATD Digital Input Enable on channel x (x= 15, 14, 13, 12, 11, 10, 9, 8, 7, 6, 5, 4, 3, 2, 1, 0) — This bit controls the digital input buffer from the analog input pin (ANx) to the digital data register.</li> <li>0 Disable digital input buffer to ANx pin</li> <li>1 Enable digital input buffer on ANx pin.</li> <li>Note: Setting this bit will enable the corresponding digital input buffer continuously. If this bit is set while simultaneously using it as an analog port, there is potentially increased power consumption because the digital input buffer maybe in the linear region.</li> </ul> |

# 15.3.2.11 ATD Compare Higher Than Register (ATDCMPHT)

Writes to this register will abort current conversion sequence.

### Read: Anytime

Write: Anytime

Module Base + 0x000E



### Figure 15-13. ATD Compare Higher Than Register (ATDCMPHT)

### Table 15-20. ATDCMPHT Field Descriptions

| Field       | Description                                                                                                                   |
|-------------|-------------------------------------------------------------------------------------------------------------------------------|
| 15–0        | Compare Operation Higher Than Enable for conversion number <i>n</i> ( <i>n</i> = 15, 14, 13, 12, 11, 10, 9, 8, 7, 6, 5,       |
| CMPHT[15:0] | 4, 3, 2, 1, 0) of a Sequence (n conversion number, NOT channel number!) — This bit selects the operator                       |
|             | for comparison of conversion results.                                                                                         |
|             | 0 If result of conversion <i>n</i> is <b>lower or same than</b> compare value in ATDDR <i>n</i> , this is flagged in ATDSTAT2 |
|             | 1 If result of conversion <i>n</i> is <b>higher than</b> compare value in ATDDR <i>n</i> , this is flagged in ATDSTAT2        |

#### MC9S12G Family Reference Manual Rev.1.27

# 18.3.2.17 MSCAN Identifier Acceptance Registers (CANIDAR0-7)

On reception, each message is written into the background receive buffer. The CPU is only signalled to read the message if it passes the criteria in the identifier acceptance and identifier mask registers (accepted); otherwise, the message is overwritten by the next message (dropped).

The acceptance registers of the MSCAN are applied on the IDR0–IDR3 registers (see Section 18.3.3.1, "Identifier Registers (IDR0–IDR3)") of incoming messages in a bit by bit manner (see Section 18.4.3, "Identifier Acceptance Filter").

For extended identifiers, all four acceptance and mask registers are applied. For standard identifiers, only the first two (CANIDAR0/1, CANIDMR0/1) are applied.

Module Base + 0x0010 to Module Base + 0x0013

Access: User read/write<sup>1</sup>

Access: User read/write<sup>1</sup>

|        | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|--------|-----|-----|-----|-----|-----|-----|-----|-----|
| R<br>W | AC7 | AC6 | AC5 | AC4 | AC3 | AC2 | AC1 | AC0 |
| Reset  | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

#### Figure 18-20. MSCAN Identifier Acceptance Registers (First Bank) — CANIDAR0–CANIDAR3

<sup>1</sup> Read: Anytime

Write: Anytime in initialization mode (INITRQ = 1 and INITAK = 1)

#### Table 18-22. CANIDAR0–CANIDAR3 Register Field Descriptions

| Field          | Description                                                                                                                                                                                                                                                                                   |
|----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-0<br>AC[7:0] | Acceptance Code Bits — AC[7:0] comprise a user-defined sequence of bits with which the corresponding bits of the related identifier register (IDRn) of the receive message buffer are compared. The result of this comparison is then masked with the corresponding identifier mask register. |

Module Base + 0x0018 to Module Base + 0x001B

|        | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|--------|-----|-----|-----|-----|-----|-----|-----|-----|
| R<br>W | AC7 | AC6 | AC5 | AC4 | AC3 | AC2 | AC1 | AC0 |
| Reset  | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |

#### Figure 18-21. MSCAN Identifier Acceptance Registers (Second Bank) — CANIDAR4–CANIDAR7

<sup>1</sup> Read: Anytime

Write: Anytime in initialization mode (INITRQ = 1 and INITAK = 1)

#### Scalable Controller Area Network (S12MSCANV3)

In cases of more than one buffer having the same lowest priority, the message buffer with the lower index number wins.



Figure 18-36. Transmit Buffer Priority Register (TBPR)

<sup>1</sup> Read: Anytime when TXEx flag is set (see Section 18.3.2.7, "MSCAN Transmitter Flag Register (CANTFLG)") and the corresponding transmit buffer is selected in CANTBSEL (see Section 18.3.2.11, "MSCAN Transmit Buffer Selection Register (CANTBSEL)")

Write: Anytime when TXEx flag is set (see Section 18.3.2.7, "MSCAN Transmitter Flag Register (CANTFLG)") and the corresponding transmit buffer is selected in CANTBSEL (see Section 18.3.2.11, "MSCAN Transmit Buffer Selection Register (CANTBSEL)")

## 18.3.3.5 Time Stamp Register (TSRH–TSRL)

If the TIME bit is enabled, the MSCAN will write a time stamp to the respective registers in the active transmit or receive buffer right after the EOF of a valid message on the CAN bus (see Section 18.3.2.1, "MSCAN Control Register 0 (CANCTL0)"). In case of a transmission, the CPU can only read the time stamp after the respective transmit buffer has been flagged empty.

The timer value, which is used for stamping, is taken from a free running internal CAN bit clock. A timer overrun is not indicated by the MSCAN. The timer is reset (all bits set to 0) during initialization mode. The CPU can only read the time stamp registers.

| Module Base · | + 0x00XE |       |       |       |       |       | Access: Us | er read/write <sup>1</sup> |
|---------------|----------|-------|-------|-------|-------|-------|------------|----------------------------|
| _             | 7        | 6     | 5     | 4     | 3     | 2     | 1          | 0                          |
| R             | TSR15    | TSR14 | TSR13 | TSR12 | TSR11 | TSR10 | TSR9       | TSR8                       |
| w             |          |       |       |       |       |       |            |                            |
| Reset:        | х        | х     | х     | х     | х     | х     | х          | х                          |
|               |          | -     |       |       |       |       |            |                            |



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

# 20.3.1 Module Memory Map and Register Definition

The memory map for the SCI module is given below in Figure 20-2. The address listed for each register is the address offset. The total address for each register is the sum of the base address for the SCI module and the address offset for each register.

# 20.3.2 Register Descriptions

This section consists of register descriptions in address order. Each description includes a standard register diagram with an associated figure number. Writes to a reserved register locations do not have any effect and reads of these locations return a zero. Details of register bit and field function follow the register diagrams, in bit order.

| Register<br>Name               |        | Bit 7   | 6          | 5             | 4     | 3     | 2      | 1      | Bit 0 |
|--------------------------------|--------|---------|------------|---------------|-------|-------|--------|--------|-------|
| 0x0000<br>SCIBDH <sup>1</sup>  | R<br>W | IREN    | TNP1       | TNP0          | SBR12 | SBR11 | SBR10  | SBR9   | SBR8  |
| 0x0001<br>SCIBDL <sup>1</sup>  | R<br>W | SBR7    | SBR6       | SBR5          | SBR4  | SBR3  | SBR2   | SBR1   | SBR0  |
| 0x0002<br>SCICR1 <sup>1</sup>  | R<br>W | LOOPS   | SCISWAI    | RSRC          | М     | WAKE  | ILT    | PE     | PT    |
| 0x0000<br>SCIASR1 <sup>2</sup> | R<br>W | RXEDGIF | 0          | 0             | 0     | 0     | BERRV  | BERRIF | BKDIF |
| 0x0001<br>SCIACR1 <sup>2</sup> | R<br>W | RXEDGIE | 0          | 0             | 0     | 0     | 0      | BERRIE | BKDIE |
| 0x0002<br>SCIACR2 <sup>2</sup> | R<br>W | 0       | 0          | 0             | 0     | 0     | BERRM1 | BERRM0 | BKDFE |
| 0x0003<br>SCICR2               | R<br>W | TIE     | TCIE       | RIE           | ILIE  | TE    | RE     | RWU    | SBK   |
| 0x0004                         | R      | TDRE    | TC         | RDRF          | IDLE  | OR    | NF     | FE     | PF    |
| SCISR1                         | W      |         |            |               |       |       |        |        |       |
| 0x0005<br>SCISR2               | R<br>W | AMAP    | 0          | 0             | TXPOL | RXPOL | BRK13  | TXDIR  | RAF   |
|                                | [      |         | = Unimplem | ented or Rese | erved |       |        |        |       |



MC9S12G Family Reference Manual Rev.1.27

Serial Communication Interface (S12SCIV5)



Figure 20-25 shows the effect of noise early in the start bit time. Although this noise does not affect proper synchronization with the start bit time, it does set the noise flag.



Figure 20-26 shows a burst of noise near the beginning of the start bit that resets the RT clock. The sample after the reset is low but is not preceded by three high samples that would qualify as a falling edge. Depending on the timing of the start bit search and on the data, the frame may be missed entirely or it may set the framing error flag.

### 20.5.3.1.8 BKDIF Description

The BKDIF interrupt is set when a break signal was received. Clear BKDIF by writing a "1" to the SCIASR1 SCI alternative status register 1. This flag is also cleared if break detect feature is disabled.

# 20.5.4 Recovery from Wait Mode

The SCI interrupt request can be used to bring the CPU out of wait mode.

# 20.5.5 Recovery from Stop Mode

An active edge on the receive input can be used to bring the CPU out of stop mode.

# 22.3.2.13 Output Compare Pin Disconnect Register(OCPD)

Module Base + 0x002C



#### Read: Anytime

Write: Anytime

All bits reset to zero.

### Table 22-15. OCPD Field Description

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

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

## 22.3.2.14 Precision Timer Prescaler Select Register (PTPSR)

Module Base + 0x002E

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



Read: Anytime

Write: Anytime

All bits reset to zero.

| Register | Error Bit | Error Condition                                                                     |
|----------|-----------|-------------------------------------------------------------------------------------|
|          |           | Set if CCOBIX[2:0] != 101 at command launch                                         |
|          | ACCERR    | Set if command not available in current mode (see Table 24-25)                      |
|          | ACCERR    | Set if an invalid phrase index is supplied                                          |
| FSTAT    |           | Set if the requested phrase has already been programmed <sup>1</sup>                |
|          | FPVIOL    | None                                                                                |
|          | MGSTAT1   | Set if any errors have been encountered during the verify operation                 |
|          | MGSTAT0   | Set if any non-correctable errors have been encountered during the verify operation |

Table 24-41. Program Once Command Error Handling

### 24.4.6.7 Erase All Blocks Command

The Erase All Blocks operation will erase the entire P-Flash and EEPROM memory space.

#### Table 24-42. Erase All Blocks Command FCCOB Requirements

| CCOBIX[2:0] | FCCOB P | arameters    |
|-------------|---------|--------------|
| 000         | 0x08    | Not required |

Upon clearing CCIF to launch the Erase All Blocks command, the Memory Controller will erase the entire Flash memory space and verify that it is erased. If the Memory Controller verifies that the entire Flash memory space was properly erased, security will be released. During the execution of this command (CCIF=0) the user must not write to any Flash module register. The CCIF flag will set after the Erase All Blocks operation has completed.

| Register | Error Bit | Error Condition                                                                                  |
|----------|-----------|--------------------------------------------------------------------------------------------------|
|          |           | Set if CCOBIX[2:0] != 000 at command launch                                                      |
|          | ACCERK    | Set if command not available in current mode (see Table 24-25)                                   |
| FSTAT    | FPVIOL    | Set if any area of the P-Flash or EEPROM memory is protected                                     |
| _        | MGSTAT1   | Set if any errors have been encountered during the verify operation <sup>1</sup>                 |
|          | MGSTAT0   | Set if any non-correctable errors have been encountered during the verify operation <sup>1</sup> |

<sup>1</sup> As found in the memory map for FTMRG32K1.

### 24.4.6.8 Erase Flash Block Command

The Erase Flash Block operation will erase all addresses in a P-Flash or EEPROM block.

MC9S12G Family Reference Manual Rev.1.27

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

#### Table 27-25. FOPT Field Descriptions

### 27.3.2.17 Flash Reserved5 Register (FRSV5)

This Flash register is reserved for factory testing.



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

### 27.3.2.18 Flash Reserved6 Register (FRSV6)

This Flash register is reserved for factory testing.



#### Figure 27-24. Flash Reserved6 Register (FRSV6)

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

### 27.3.2.19 Flash Reserved7 Register (FRSV7)

This Flash register is reserved for factory testing.

#### 240 KByte Flash Module (S12FTMRG240K2V1)

indicated by reset condition F in Figure 31-6. If a double bit fault is detected while reading the P-Flash phrase containing the Flash security byte during the reset sequence, all bits in the FSEC register will be set to leave the Flash module in a secured state with backdoor key access disabled.

| Table 31-9. | . FSEC Field | d Descriptions |
|-------------|--------------|----------------|
|-------------|--------------|----------------|

| Field             | Description                                                                                                                                                                                      |
|-------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–6<br>KEYEN[1:0] | <b>Backdoor Key Security Enable Bits</b> — The KEYEN[1:0] bits define the enabling of backdoor key access to the Flash module as shown in Table 31-10.                                           |
| 5–2<br>RNV[5:2]   | <b>Reserved Nonvolatile Bits</b> — The RNV bits should remain in the erased state for future enhancements.                                                                                       |
| 1–0<br>SEC[1:0]   | Flash Security Bits — The SEC[1:0] bits define the security state of the MCU as shown in Table 31-11. If the Flash module is unsecured using backdoor key access, the SEC bits are forced to 10. |

#### Table 31-10. Flash KEYEN States

| KEYEN[1:0] | Status of Backdoor Key Access |
|------------|-------------------------------|
| 00         | DISABLED                      |
| 01         | DISABLED <sup>1</sup>         |
| 10         | ENABLED                       |
| 11         | DISABLED                      |

<sup>1</sup> Preferred KEYEN state to disable backdoor key access.

#### Table 31-11. Flash Security States

| SEC[1:0] | Status of Security   |
|----------|----------------------|
| 00       | SECURED              |
| 01       | SECURED <sup>1</sup> |
| 10       | UNSECURED            |
| 11       | SECURED              |
|          |                      |

Preferred SEC state to set MCU to secured state.

The security function in the Flash module is described in Section 31.5.

## 31.3.2.3 Flash CCOB Index Register (FCCOBIX)

The FCCOBIX register is used to index the FCCOB register for Flash memory operations.

6 5 3 2 1 0 7 4 0 0 0 R 0 0 CCOBIX[2:0] W 0 Reset 0 0 0 0 0 0 0 = Unimplemented or Reserved Figure 31-7. FCCOB Index Register (FCCOBIX)

MC9S12G Family Reference Manual Rev.1.27

Offset Module Base + 0x0002

| Field            | Description                                                                                                                                                                                                                                                                        |
|------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 2<br>FPLDIS      | Flash Protection Lower Address Range Disable — The FPLDIS bit determines whether there is a<br>protected/unprotected area in a specific region of the P-Flash memory beginning with global address 0x3_8000.0Protection/Unprotection enabled<br>11Protection/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 31-20. The FPLS bits can only be written to while the FPLDIS bit is set.                                                       |

#### Table 31-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 31-18. P-Flash Protection Function

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

#### Table 31-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 31-20. P-Flash Protection Lower Address Range

| FPLS[1:0] | Global Address Range | 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 31-14. Although 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 single chip mode while providing as much protection as possible if reprogramming is not required.

 $^2$  These values include the quantization error which is inherently 1/2 count for any A/D converter.

#### Table A-26. ADC Conversion Performance 3.3V range (Junction Temperature From +150°C To +160°C)

| S12GNA16, S12GNA32                                                                                                                                                                                                                                            |   |                             |        |        |     |       |     |        |
|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---|-----------------------------|--------|--------|-----|-------|-----|--------|
| Supply voltage $3.13V < V_{DDA} < 4.5 V$ , $150^{\circ}C < T_{J} < 160^{\circ}C$ , $V_{REF} = V_{RH} - V_{RL} = V_{DDA}$ , $f_{ADCCLK} = 8.0MHz$<br>The values are tested to be valid with no port AD output drivers switching simultaneous with conversions. |   |                             |        |        |     |       |     |        |
| Num                                                                                                                                                                                                                                                           | С | Rating <sup>1</sup>         |        | Symbol | Min | Тур   | Мах | Unit   |
| 1                                                                                                                                                                                                                                                             | М | Resolution                  | 12-Bit | LSB    |     | 0.80  |     | mV     |
| 2                                                                                                                                                                                                                                                             | М | Differential Nonlinearity   | 12-Bit | DNL    |     | ±3    |     | counts |
| 3                                                                                                                                                                                                                                                             | Μ | Integral Nonlinearity       | 12-Bit | INL    |     | ±3    |     | counts |
| 4                                                                                                                                                                                                                                                             | Μ | Absolute Error <sup>2</sup> | 12-Bit | AE     |     | ±4    |     | counts |
| 5                                                                                                                                                                                                                                                             | С | Resolution                  | 10-Bit | LSB    |     | 3.22  |     | mV     |
| 6                                                                                                                                                                                                                                                             | С | Differential Nonlinearity   | 10-Bit | DNL    |     | ±1    |     | counts |
| 7                                                                                                                                                                                                                                                             | С | Integral Nonlinearity       | 10-Bit | INL    |     | ±1    |     | counts |
| 8                                                                                                                                                                                                                                                             | С | Absolute Error <sup>2</sup> | 10-Bit | AE     |     | ±2    |     | counts |
| 9                                                                                                                                                                                                                                                             | С | Resolution                  | 8-Bit  | LSB    |     | 12.89 |     | mV     |
| 10                                                                                                                                                                                                                                                            | С | Differential Nonlinearity   | 8-Bit  | DNL    |     | ±0.3  |     | counts |
| 11                                                                                                                                                                                                                                                            | С | Integral Nonlinearity       | 8-Bit  | INL    |     | ±0.5  |     | counts |
| 12                                                                                                                                                                                                                                                            | С | Absolute Error <sup>2</sup> | 8-Bit  | AE     |     | ±1    |     | counts |

<sup>1</sup> The 8-bit and 10-bit mode operation is structurally tested in production test. Absolute values are tested in 12-bit mode.

 $^2$  These values include the quantization error which is inherently 1/2 count for any A/D converter.

#### Table A-27. ADC Conversion Performance 3.3V range (Junction Temperature From -40°C To +150°C)

| Num C Rating <sup>1</sup> Symbol Min Typ Max U                                   |                                                                                                                                                                                                                                                   |  |  |  |  |  |  |  |
|----------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|--|--|
| Supply<br>The va                                                                 | Supply voltage 3.13V < $V_{DDA}$ < 4.5 V, -40°C < $T_J$ < 150°C, $V_{REF}$ = $V_{RH}$ - $V_{RL}$ = $V_{DDA}$ , $f_{ADCCLK}$ = 8.0MHz<br>The values are tested to be valid with no port AD output drivers switching simultaneous with conversions. |  |  |  |  |  |  |  |
| S12GN16, S12GN32, S12GN48, S12G48, S12G64, S12G96, S12G128, S12G192, and S12G240 |                                                                                                                                                                                                                                                   |  |  |  |  |  |  |  |

| Num | С | Rating <sup>1</sup>         |                                            | Symbol | Min      | Тур      | Max    | Unit   |
|-----|---|-----------------------------|--------------------------------------------|--------|----------|----------|--------|--------|
| 1   | Ρ | Resolution                  | 10-Bit                                     | LSB    |          | 3.22     |        | mV     |
| 2   | Ρ | Differential Nonlinearity   | 10-Bit                                     | DNL    | -1.5     | ±1       | 1.5    | counts |
| 3   | Ρ | Integral Nonlinearity       | 10-Bit                                     | INL    | -2       | ±1       | 2      | counts |
| 4   | Ρ | Absolute Error <sup>2</sup> | 10-Bit <sup>3</sup><br>10-Bit <sup>4</sup> | AE     | -3<br>-4 | ±2<br>±2 | 3<br>4 | counts |
| 5   | С | Resolution                  | 8-Bit                                      | LSB    |          | 12.89    |        | mV     |
| 6   | С | Differential Nonlinearity   | 8-Bit                                      | DNL    | -0.5     | ±0.3     | 0.5    | counts |
| 7   | С | Integral Nonlinearity       | 8-Bit                                      | INL    | -1       | ±0.5     | 1      | counts |
| 8   | С | Absolute Error <sup>2</sup> | 8-Bit                                      | AE     | -1.5     | ±1       | 1.5    | counts |

#### Table A-33. Static Electrical Characteristics

Characteristics noted under conditions 3.13V <= VDDA <= 5.5V>, -40°C < Tj < 150°C >, VRH=VDDA, VRL=VSSA unless otherwise noted. Typical values noted reflect the approximate parameter mean at  $T_A = 25$ °C under nominal conditions unless otherwise noted.

| Num | С | Ratings                                                                                                                                                                                                                                                                    | Symbol                       | Min                   | Тур  | Мах       | Unit |
|-----|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------|-----------------------|------|-----------|------|
| 8   | С | Output Voltage unbuffered range A or B (load >= $50M\Omega$ )                                                                                                                                                                                                              | V <sub>out</sub>             | full DAC Range A or B |      |           | v    |
| 9   | Ρ | Output Voltage (DRIVE bit = 0) <sup>1</sup><br>buffered range A (load >= 100K $\Omega$ to VSSA)<br>buffered range A (load >= 100K $\Omega$ to VDDA)                                                                                                                        | 0 - VDDA-0.15<br>0.15 - VDDA |                       | v    |           |      |
|     |   | buffered range B (load >= 100K $\Omega$ to VSSA)<br>buffered range B (load >= 100K $\Omega$ to VDDA)                                                                                                                                                                       | • out                        | full DAC Range B      |      |           |      |
| 10  | Ρ | Output Voltage (DRIVE bit = 1) <sup>2</sup><br>buffered range B with $6.4K\Omega$ load into resistor<br>divider of $800\Omega$ / $6.56K\Omega$ between VDDA and<br>VSSA.<br>(equivalent load is >= $65K\Omega$ to VSSA) or<br>(equivalent load is >= $7.5K\Omega$ to VDDA) | V <sub>out</sub>             | full DAC Range B      |      |           | V    |
| 11  | D | Buffer Output Capacitive load                                                                                                                                                                                                                                              | C <sub>load</sub>            | 0                     | -    | 100       | pF   |
| 12  | Р | Buffer Output Offset                                                                                                                                                                                                                                                       | V <sub>offset</sub>          | -30 - +30             |      | mV        |      |
| 13  | Ρ | Settling time                                                                                                                                                                                                                                                              | t <sub>delay</sub>           | -                     | 3    | 5         | μS   |
| 14  | D | Reverence voltage high                                                                                                                                                                                                                                                     | V <sub>refh</sub>            | VDDA-0.1V             | VDDA | VDDA+0.1V | V    |

<sup>1</sup> DRIVE bit = 1 is not recommended in this case.

<sup>2</sup> DRIVE bit = 0 is not allowed with this high load.

# A.7 NVM

# A.7.1 Timing Parameters

The time base for all NVM program or erase operations is derived from the bus clock using the FCLKDIV register. The frequency of this derived clock must be set within the limits specified as  $f_{NVMOP}$ . The NVM module does not have any means to monitor the frequency and will not prevent program or erase operation at frequencies above or below the specified minimum. When attempting to program or erase the NVM module at a lower frequency, a full program or erase transition is not assured.

All timing parameters are a function of the bus clock frequency, fNVMBUS. All program and erase times are also a function of the NVM operating frequency,  $f_{NVMOP}$