



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        | 128KB (128K x 8)                                                        |
| Program Memory Type        | FLASH                                                                   |
| EEPROM Size                | 4K x 8                                                                  |
| RAM Size                   | 8K x 8                                                                  |
| Voltage - Supply (Vcc/Vdd) | 3.13V ~ 5.5V                                                            |
| Data Converters            | A/D 12x12b                                                              |
| Oscillator Type            | Internal                                                                |
| Operating Temperature      | -40°C ~ 125°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/s9s12ga128f0mlf |

Email: info@E-XFL.COM

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

**Device Overview MC9S12G-Family** 

#### 1.8.2 S12GNA16 and S12GNA32

#### 1.8.2.1 Pinout 48-Pin LQFP/QFN



Figure 1-6. 48-Pin LQFP/QFN Pinout for S12GNA16 and S12GNA32

| Table 1-11. | 48-Pin LQFP/QFN | Pinout for S12 | GNA16 and S12GN | A32 |
|-------------|-----------------|----------------|-----------------|-----|
|-------------|-----------------|----------------|-----------------|-----|

|             |       | <lowest< th=""><th>Function</th><th>Power</th><th>Internal P<br/>Resisto</th><th>ull<br/>r</th></lowest<> | Function     | Power       | Internal P<br>Resisto | ull<br>r         |        |                |  |  |
|-------------|-------|-----------------------------------------------------------------------------------------------------------|--------------|-------------|-----------------------|------------------|--------|----------------|--|--|
| Package Pin | Pin   | 2nd<br>Func.                                                                                              | 3rd<br>Func. | 4th<br>Func | 5th<br>Func           | Supply           | CTRL   | Reset<br>State |  |  |
| 1           | RESET | —                                                                                                         | —            | —           | —                     | V <sub>DDX</sub> | PULLUF | PULLUP         |  |  |

MC9S12G Family Reference Manual Rev.1.27

|             |     | <lowest< th=""><th>Function<br/>PRIORITY</th><th>Power</th><th colspan="3">Internal Pull<br/>Resistor</th></lowest<> | Function<br>PRIORITY | Power       | Internal Pull<br>Resistor |                  |           |                |
|-------------|-----|----------------------------------------------------------------------------------------------------------------------|----------------------|-------------|---------------------------|------------------|-----------|----------------|
| Package Pin | Pin | 2nd<br>Func.                                                                                                         | 3rd<br>Func.         | 4th<br>Func | 5th<br>Func               | Supply           | CTRL      | Reset<br>State |
| 57          | PS5 | MOSI0                                                                                                                | —                    | —           | —                         | V <sub>DDX</sub> | PERS/PPSS | Up             |
| 58          | PS6 | SCK0                                                                                                                 | —                    | —           | —                         | V <sub>DDX</sub> | PERS/PPSS | Up             |
| 59          | PS7 | API_EXTC<br>LK                                                                                                       | ECLK                 | SS0         | —                         | V <sub>DDX</sub> | PERS/PPSS | Up             |
| 60          | PM0 | RXCAN                                                                                                                | —                    | —           | —                         | V <sub>DDX</sub> | PERM/PPSM | Disabled       |
| 61          | PM1 | TXCAN                                                                                                                | —                    | —           | —                         | V <sub>DDX</sub> | PERM/PPSM | Disabled       |
| 62          | PM2 | RXD2                                                                                                                 | —                    | —           | —                         | V <sub>DDX</sub> | PERM/PPSM | Disabled       |
| 63          | PM3 | TXD2                                                                                                                 | —                    |             | —                         | V <sub>DDX</sub> | PERM/PPSM | Disabled       |
| 64          | PJ7 | KWJ7                                                                                                                 | SS2                  | —           | —                         | V <sub>DDX</sub> | PERJ/PPSJ | Up             |

<sup>1</sup> The regular I/O characteristics (see Section A.2, "I/O Characteristics") apply if the EXTAL/XTAL function is disabled

|             | < (              | Fund<br>owestPRIO | c <b>tion</b><br>RITYhighe | Power        | Internal P<br>Resisto | Pull<br>r  |                |
|-------------|------------------|-------------------|----------------------------|--------------|-----------------------|------------|----------------|
| Package Pin | Pin              | 2nd<br>Func.      | 3rd<br>Func.               | 4th<br>Func. | Supply                | CTRL       | Reset<br>State |
| 1           | PJ6              | KWJ6              | SCK2                       | —            | V <sub>DDX</sub>      | PERJ/PPSJ  | Up             |
| 2           | PJ5              | KWJ5              | MOSI2                      | —            | V <sub>DDX</sub>      | PERJ/PPSJ  | Up             |
| 3           | PJ4              | KWJ4              | MISO2                      | _            | V <sub>DDX</sub>      | PERJ/PPSJ  | Up             |
| 4           | PA0              | —                 | _                          | _            | V <sub>DDX</sub>      | PUCR/PUPAE | Disabled       |
| 5           | PA1              | —                 | _                          | _            | V <sub>DDX</sub>      | PUCR/PUPAE | Disabled       |
| 6           | PA2              | —                 | _                          | _            | V <sub>DDX</sub>      | PUCR/PUPAE | Disabled       |
| 7           | PA3              | —                 | _                          | _            | V <sub>DDX</sub>      | PUCR/PUPAE | Disabled       |
| 8           | RESET            | —                 | _                          | _            | V <sub>DDX</sub>      | PULLUF     | 5              |
| 9           | VDDX1            | —                 | _                          | _            | —                     | _          | —              |
| 10          | VDDR             | —                 | _                          | _            | —                     | _          | —              |
| 11          | VSSX1            | —                 | _                          | _            | —                     | _          | —              |
| 12          | PE0 <sup>1</sup> | EXTAL             | _                          | _            | V <sub>DDX</sub>      | PUCR/PDPEE | Down           |
| 13          | VSS              | —                 | _                          | _            | —                     | _          | —              |
| 14          | PE1 <sup>1</sup> | XTAL              | _                          | _            | V <sub>DDX</sub>      | PUCR/PDPEE | Down           |
| 15          | TEST             | —                 | _                          | _            | N.A.                  | RESET pin  | Down           |
| 16          | PA4              | —                 | _                          | _            | V <sub>DDX</sub>      | PUCR/PUPAE | Disabled       |
| 17          | PA5              | —                 | _                          | _            | V <sub>DDX</sub>      | PUCR/PUPAE | Disabled       |
| 18          | PA6              | —                 | _                          | _            | V <sub>DDX</sub>      | PUCR/PUPAE | Disabled       |
| 19          | PA7              | —                 | _                          | _            | V <sub>DDX</sub>      | PUCR/PUPAE | Disabled       |
| 20          | PJ0              | KWJ0              | MISO1                      | _            | V <sub>DDX</sub>      | PERJ/PPSJ  | Up             |
| 21          | PJ1              | KWJ1              | MOSI1                      | _            | V <sub>DDX</sub>      | PERJ/PPSJ  | Up             |
| 22          | PJ2              | KWJ2              | SCK1                       | _            | V <sub>DDX</sub>      | PERJ/PPSJ  | Up             |
| 23          | PJ3              | KWJ3              | SS1                        | _            | V <sub>DDX</sub>      | PERJ/PPSJ  | Up             |
| 24          | BKGD             | MODC              |                            |              | V <sub>DDX</sub>      | PUCR/BKPUE | Up             |
| 25          | PB0              | ECLK              | _                          |              | V <sub>DDX</sub>      | PUCR/PUPBE | Disabled       |
| 26          | PB1              | API_EXTC<br>LK    |                            |              | V <sub>DDX</sub>      | PUCR/PUPBE | Disabled       |
| 27          | PB2              | ECLKX2            | —                          |              | V <sub>DDX</sub>      | PUCR/PUPBE | Disabled       |

Table 1-31. 100-Pin LQFP Pinout for S12GA192 and S12GA240

#### Port Integration Module (S12GPIMV1)

| Global Address<br>Register Name |        | Bit 7   | 6                           | 5       | 4       | 3       | 2       | 1       | Bit 0   |  |  |
|---------------------------------|--------|---------|-----------------------------|---------|---------|---------|---------|---------|---------|--|--|
| 0x027B<br>PPS1AD                | R<br>W | PPS1AD7 | PPS1AD6                     | PPS1AD5 | PPS1AD4 | PPS1AD3 | PPS1AD2 | PPS1AD1 | PPS1AD0 |  |  |
| 0x027C<br>PIE0AD                | R<br>W | PIE0AD7 | PIE0AD6                     | PIE0AD5 | PIE0AD4 | PIE0AD3 | PIE0AD2 | PIE0AD1 | PIE0AD0 |  |  |
| 0x027D<br>PIE1AD                | R<br>W | PIE1AD7 | PIE1AD6                     | PIE1AD5 | PIE1AD4 | PIE1AD3 | PIE1AD2 | PIE1AD1 | PIE1AD0 |  |  |
| 0x027E<br>PIF0AD                | R<br>W | PIF0AD7 | PIF0AD6                     | PIF0AD5 | PIF0AD4 | PIF0AD3 | PIF0AD2 | PIF0AD1 | PIF0AD0 |  |  |
| 0x027F<br>PIF1AD                | R<br>W | PIF1AD7 | PIF1AD6                     | PIF1AD5 | PIF1AD4 | PIF1AD3 | PIF1AD2 | PIF1AD1 | PIF1AD0 |  |  |
|                                 |        |         | = Unimplemented or Reserved |         |         |         |         |         |         |  |  |

#### Table 2-20. Block Register Map (G2) (continued)

# 2.4.2.3 Block Register Map (G3)

### Table 2-21. Block Register Map (G3)

| Global Address<br>Register Name           |        | Bit 7 | 6          | 5            | 4          | 3           | 2 | 1     | Bit 0 |
|-------------------------------------------|--------|-------|------------|--------------|------------|-------------|---|-------|-------|
| 0x0000–0x0007                             | R      | 0     | 0          | 0            | 0          | 0           | 0 | 0     | 0     |
| Reserved                                  | W      |       |            |              |            |             |   |       |       |
| 0x0008                                    | R      | 0     | 0          | 0            | 0          | 0           | 0 |       | DEO   |
| PORTE                                     | W      |       |            |              |            |             |   | PEI   | PEU   |
| 0x0009                                    | R      | 0     | 0          | 0            | 0          | 0           | 0 |       |       |
| DDRE                                      | W      |       |            |              |            |             |   | DDRE1 | DDREU |
| 0x000A–0x000B<br>Non-PIM<br>Address Range | R<br>W |       |            |              | Non-PIM Ad | dress Range |   |       |       |
| 0x000C                                    | R      | 0     | DKDUE      | 0            | DDDEE      | 0           | 0 | 0     | 0     |
| PUCR                                      | W      |       | BKPUE      |              | PDPEE      |             |   |       |       |
| 0x000D                                    | R      | 0     | 0          | 0            | 0          | 0           | 0 | 0     | 0     |
| Reserved                                  | W      |       |            |              |            |             |   |       |       |
|                                           |        |       | = Unimplem | nented or Re | served     |             |   |       |       |

| Field     | Description                                                                                                                                                                                                    |
|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-0<br>PC | <b>Port C general-purpose input/output data</b> —Data Register<br>The associated pin can be used as general-purpose I/O. In general-purpose output mode the port data register bit value is driven to the pin. |
|           | If the associated data direction bit is set to 1, a read returns the value of the port data register bit, otherwise the buffered pin input state is read.                                                      |

### Table 2-26. PORTC Register Field Descriptions

## 2.4.3.6 Port D Data Register (PORTD)

Address 0x0005 (G1)

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

|                                              | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
|----------------------------------------------|-----|-----|-----|-----|-----|-----|-----|-----|
| R<br>W                                       | PD7 | PD6 | PD5 | PD4 | PD3 | PD2 | PD1 | PD0 |
| Reset                                        | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| Address 0x0005 (G2, G3) Access: User read or |     |     |     |     |     |     |     |     |
|                                              | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |
| R                                            | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
| W                                            |     |     |     |     |     |     |     |     |
| Reset                                        | 0   | 0   | 0   | 0   | 0   | 0   | 0   | 0   |
|                                              |     |     |     |     |     |     |     |     |

T

Figure 2-7. Port D Data Register (PORTD)

<sup>1</sup> Read: Anytime. The data source is depending on the data direction value. Write: Anytime

#### Table 2-27. PORTD Register Field Descriptions

| Field | Description                                                                                                                                                                                                                                                          |
|-------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-0   | Port D general-purpose input/output data—Data Register                                                                                                                                                                                                               |
| PD    | The associated pin can be used as general-purpose I/O. In general-purpose output mode the port data register bit value is driven to the pin. If the associated data direction bit is set to 1, a read returns the value of the port data register bit, otherwise the |
|       | buffered pin input state is read.                                                                                                                                                                                                                                    |

### 8.3.2.8.3 Debug Comparator Address Mid Register (DBGXAM)

Address: 0x002A

|        | 7      | 6      | 5      | 4      | 3      | 2      | 1     | 0     |
|--------|--------|--------|--------|--------|--------|--------|-------|-------|
| R<br>W | Bit 15 | Bit 14 | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 |
| Reset  | 0      | 0      | 0      | 0      | 0      | 0      | 0     | 0     |

Figure 8-17. Debug Comparator Address Mid Register (DBGXAM)

Read: Anytime. See Table 8-24 for visible register encoding.

Write: If DBG not armed. See Table 8-24 for visible register encoding.

 Table 8-26. DBGXAM Field Descriptions

| Field            | Description                                                                                                                                                                                                                                                                                                                       |
|------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–0<br>Bit[15:8] | <ul> <li>Comparator Address Mid Compare Bits — The Comparator address mid compare bits control whether the selected comparator compares the address bus bits [15:8] to a logic one or logic zero.</li> <li>Compare corresponding address bit to a logic zero</li> <li>Compare corresponding address bit to a logic one</li> </ul> |

### 8.3.2.8.4 Debug Comparator Address Low Register (DBGXAL)

Address: 0x002B



Figure 8-18. Debug Comparator Address Low Register (DBGXAL)

Read: Anytime. See Table 8-24 for visible register encoding.

Write: If DBG not armed. See Table 8-24 for visible register encoding.

### Table 8-27. DBGXAL Field Descriptions

| Field            | Description                                                                                                                                                                                                                                                                                                                      |
|------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–0<br>Bits[7:0] | <ul> <li>Comparator Address Low Compare Bits — The Comparator address low compare bits control whether the selected comparator compares the address bus bits [7:0] to a logic one or logic zero.</li> <li>Compare corresponding address bit to a logic zero</li> <li>Compare corresponding address bit to a logic one</li> </ul> |

# 8.4.1 S12SDBG Operation

Arming the DBG module by setting ARM in DBGC1 allows triggering the state sequencer, storing of data in the trace buffer and generation of breakpoints to the CPU. The DBG module is made up of four main blocks, the comparators, control logic, the state sequencer, and the trace buffer.

The comparators monitor the bus activity of the CPU. All comparators can be configured to monitor address bus activity. Comparator A can also be configured to monitor databus activity and mask out individual data bus bits during a compare. Comparators can be configured to use R/W and word/byte access qualification in the comparison. A match with a comparator register value can initiate a state sequencer transition to another state (see Figure 8-24). Either forced or tagged matches are possible. Using a forced match, a state sequencer transition can occur immediately on a successful match of system busses and comparator registers. Whilst tagging, at a comparator match, the instruction opcode is tagged and only if the instruction reaches the execution stage of the instruction queue can a state sequencer transition occur. In the case of a transition to Final State, bus tracing is triggered and/or a breakpoint can be generated.

A state sequencer transition to final state (with associated breakpoint, if enabled) can be initiated by writing to the TRIG bit in the DBGC1 control register.

The trace buffer is visible through a 2-byte window in the register address map and must be read out using standard 16-bit word reads.



Figure 8-23. DBG Overview

# 8.4.2 Comparator Modes

The DBG contains three comparators, A, B and C. Each comparator compares the system address bus with the address stored in DBGXAH, DBGXAM, and DBGXAL. Furthermore, comparator A also compares the data buses to the data stored in DBGADH, DBGADL and allows masking of individual data bus bits.

| 0 | 1 | 1 | Start Trace Buffer at trigger<br>A breakpoint request occurs when Trace Buffer is full |
|---|---|---|----------------------------------------------------------------------------------------|
| 1 | x | 1 | Terminate tracing and generate breakpoint immediately on trigger                       |
| 1 | x | 0 | Terminate tracing immediately on trigger                                               |

#### Table 8-42. Breakpoint Setup For CPU Breakpoints

### 8.4.7.2 Breakpoints Generated Via The TRIG Bit

If a TRIG triggers occur, the Final State is entered whereby tracing trigger alignment is defined by the TALIGN bit. If a tracing session is selected by the TSOURCE bit, breakpoints are requested when the tracing session has completed, thus if Begin aligned triggering is selected, the breakpoint is requested only on completion of the subsequent trace (see Table 8-42). If no tracing session is selected, breakpoints are requested immediately. TRIG breakpoints are possible with a single write to DBGC1, setting ARM and TRIG simultaneously.

### 8.4.7.3 Breakpoint Priorities

If a TRIG trigger occurs after Begin aligned tracing has already started, then the TRIG no longer has an effect. When the associated tracing session is complete, the breakpoint occurs. Similarly if a TRIG is followed by a subsequent comparator channel match, it has no effect, since tracing has already started.

If a forced SWI breakpoint coincides with a BGND in user code with BDM enabled, then the BDM is activated by the BGND and the breakpoint to SWI is suppressed.

### 8.4.7.3.1 DBG Breakpoint Priorities And BDM Interfacing

Breakpoint operation is dependent on the state of the BDM module. If the BDM module is active, the CPU is executing out of BDM firmware, thus comparator matches and associated breakpoints are disabled. In addition, while executing a BDM TRACE command, tagging into BDM is disabled. If BDM is not active, the breakpoint gives priority to BDM requests over SWI requests if the breakpoint happens to coincide with a SWI instruction in user code. On returning from BDM, the SWI from user code gets executed.

| DBGBRK | BDM Bit<br>(DBGC1[4]) | BDM<br>Enabled | BDM<br>Active | Breakpoint<br>Mapping |
|--------|-----------------------|----------------|---------------|-----------------------|
| 0      | Х                     | Х              | Х             | No Breakpoint         |
| 1      | 0                     | Х              | 0             | Breakpoint to SWI     |
| Х      | Х                     | 1              | 1             | No Breakpoint         |
| 1      | 1                     | 0              | Х             | Breakpoint to SWI     |
| 1      | 1                     | 1              | 0             | Breakpoint to BDM     |

BDM cannot be entered from a breakpoint unless the ENABLE bit is set in the BDM. If entry to BDM via a BGND instruction is attempted and the ENABLE bit in the BDM is cleared, the CPU actually executes the BDM firmware code, checks the ENABLE and returns if ENABLE is not set. If not serviced by the monitor then the breakpoint is re-asserted when the BDM returns to normal CPU flow.

# 10.3.2.18 S12CPMU IRC1M Trim Registers (CPMUIRCTRIMH / CPMUIRCTRIML)



After de-assert of System Reset a factory programmed trim value is automatically loaded from the Flash memory to provide trimmed Internal Reference Frequency  $f_{IRC1M}$  TRIM.





After de-assert of System Reset a factory programmed trim value is automatically loaded from the Flash memory to provide trimmed Internal Reference Frequency  $f_{IRC1M\_TRIM}$ .

### Figure 10-24. S12CPMU IRC1M Trim Low Register (CPMUIRCTRIML)

### Read: Anytime

Write: Anytime if PROT=0 (CPMUPROT register). Else write has no effect

#### NOTE

Writes to these registers while PLLSEL=1 clears the LOCK and UPOSC status bits.

| f <sub>osc</sub> | REFDIV[3:<br>0] | f <sub>REF</sub> | REFFRQ[1:0] | SYNDIV[5:0] | f <sub>vco</sub> | VCOFRQ[1:0] | POSTDIV<br>[4:0] | f <sub>PLL</sub> | f <sub>bus</sub> |
|------------------|-----------------|------------------|-------------|-------------|------------------|-------------|------------------|------------------|------------------|
| off              | \$00            | 1MHz             | 00          | \$18        | 50MHz            | 01          | \$00             | 50MHz            | 25MHz            |
| 4MHz             | \$00            | 4MHz             | 01          | \$05        | 48MHz            | 00          | \$00             | 48MHz            | 24MHz            |

Table 10-25. Examples of PLL Divider Settings

The phase detector inside the PLL compares the feedback clock (FBCLK = VCOCLK/(SYNDIV+1)) with the reference clock (REFCLK = (IRC1M or OSCCLK)/(REFDIV+1)). Correction pulses are generated based on the phase difference between the two signals. The loop filter alters the DC voltage on the internal filter capacitor, based on the width and direction of the correction pulse, which leads to a higher or lower VCO frequency.

The user must select the range of the REFCLK frequency (REFFRQ[1:0] bits) and the range of the VCOCLK frequency (VCOFRQ[1:0] bits) to ensure that the correct PLL loop bandwidth is set.

The lock detector compares the frequencies of the FBCLK and the REFCLK. Therefore the speed of the lock detector is directly proportional to the reference clock frequency. The circuit determines the lock condition based on this comparison.

If PLL LOCK interrupt requests are enabled, the software can wait for an interrupt request and for instance check the LOCK bit. If interrupt requests are disabled, software can poll the LOCK bit continuously (during PLL start-up) or at periodic intervals. In either case, only when the LOCK bit is set, the VCOCLK will have stabilized to the programmed frequency.

- The LOCK bit is a read-only indicator of the locked state of the PLL.
- The LOCK bit is set when the VCO frequency is within the tolerance  $\Delta_{Lock}$  and is cleared when the VCO frequency is out of the tolerance  $\Delta_{unl}$ .
- Interrupt requests can occur if enabled (LOCKIE = 1) when the lock condition changes, toggling the LOCK bit.

# 10.4.2 Startup from Reset

An example of startup of clock system from Reset is given in Figure 10-30.

Analog-to-Digital Converter (ADC10B12CV2)

# 13.3.2.4 ATD Control Register 3 (ATDCTL3)

Writes to this register will abort current conversion sequence.

Module Base + 0x0003



### Figure 13-6. ATD Control Register 3 (ATDCTL3)

Read: Anytime

Write: Anytime

| Field                        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>DJM                     | <ul> <li>Result Register Data Justification — Result data format is always unsigned. This bit controls justification of conversion data in the result registers.</li> <li>0 Left justified data in the result registers.</li> <li>1 Right justified data in the result registers.</li> <li>Table 13-9 gives example ATD results for an input signal range between 0 and 5.12 Volts.</li> </ul>                                                                                                              |
| 6–3<br>S8C, S4C,<br>S2C, S1C | <b>Conversion Sequence Length</b> — These bits control the number of conversions per sequence. Table 13-10 shows all combinations. At reset, S4C is set to 1 (sequence length is 4). This is to maintain software continuity to HC12 family.                                                                                                                                                                                                                                                                |
| 2<br>FIFO                    | <b>Result Register FIFO Mode</b> — If this bit is zero (non-FIFO mode), the A/D conversion results map into the result registers based on the conversion sequence; the result of the first conversion appears in the first result register (ATDDR0), the second result in the second result register (ATDDR1), and so on.                                                                                                                                                                                   |
|                              | If this bit is one (FIFO mode) the conversion counter is not reset at the beginning or end of a conversion sequence; sequential conversion results are placed in consecutive result registers. In a continuously scanning conversion sequence, the result register counter will wrap around when it reaches the end of the result register file. The conversion counter value (CC3-0 in ATDSTAT0) can be used to determine where in the result register file, the current conversion result will be placed. |
|                              | Aborting a conversion or starting a new conversion clears the conversion counter even if FIFO=1. So the first result of a new conversion sequence, started by writing to ATDCTL5, will always be place in the first result register (ATDDDR0). Intended usage of FIFO mode is continuos conversion (SCAN=1) or triggered conversion (ETRIG=1).                                                                                                                                                              |
|                              | Which result registers hold valid data can be tracked using the conversion complete flags. Fast flag clear mode may be useful in a particular application to track valid data.                                                                                                                                                                                                                                                                                                                              |
|                              | If this bit is one, automatic compare of result registers is always disabled, that is ADC10B12C will behave as if ACMPIE and all CPME[ <i>n</i> ] were zero.<br>0 Conversion results are placed in the corresponding result register up to the selected sequence length.<br>1 Conversion results are placed in consecutive result registers (wrap around at end).                                                                                                                                           |
| 1–0<br>FRZ[1:0]              | <b>Background Debug Freeze Enable</b> — When debugging an application, it is useful in many cases to have the ATD pause when a breakpoint (Freeze Mode) is encountered. These 2 bits determine how the ATD will respond to a breakpoint as shown in Table 13-11. Leakage onto the storage node and comparator reference capacitors may compromise the accuracy of an immediately frozen conversion depending on the length of the freeze period.                                                            |

### Table 13-8. ATDCTL3 Field Descriptions

Scalable Controller Area Network (S12MSCANV3)

| Register<br>Name            |        | Bit 7  | 6                                                           | 5      | 4      | 3      | 2      | 1      | Bit 0  |
|-----------------------------|--------|--------|-------------------------------------------------------------|--------|--------|--------|--------|--------|--------|
| 0x000E                      | R      | RXERR7 | RXERR6                                                      | RXERR5 | RXERR4 | RXERR3 | RXERR2 | RXERR1 | RXERR0 |
| CANRXERR                    | W      |        |                                                             |        |        |        |        |        |        |
| 0x000F                      | R      | TXERR7 | TXERR6                                                      | TXERR5 | TXERR4 | TXERR3 | TXERR2 | TXERR1 | TXERR0 |
| CANTXERR                    | W      |        |                                                             |        |        |        |        |        |        |
| 0x0010-0x0013<br>CANIDAR0-3 | R<br>W | AC7    | AC6                                                         | AC5    | AC4    | AC3    | AC2    | AC1    | AC0    |
| 0x0014–0x0017<br>CANIDMRx   | R<br>W | AM7    | AM6                                                         | AM5    | AM4    | AM3    | AM2    | AM1    | AM0    |
| 0x0018–0x001B<br>CANIDAR4–7 | R<br>W | AC7    | AC6                                                         | AC5    | AC4    | AC3    | AC2    | AC1    | AC0    |
| 0x001C–0x001F<br>CANIDMR4–7 | R<br>W | AM7    | AM6                                                         | AM5    | AM4    | AM3    | AM2    | AM1    | AM0    |
| 0x0020–0x002F<br>CANRXFG    | R<br>W |        | See Section 18.3.3, "Programmer's Model of Message Storage" |        |        |        |        |        |        |
| 0x0030–0x003F<br>CANTXFG    | R<br>W |        | See Section 18.3.3, "Programmer's Model of Message Storage" |        |        |        |        |        |        |
|                             |        |        | = Unimplemented or Reserved                                 |        |        |        |        |        |        |



# 18.3.2 Register Descriptions

This section describes in detail all the registers and register bits in the MSCAN module. Each description includes a standard register diagram with an associated figure number. Details of register bit and field function follow the register diagrams, in bit order. All bits of all registers in this module are completely synchronous to internal clocks during a register read.

# 18.3.2.1 MSCAN Control Register 0 (CANCTL0)

The CANCTL0 register provides various control bits of the MSCAN module as described below.

#### Pulse-Width Modulator (S12PWM8B8CV2)

Module Base + 0x0001



Read: Anytime

Write: Anytime

### NOTE

PPOLx register bits can be written anytime. If the polarity is changed while a PWM signal is being generated, a truncated or stretched pulse can occur during the transition

#### Table 19-3. PWMPOL Field Descriptions

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

| Field     | Description                                                                                                    |
|-----------|----------------------------------------------------------------------------------------------------------------|
| 7–0       | Pulse Width Channel 7–0 Polarity Bits                                                                          |
| PPOL[7:0] | 0 PWM channel 7–0 outputs are low at the beginning of the period, then go high when the duty count is reached. |
|           | 1 PWM channel 7–0 outputs are high at the beginning of the period, then go low when the duty count is reached. |

### 19.3.2.3 PWM Clock Select Register (PWMCLK)

Each PWM channel has a choice of four clocks to use as the clock source for that channel as described below.

Module Base + 0x0002





Read: Anytime

Write: Anytime

### NOTE

Register bits PCLK0 to PCLK7 can be written anytime. If a clock select is changed while a PWM signal is being generated, a truncated or stretched pulse can occur during the transition.

#### Pulse-Width Modulator (S12PWM8B8CV2)

Clock Source = E, where E = 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 19-20 is the output waveform generated.



Figure 19-20. PWM Center Aligned Output Example Waveform

### 19.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 19-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 bytes of 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 19-21. The polarity of the resulting PWM output is controlled by the PPOLx bit of the corresponding low order 8-bit channel as well.

| Table 22-9. | Edge | Detector | Circuit | Configuration |
|-------------|------|----------|---------|---------------|
|-------------|------|----------|---------|---------------|

| EDGnB | EDGnA | Configuration                           |
|-------|-------|-----------------------------------------|
| 1     | 1     | Capture on any edge (rising or falling) |

# 22.3.2.8 Timer Interrupt Enable Register (TIE)

Module Base + 0x000C



Figure 22-14. Timer Interrupt Enable Register (TIE)

Read: Anytime

Write: Anytime.

### Table 22-10. TIE Field Descriptions

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

| Field          | Description                                                                                                                                                                                                                                                                              |
|----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5:0<br>C5I:C0I | Input Capture/Output Compare "x" Interrupt Enable — The bits in TIE correspond bit-for-bit with the bits in the TFLG1 status register. If cleared, the corresponding flag is disabled from causing a hardware interrupt. If set, the corresponding flag is enabled to cause a interrupt. |

# 22.3.2.9 Timer System Control Register 2 (TSCR2)

Module Base + 0x000D



Read: Anytime

Write: Anytime.

## 24.4.4.3 Valid Flash Module Commands

Table 24-25 present the valid Flash commands, as enabled by the combination of the functional MCU mode (Normal SingleChip NS, Special Singlechip SS) with the MCU security state (Unsecured, Secured).

Special Singlechip mode is selected by input mmc\_ss\_mode\_ts2 asserted. MCU Secured state is selected by input mmc\_secure input asserted.

| FOND | 0 - m - m - d                | Unsecured<br>NS <sup>1</sup> SS <sup>2</sup> |   | Secured         |                 |
|------|------------------------------|----------------------------------------------|---|-----------------|-----------------|
| FCMD | Command                      |                                              |   | NS <sup>3</sup> | SS <sup>4</sup> |
| 0x01 | Erase Verify All Blocks      | *                                            | * | *               | *               |
| 0x02 | Erase Verify Block           | *                                            | * | *               | *               |
| 0x03 | Erase Verify P-Flash Section | *                                            | * | *               |                 |
| 0x04 | Read Once                    | *                                            | * | *               |                 |
| 0x06 | Program P-Flash              | *                                            | * | *               |                 |
| 0x07 | Program Once                 | *                                            | * | *               |                 |
| 0x08 | Erase All Blocks             |                                              | * |                 | *               |
| 0x09 | Erase Flash Block            | *                                            | * | *               |                 |
| 0x0A | Erase P-Flash Sector         | *                                            | * | *               |                 |
| 0x0B | Unsecure Flash               |                                              | * |                 | *               |
| 0x0C | Verify Backdoor Access Key   | *                                            |   | *               |                 |
| 0x0D | Set User Margin Level        | *                                            | * | *               |                 |
| 0x0E | Set Field Margin Level       |                                              | * |                 |                 |
| 0x10 | Erase Verify EEPROM Section  | *                                            | * | *               |                 |
| 0x11 | Program EEPROM               | *                                            | * | *               |                 |
| 0x12 | Erase EEPROM Sector          | *                                            | * | *               |                 |

Table 24-25. Flash Commands by Mode and Security State

<sup>1</sup> Unsecured Normal Single Chip mode

<sup>2</sup> Unsecured Special Single Chip mode.

<sup>3</sup> Secured Normal Single Chip mode.

<sup>4</sup> Secured Special Single Chip mode.

### 24.4.4.4 P-Flash Commands

Table 24-26 summarizes the valid P-Flash commands along with the effects of the commands on the P-Flash block and other resources within the Flash module.

| FCMD | Command                    | Function on P-Flash Memory                              |
|------|----------------------------|---------------------------------------------------------|
| 0x01 | Erase Verify All<br>Blocks | Verify that all P-Flash (and EEPROM) blocks are erased. |

#### Table 24-26. P-Flash Commands

| Field              | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|--------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>CCIF          | <ul> <li>Command Complete Interrupt Flag — The CCIF flag indicates that a Flash command has completed. The CCIF flag is cleared by writing a 1 to CCIF to launch a command and CCIF will stay low until command completion or command violation.</li> <li>0 Flash command in progress</li> <li>1 Flash command has completed</li> </ul>                                                                                                                                           |
| 5<br>ACCERR        | Flash Access Error Flag — The ACCERR bit indicates an illegal access has occurred to the Flash memory caused by either a violation of the command write sequence (see Section 25.4.4.2) or issuing an illegal Flash command. While ACCERR is set, the CCIF flag cannot be cleared to launch a command. The ACCERR bit is cleared by writing a 1 to ACCERR. Writing a 0 to the ACCERR bit has no effect on ACCERR. 0 No access error detected 1 Access error detected              |
| 4<br>FPVIOL        | Flash Protection Violation Flag — The FPVIOL bit indicates an attempt was made to program or erase an address in a protected area of P-Flash or EEPROM memory during a command write sequence. The FPVIOL bit is cleared by writing a 1 to FPVIOL. Writing a 0 to the FPVIOL bit has no effect on FPVIOL. While FPVIOL is set, it is not possible to launch a command or start a command write sequence.<br>0 No protection violation detected<br>1 Protection violation detected |
| 3<br>MGBUSY        | <ul> <li>Memory Controller Busy Flag — The MGBUSY flag reflects the active state of the Memory Controller.</li> <li>0 Memory Controller is idle</li> <li>1 Memory Controller is busy executing a Flash command (CCIF = 0)</li> </ul>                                                                                                                                                                                                                                              |
| 2<br>RSVD          | <b>Reserved Bit</b> — This bit is reserved and always reads 0.                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 1–0<br>MGSTAT[1:0] | <b>Memory Controller Command Completion Status Flag</b> — One or more MGSTAT flag bits are set if an error is detected during execution of a Flash command or during the Flash reset sequence. See Section 25.4.6, "Flash Command Description," and Section 25.6, "Initialization" for details.                                                                                                                                                                                   |

### Table 25-15. FSTAT Field Descriptions

# 25.3.2.8 Flash Error Status Register (FERSTAT)

The FERSTAT register reflects the error status of internal Flash operations.



All flags in the FERSTAT register are readable and only writable to clear the flag.

#### 96 KByte Flash Module (S12FTMRG96K1V1)

| Global Address      | Size<br>(Bytes) | Description                                                             |
|---------------------|-----------------|-------------------------------------------------------------------------|
| 0x2_8000 – 0x3_FFFF | 96 K            | P-Flash Block<br>Contains Flash Configuration Field<br>(see Table 28-4) |

The FPROT register, described in Section 28.3.2.9, can be set to protect regions in the Flash memory from accidental program or erase. Three separate memory regions, one growing upward from global address 0x3\_8000 in the Flash memory (called the lower region), one growing downward from global address 0x3\_FFFF in the Flash memory (called the higher region), and the remaining addresses in the Flash memory, can be activated for protection. The Flash memory addresses covered by these protectable regions are shown in the P-Flash memory map. The higher address region is mainly targeted to hold the boot loader code since it covers the vector space. Default protection settings as well as security information that allows the MCU to restrict access to the Flash module are stored in the Flash configuration field as described in Table 28-4.

Table 28-4. Flash Configuration Field

| Global Address                 | Size<br>(Bytes) | Description                                                                                                                                                        |
|--------------------------------|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x3_FF00-0x3_FF07              | 8               | Backdoor Comparison Key<br>Refer to Section 28.4.6.11, "Verify Backdoor Access Key Command," and<br>Section 28.5.1, "Unsecuring the MCU using Backdoor Key Access" |
| 0x3_FF08-0x3_FF0B <sup>1</sup> | 4               | Reserved                                                                                                                                                           |
| 0x3_FF0C <sup>1</sup>          | 1               | P-Flash Protection byte.<br>Refer to Section 28.3.2.9, "P-Flash Protection Register (FPROT)"                                                                       |
| 0x3_FF0D <sup>1</sup>          | 1               | EEPROM Protection byte.<br>Refer to Section 28.3.2.10, "EEPROM Protection Register (EEPROT)"                                                                       |
| 0x3_FF0E <sup>1</sup>          | 1               | Flash Nonvolatile byte<br>Refer to Section 28.3.2.16, "Flash Option Register (FOPT)"                                                                               |
| 0x3_FF0F <sup>1</sup>          | 1               | Flash Security byte<br>Refer to Section 28.3.2.2, "Flash Security Register (FSEC)"                                                                                 |

<sup>1</sup> 0x3FF08-0x3\_FF0F form a Flash phrase and must be programmed in a single command write sequence. Each byte in the 0x3\_FF08 - 0x3\_FF0B reserved field should be programmed to 0xFF.

#### 192 KByte Flash Module (S12FTMRG192K2V1)

P-Flash memory (see Table 30-4) as indicated by reset condition F in Table 30-23. To change the EEPROM protection that will be loaded during the reset sequence, the P-Flash sector containing the EEPROM protection byte must be unprotected, then the EEPROM protection byte must be programmed. If a double bit fault is detected while reading the P-Flash phrase containing the EEPROM protection byte during the reset sequence, the DPOPEN bit will be cleared and DPS bits will be set to leave the EEPROM memory fully protected.

Trying to alter data in any protected area in the EEPROM memory will result in a protection violation error and the FPVIOL bit will be set in the FSTAT register. Block erase of the EEPROM memory is not possible if any of the EEPROM sectors are protected.

| Field           | Description                                                                                                                                                                                                                       |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>DPOPEN     | <ul> <li>EEPROM Protection Control</li> <li>Enables EEPROM memory protection from program and erase with protected address range defined by DPS bits</li> <li>Disables EEPROM memory protection from program and erase</li> </ul> |
| 6–0<br>DPS[6:0] | <b>EEPROM Protection Size</b> — The DPS[6:0] bits determine the size of the protected area in the EEPROM memory, this size increase in step of 32 bytes, as shown in Table 30-23.                                                 |

| Table 30-22. | EEPROT | Field | Descriptions |
|--------------|--------|-------|--------------|
|--------------|--------|-------|--------------|

#### Table 30-23. EEPROM Protection Address Range

| DPS[6:0]                                                                                         | Global Address Range | Protected Size |  |
|--------------------------------------------------------------------------------------------------|----------------------|----------------|--|
| 0000000                                                                                          | 0x0_0400 - 0x0_041F  | 32 bytes       |  |
| 0000001                                                                                          | 0x0_0400 - 0x0_043F  | 64 bytes       |  |
| 0000010                                                                                          | 0x0_0400 – 0x0_045F  | 96 bytes       |  |
| 0000011                                                                                          | 0x0_0400 - 0x0_047F  | 128 bytes      |  |
| 0000100                                                                                          | 0x0_0400 - 0x0_049F  | 160 bytes      |  |
| 0000101                                                                                          | 0x0_0400 – 0x0_04BF  | 192 bytes      |  |
| The Protection Size goes on enlarging in step of 32 bytes, for each DPS value increasing of one. |                      |                |  |
| 1111111                                                                                          | 0x0_0400 – 0x0_13FF  | 4,096 bytes    |  |

| CCOBIX[2:0] | FCCOB Parameters                                       |  |  |
|-------------|--------------------------------------------------------|--|--|
| 000         | 0x0E Flash block selection code [1:0]. See Table 30-34 |  |  |
| 001         | Margin level setting.                                  |  |  |

| Table 30-57. | Set Field Margin | Level Command | FCCOB | Requirements |
|--------------|------------------|---------------|-------|--------------|
|--------------|------------------|---------------|-------|--------------|

Upon clearing CCIF to launch the Set Field Margin Level command, the Memory Controller will set the field margin level for the targeted block and then set the CCIF flag.

### NOTE

When the EEPROM block is targeted, the EEPROM field margin levels are applied only to the EEPROM reads. However, when the P-Flash block is targeted, the P-Flash field margin levels are applied to both P-Flash and EEPROM reads. It is not possible to apply field margin levels to the P-Flash block only.

Valid margin level settings for the Set Field Margin Level command are defined in Table 30-58.

| CCOB<br>(CCOBIX=001) | Level Description                 |
|----------------------|-----------------------------------|
| 0x0000               | Return to Normal Level            |
| 0x0001               | User Margin-1 Level <sup>1</sup>  |
| 0x0002               | User Margin-0 Level <sup>2</sup>  |
| 0x0003               | Field Margin-1 Level <sup>1</sup> |
| 0x0004               | Field Margin-0 Level <sup>2</sup> |

Table 30-58. Valid Set Field Margin Level Settings

<sup>1</sup> Read margin to the erased state

<sup>2</sup> Read margin to the programmed state

### Table 30-59. Set Field Margin Level Command Error Handling

| Register | Error Bit | Error Condition                                                 |
|----------|-----------|-----------------------------------------------------------------|
| FSTAT    | ACCERR    | Set if CCOBIX[2:0] != 001 at command launch.                    |
|          |           | Set if command not available in current mode (see Table 30-27). |
|          |           | Set if an invalid margin level setting is supplied.             |
|          | FPVIOL    | None                                                            |
|          | MGSTAT1   | None                                                            |
|          | MGSTAT0   | None                                                            |