#### NXP USA Inc. - S9S12G128F0MLHR Datasheet





#### 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              | 54                                                                      |
| 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 12x10b                                                              |
| Oscillator Type            | Internal                                                                |
| Operating Temperature      | -40°C ~ 125°C (TA)                                                      |
| Mounting Type              | Surface Mount                                                           |
| Package / Case             | 64-LQFP                                                                 |
| Supplier Device Package    | 64-LQFP (10x10)                                                         |
| Purchase URL               | https://www.e-xfl.com/product-detail/nxp-semiconductors/s9s12g128f0mlhr |

Email: info@E-XFL.COM

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

|             | <lo< th=""><th>Fund<br/>owestPRIO</th><th>c<b>tion</b><br/>RITYhighe</th><th>Power</th><th colspan="3">Internal Pull<br/>Resistor</th></lo<> | Fund<br>owestPRIO | c <b>tion</b><br>RITYhighe | Power        | Internal Pull<br>Resistor |            |                |
|-------------|----------------------------------------------------------------------------------------------------------------------------------------------|-------------------|----------------------------|--------------|---------------------------|------------|----------------|
| Package Pin | Pin                                                                                                                                          | 2nd<br>Func.      | 3rd<br>Func.               | 4th<br>Func. | Supply                    | CTRL       | Reset<br>State |
| 86          | PS4                                                                                                                                          | MISO0             | _                          | —            | V <sub>DDX</sub>          | PERS/PPSS  | Up             |
| 87          | PS5                                                                                                                                          | MOSI0             | _                          | —            | V <sub>DDX</sub>          | PERS/PPSS  | Up             |
| 88          | PS6                                                                                                                                          | SCK0              | _                          | —            | V <sub>DDX</sub>          | PERS/PPSS  | Up             |
| 89          | PS7                                                                                                                                          | API_EXTC<br>LK    | SS0                        | —            | V <sub>DDX</sub>          | PERS/PPSS  | Up             |
| 90          | VSSX2                                                                                                                                        | —                 | _                          | —            | —                         | _          | —              |
| 91          | VDDX2                                                                                                                                        | —                 | _                          | —            | —                         | _          | —              |
| 92          | PM0                                                                                                                                          | RXCAN             | _                          | —            | V <sub>DDX</sub>          | PERM/PPSM  | Disabled       |
| 93          | PM1                                                                                                                                          | TXCAN             | _                          | —            | V <sub>DDX</sub>          | PERM/PPSM  | Disabled       |
| 94          | PD4                                                                                                                                          | —                 | _                          | —            | V <sub>DDX</sub>          | PUCR/PUPDE | Disabled       |
| 95          | PD5                                                                                                                                          | —                 | _                          | —            | V <sub>DDX</sub>          | PUCR/PUPDE | Disabled       |
| 96          | PD6                                                                                                                                          | —                 | _                          | —            | V <sub>DDX</sub>          | PUCR/PUPDE | Disabled       |
| 97          | PD7                                                                                                                                          | —                 | —                          | —            | V <sub>DDX</sub>          | PUCR/PUPDE | Disabled       |
| 98          | PM2                                                                                                                                          | RXD2              | —                          | —            | V <sub>DDX</sub>          | PERM/PPSM  | Disabled       |
| 99          | PM3                                                                                                                                          | TXD2              | —                          | —            | V <sub>DDX</sub>          | PERM/PPSM  | Disabled       |
| 100         | PJ7                                                                                                                                          | KWJ7              | SS2                        | _            | V <sub>DDX</sub>          | PERJ/PPSJ  | Up             |

 Table 1-25.
 100-Pin LQFP Pinout for S12GA96 and S12GA128

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

| PP3-PP2 | <ul> <li>Except 20 TSSOP: The PWM channels 3 and 2 signal are mapped to these pins when used with the PWM function. The enabled PWM channel forces the I/O state to be an output.</li> <li>Except 20 TSSOP: The ADC ETRIG 3 and 2 signal are mapped to these pins when used with the ADC function. The enabled external trigger function has no effect on the I/O state. Refer to Section 2.6.4, "ADC External Triggers ETRIG3-0".</li> <li>Except 20 TSSOP: Pin interrupts can be generated if enabled in input or output mode.</li> <li>Signal priority: Except 20 TSSOP: PWM &gt; GPO</li> </ul>                                                                                                                                                                                                                                                                                   |
|---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PP1     | <ul> <li>Except 20 TSSOP: The PWM channel 1 signal is mapped to this pin when used with the PWM function.<br/>The enabled PWM channel forces the I/O state to be an output.</li> <li>Except 100 LQFP and 20 TSSOP: The ECLKX2 signal is mapped to this pin when used with the external clock function. The enabled ECLKX2 forces the I/O state to an output.</li> <li>Except 20 TSSOP: The ADC ETRIG1 signal is mapped to this pin when used with the ADC function.<br/>The enabled external trigger function has no effect on the I/O state. Refer to Section 2.6.4, "ADC External Triggers ETRIG3-0".</li> <li>Except 20 TSSOP: Pin interrupts can be generated if enabled in input or output mode.</li> <li>Signal priority:<br/>Except 100 LQFP and 20 TSSOP: PWM1 &gt; ECLKX2 &gt; GPO 100 LQFP: PWM1 &gt; GPO</li> </ul>                                                        |
| PP0     | <ul> <li>Except 20 TSSOP: The PWM channel 0 signal is mapped to this pin when used with the PWM function.<br/>The enabled PWM channel forces the I/O state to be an output.</li> <li>Except 100 LQFP and 20 TSSOP: The API_EXTCLK signal is mapped to this pin when used with the external clock function. If the Autonomous Periodic Interrupt clock is enabled and routed here the I/O state is forced to output.</li> <li>Except 20 TSSOP: The ADC ETRIG0 signal is mapped to this pin when used with the ADC function. The enabled external trigger function has no effect on the I/O state. Refer to Section 2.6.4, "ADC External Triggers ETRIG3-0".</li> <li>Except 20 TSSOP: Pin interrupts can be generated if enabled in input or output mode.</li> <li>Signal priority:<br/>Except 100 LQFP and 20 TSSOP: PWM0 &gt; API_EXTCLK &gt; GPO 100 LQFP: PWM0 &gt; GPO</li> </ul> |

#### Table 2-14. Port P Pins PP7-0 (continued)

# 2.4.3.58 Port AD Pull Enable Register (PER1AD)



#### Table 2-84. PER1AD Register Field Descriptions

| Field         | Description                                                                                                                                                                                                                                                                                                               |
|---------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7-0<br>PER1AD | Port AD pull enable—Enable pull device on input pin<br>This bit controls whether a pull device on the associated port input pin is active. If a pin is used as output this bit has<br>no effect. The polarity is selected by the related polarity select register bit.<br>1 Pull device enabled<br>0 Pull device disabled |

## 2.4.3.59 Port AD Polarity Select Register (PPS0AD)



<sup>1</sup> Read: Anytime Write: Anytime



Figure 6-1. INT Block Diagram

# 6.2 External Signal Description

The INT module has no external signals.

# 6.3 Memory Map and Register Definition

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

## 6.3.1 Register Descriptions

This section describes in address order all the INT registers and their individual bits.

## 6.3.1.1 Interrupt Vector Base Register (IVBR)



Read: Anytime

Write: Anytime

| Global<br>Address | Register<br>Name |   | Bit 7  | 6          | 5           | 4       | 3          | 2           | 1            | Bit 0  |
|-------------------|------------------|---|--------|------------|-------------|---------|------------|-------------|--------------|--------|
| 0x3_FF09          | Reserved         | R | 0      | 0          | 0           | 0       | 0          | 0           | 0            | 0      |
|                   |                  | W |        |            |             |         |            |             |              |        |
| 0x3_FF0A          | Reserved         | R | 0      | 0          | 0           | 0       | 0          | 0           | 0            | 0      |
|                   |                  | W |        |            |             |         |            |             |              |        |
| 0x3_FF0B          | Reserved         | R | 0      | 0          | 0           | 0       | 0          | 0           | 0            | 0      |
|                   |                  | W |        |            |             |         |            |             |              |        |
|                   |                  | [ |        | = Unimpler | nented, Res | erved   |            | = Impleme   | nted (do not | alter) |
|                   |                  |   | Х      | = Indeterm | inate       |         | 0          | = Always re | ead zero     |        |
|                   |                  | - | Figure | e 7-2. BDM | Register \$ | Summary | (continued | )           |              |        |

## 7.3.2.1 BDM Status Register (BDMSTS)



Register Global Address 0x3\_FF01

- <sup>1</sup> ENBDM is read as 1 by a debugging environment in special single chip mode when the device is not secured or secured but fully erased (Flash). This is because the ENBDM bit is set by the standard BDM firmware before a BDM command can be fully transmitted and executed.
- <sup>2</sup> UNSEC is read as 1 by a debugging environment in special single chip mode when the device is secured and fully erased, else it is 0 and can only be read if not secure (see also bit description).

#### Figure 7-3. BDM Status Register (BDMSTS)

Read: All modes through BDM operation when not secured

Write: All modes through BDM operation when not secured, but subject to the following:

- ENBDM should only be set via a BDM hardware command if the BDM firmware commands are needed. (This does not apply in special single chip mode).
- BDMACT can only be set by BDM hardware upon entry into BDM. It can only be cleared by the standard BDM firmware lookup table upon exit from BDM active mode.
- All other bits, while writable via BDM hardware or standard BDM firmware write commands, should only be altered by the BDM hardware or standard firmware lookup table as part of BDM command execution.

# 7.4.7 Serial Interface Hardware Handshake Protocol

BDM commands that require CPU execution are ultimately treated at the MCU bus rate. Since the BDM clock source can be modified when changing the settings for the VCO frequency (CPMUSYNR), it is very helpful to provide a handshake protocol in which the host could determine when an issued command is executed by the CPU. The BDM clock frequency is always VCO frequency divided by 8. The alternative is to always wait the amount of time equal to the appropriate number of cycles at the slowest possible rate the clock could be running. This sub-section will describe the hardware handshake protocol.

The hardware handshake protocol signals to the host controller when an issued command was successfully executed by the target. This protocol is implemented by a 16 serial clock cycle low pulse followed by a brief speedup pulse in the BKGD pin. This pulse is generated by the target MCU when a command, issued by the host, has been successfully executed (see Figure 7-10). This pulse is referred to as the ACK pulse. After the ACK pulse has finished: the host can start the bit retrieval if the last issued command was a read command, or start a new command if the last command was a write command or a control command (BACKGROUND, GO, GO\_UNTIL or TRACE1). The ACK pulse is not issued earlier than 32 serial clock cycles after the BDM command was issued. The end of the BDM command is assumed to be the 16th tick of the last bit. This minimum delay assures enough time for the host to perceive the ACK pulse. Note also that, there is no upper limit for the delay between the command and the related ACK pulse, since the command execution depends upon the CPU bus, which in some cases could be very slow due to long accesses taking place. This protocol allows a great flexibility for the POD designers, since it does not rely on any accurate time measurement or short response time to any event in the serial communication.



Figure 7-10. Target Acknowledge Pulse (ACK)

### NOTE

If the ACK pulse was issued by the target, the host assumes the previous command was executed. If the CPU enters wait or stop prior to executing a hardware command, the ACK pulse will not be issued meaning that the BDM command was not executed. After entering wait or stop mode, the BDM command is no longer pending.

- 4-stage state sequencer for trace buffer control
  - Tracing session trigger linked to Final State of state sequencer
  - Begin and End alignment of tracing to trigger

## 8.1.4 Modes of Operation

The DBG module can be used in all MCU functional modes.

During BDM hardware accesses and whilst the BDM module is active, CPU monitoring is disabled. When the CPU enters active BDM Mode through a BACKGROUND command, the DBG module, if already armed, remains armed.

The DBG module tracing is disabled if the MCU is secure, however, breakpoints can still be generated.

| BDM<br>Enable | BDM<br>Active | MCU<br>Secure | Comparator<br>Matches Enabled            | Breakpoints<br>Possible | Tagging<br>Possible | Tracing<br>Possible |  |
|---------------|---------------|---------------|------------------------------------------|-------------------------|---------------------|---------------------|--|
| Х             | х             | 1             | Yes                                      | Yes                     | Yes                 | No                  |  |
| 0             | 0             | 0             | Yes                                      | Only SWI                | Yes                 | Yes                 |  |
| 0             | 1             | 0             | Active BDM not possible when not enabled |                         |                     |                     |  |
| 1             | 0             | 0             | Yes                                      | Yes                     | Yes                 | Yes                 |  |
| 1             | 1             | 0             | No                                       | No                      | No                  | No                  |  |

Table 8-2. Mode Dependent Restriction Summary

## 8.1.5 Block Diagram



Figure 8-1. Debug Module Block Diagram

MC9S12G Family Reference Manual Rev.1.27

#### S12S Debug Module (S12SDBGV2)

| Bit       | Description                                                                                              |
|-----------|----------------------------------------------------------------------------------------------------------|
| 0<br>PC16 | <b>Program Counter bit 16</b> — In Normal and Loop1 mode this bit corresponds to program counter bit 16. |

#### Table 8-39. PCH Field Descriptions (continued)

## 8.4.5.4 Trace Buffer Organization (Compressed Pure PC mode)

Table 8-40. Trace Buffer Organization Example (Compressed PurePC mode)

| Mode                       | Line<br>Number | 2-bits  | 6-bits                           | 6-bits                               | 6-bits  |  |  |  |
|----------------------------|----------------|---------|----------------------------------|--------------------------------------|---------|--|--|--|
|                            |                | Field 3 | Field 2                          | Field 1                              | Field 0 |  |  |  |
| Compressed<br>Pure PC Mode | Line 1         | 00      | PC1                              | PC1 (Initial 18-bit PC Base Address) |         |  |  |  |
|                            | Line 2         | 11      | PC4                              | PC3                                  | PC2     |  |  |  |
|                            | Line 3         | 01      | 0                                | 0                                    | PC5     |  |  |  |
|                            | Line 4         | 00      | PC6 (New 18-bit PC Base Address) |                                      |         |  |  |  |
|                            | Line 5         | 10      | 0                                | PC8                                  | PC7     |  |  |  |
|                            | Line 6         | 00      | PC9                              | ress)                                |         |  |  |  |

### NOTE

Configured for end aligned triggering in compressed PurePC mode, then after rollover it is possible that the oldest base address is overwritten. In this case all entries between the pointer and the next base address have lost their base address following rollover. For example in Table 8-40 if one line of rollover has occurred, Line 1, PC1, is overwritten with a new entry. Thus the entries on Lines 2 and 3 have lost their base address. For reconstruction of program flow the first base address following the pointer must be used, in the example, Line 4. The pointer points to the oldest entry, Line 2.

### Field3 Bits in Compressed Pure PC Modes

Table 8-41. Compressed Pure PC Mode Field 3 Information Bit Encoding

| INF1 | INF0 | TRACE BUFFER ROW CONTENT                                                              |
|------|------|---------------------------------------------------------------------------------------|
| 0    | 0    | Base PC address TB[17:0] contains a full PC[17:0] value                               |
| 0    | 1    | Trace Buffer[5:0] contain incremental PC relative to base address zero value          |
| 1    | 0    | Trace Buffer[11:0] contain next 2 incremental PCs relative to base address zero value |
| 1    | 1    | Trace Buffer[17:0] contain next 3 incremental PCs relative to base address zero value |

Each time that PC[17:6] differs from the previous base PC[17:6], then a new base address is stored. The base address zero value is the lowest address in the 64 address range

The first line of the trace buffer always gets a base PC address, this applies also on rollover.

#### S12S Debug Module (S12SDBGV2)

## 12.3.2.12.2 Right Justified Result Data (DJM=1)



Figure 12-15. Right justified ATD conversion result register (ATDDRn)

Table 12-22 shows how depending on the A/D resolution the conversion result is transferred to the ATD result registers for right justified data. Compare is always done using all 12 bits of both the conversion result and the compare value in ATDDRn.

| A/D<br>resolution | DJM | conversion result mapping to ATDDR <i>n</i>        |
|-------------------|-----|----------------------------------------------------|
| 8-bit data        | 1   | Result-Bit[7:0] = result,<br>Result-Bit[11:8]=0000 |
| 10-bit data       | 1   | Result-Bit[9:0] = result,<br>Result-Bit[11:10]=00  |
| 12-bit data       | 1   | Result-Bit[11:0] = result                          |

Table 12-22. Conversion result mapping to ATDDRn

### 14.3.2.12.2 Right Justified Result Data (DJM=1)

Module Base + 0x0010 = ATDDR0, 0x0012 = ATDDR1, 0x0014 = ATDDR2, 0x0016 = ATDDR3 0x0018 = ATDDR4, 0x001A = ATDDR5, 0x001C = ATDDR6, 0x001E = ATDDR7 0x0020 = ATDDR8, 0x0022 = ATDDR9, 0x0024 = ATDDR10, 0x0026 = ATDDR11



#### Figure 14-15. Right justified ATD conversion result register (ATDDRn)

Table 14-22 shows how depending on the A/D resolution the conversion result is transferred to the ATD result registers for right justified data. Compare is always done using all 12 bits of both the conversion result and the compare value in ATDDRn.

| A/D<br>resolution | DJM | conversion result mapping to ATDDR <i>n</i>                   |
|-------------------|-----|---------------------------------------------------------------|
| 8-bit data        | 1   | Result-Bit[11:8]=0000,<br>Result-Bit[7:0] = conversion result |
| 10-bit data       | 1   | Result-Bit[11:10]=00,<br>Result-Bit[9:0] = conversion result  |
| 12-bit data       | 1   | Result-Bit[11:0] = result                                     |

Table 14-22. Conversion result mapping to ATDDRn

| Field        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |
|--------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6<br>XFRW    | <b>Transfer Width</b> — This bit is used for selecting the data transfer width. If 8-bit transfer width is selected, SPIDRL becomes the dedicated data register and SPIDRH is unused. If 16-bit transfer width is selected, SPIDRH and SPIDRL form a 16-bit data register. Please refer to Section 21.3.2.4, "SPI Status Register (SPISR) for information about transmit/receive data handling and the interrupt flag clearing mechanism. In master mode, a change of this bit will abort a transmission in progress and force the SPI system into idle state. 0 8-bit Transfer Width (n = 8) <sup>1</sup> 1 16-bit Transfer Width (n = 16) <sup>1</sup> |
| 4<br>MODFEN  | <ul> <li>Mode Fault Enable Bit — This bit allows the MODF failure to be detected. If the SPI is in master mode and MODFEN is cleared, then the SS port pin is not used by the SPI. In slave mode, the SS is available only as an input regardless of the value of MODFEN. For an overview on the impact of the MODFEN bit on the SS port pin configuration, refer to Table 21-2. In master mode, a change of this bit will abort a transmission in progress and force the SPI system into idle state.</li> <li>0 SS port pin is not used by the SPI.</li> <li>1 SS port pin with MODF feature.</li> </ul>                                                |
| 3<br>BIDIROE | <ul> <li>Output Enable in the Bidirectional Mode of Operation — This bit controls the MOSI and MISO output buffer of the SPI, when in bidirectional mode of operation (SPC0 is set). In master mode, this bit controls the output buffer of the MOSI port, in slave mode it controls the output buffer of the MISO port. In master mode, with SPC0 set, a change of this bit will abort a transmission in progress and force the SPI into idle state.</li> <li>0 Output buffer disabled.</li> <li>1 Output buffer enabled.</li> </ul>                                                                                                                    |
| 1<br>SPISWAI | <ul> <li>SPI Stop in Wait Mode Bit — This bit is used for power conservation while in wait mode.</li> <li>SPI clock operates normally in wait mode.</li> <li>Stop SPI clock generation when in wait mode.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                     |
| 0<br>SPC0    | <b>Serial Pin Control Bit 0</b> — This bit enables bidirectional pin configurations as shown in Table 21-4. In master mode, a change of this bit will abort a transmission in progress and force the SPI system into idle state.                                                                                                                                                                                                                                                                                                                                                                                                                         |

<sup>1</sup> n is used later in this document as a placeholder for the selected transfer width.

### Table 21-4. Bidirectional Pin Configurations

| Pin Mode                 | SPC0                       | BIDIROE | MISO                 | MOSI                 |  |  |  |  |  |  |
|--------------------------|----------------------------|---------|----------------------|----------------------|--|--|--|--|--|--|
| Master Mode of Operation |                            |         |                      |                      |  |  |  |  |  |  |
| Normal                   | 0                          | Х       | Master In            | Master Out           |  |  |  |  |  |  |
| Bidirectional            | 1                          | 0       | MISO not used by SPI | Master In            |  |  |  |  |  |  |
|                          |                            | 1       |                      | Master I/O           |  |  |  |  |  |  |
|                          | Slave Mode of Operation    |         |                      |                      |  |  |  |  |  |  |
| Normal                   | 0                          | Х       | Slave Out            | Slave In             |  |  |  |  |  |  |
| Bidirectional            | Bidirectional 1 0 Slave In |         | Slave In             | MOSI not used by SPI |  |  |  |  |  |  |
|                          |                            | 1       | Slave I/O            |                      |  |  |  |  |  |  |

Any access to TCNT will clear TFLG2 register if the TFFCA bit in TSCR register is set.

#### Table 23-17. TRLG2 Field Descriptions

| Field    | Description                                                                                                                                                                                                                                                                 |
|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>TOF | <b>Timer Overflow Flag</b> — Set when 16-bit free-running timer overflows from 0xFFFF to 0x0000. Clearing this bit requires writing a one to bit 7 of TFLG2 register while the TEN bit of TSCR1 or PAEN bit of PACTL is set to one (See also TCRE control bit explanation). |

### 23.3.2.14 Timer Input Capture/Output Compare Registers High and Low 0– 7(TCxH and TCxL)



Figure 23-23. Timer Input Capture/Output Compare Register x Low (TCxL)

<sup>1</sup> This register is available only when the corresponding channel exists and is reserved if that channel does not exist. Writes to a reserved register have no functional effect. Reads from a reserved register return zeroes.

Depending on the TIOS bit for the corresponding channel, these registers are used to latch the value of the free-running counter when a defined transition is sensed by the corresponding input capture edge detector or to trigger an output action for output compare.

#### Read: Anytime

Write: Anytime for output compare function.Writes to these registers have no meaning or effect during input capture. All timer input capture/output compare registers are reset to 0x0000.

#### NOTE

Read/Write access in byte mode for high byte should take place before low byte otherwise it will give a different result.

#### MC9S12G Family Reference Manual Rev.1.27

| Register | Error Bit | Error Condition                                                                           |
|----------|-----------|-------------------------------------------------------------------------------------------|
|          |           | Set if CCOBIX[2:0] != 001 at command launch                                               |
|          | ACCERR    | Set if command not available in current mode (see Table 24-25)                            |
|          | ACCERK    | Set if an invalid FlashBlockSelectionCode[1:0] is supplied (See Table 24-32) <sup>1</sup> |
| FSTAT    |           | Set if an invalid margin level setting is supplied                                        |
|          | FPVIOL    | None                                                                                      |
|          | MGSTAT1   | None                                                                                      |
|          | MGSTAT0   | None                                                                                      |

| Table 24-57. Set Field Margin Level | <b>Command Error Handling</b> |
|-------------------------------------|-------------------------------|
|-------------------------------------|-------------------------------|

<sup>1</sup> As defined by the memory map for FTMRG32K1.

### CAUTION

Field margin levels must only be used during verify of the initial factory programming.

#### NOTE

Field margin levels can be used to check that Flash memory contents have adequate margin for data retention at the normal level setting. If unexpected results are encountered when checking Flash memory contents at field margin levels, the Flash memory contents should be erased and reprogrammed.

### 24.4.6.14 Erase Verify EEPROM Section Command

The Erase Verify EEPROM Section command will verify that a section of code in the EEPROM is erased. The Erase Verify EEPROM Section command defines the starting point of the data to be verified and the number of words.

| CCOBIX[2:0] | FCCOB Parameters                                       |                                                           |  |  |  |  |  |
|-------------|--------------------------------------------------------|-----------------------------------------------------------|--|--|--|--|--|
| 000         | 0x10                                                   | Global address [17:16] to<br>identify the EEPROM<br>block |  |  |  |  |  |
| 001         | Global address [15:0] of the first word to be verified |                                                           |  |  |  |  |  |
| 010         | Number of words to be verified                         |                                                           |  |  |  |  |  |

Table 24-58. Erase Verify EEPROM Section Command FCCOB Requirements

Upon clearing CCIF to launch the Erase Verify EEPROM Section command, the Memory Controller will verify the selected section of EEPROM memory is erased. The CCIF flag will set after the Erase Verify EEPROM Section operation has completed. If the section is not erased, it means blank check failed, both MGSTAT bits will be set.



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

### 28.3.2.15 Flash Reserved4 Register (FRSV4)

This Flash register is reserved for factory testing.





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

## 28.3.2.16 Flash Option Register (FOPT)

The FOPT register is the Flash option register.





<sup>1</sup> Loaded from IFR Flash configuration field, during reset sequence.

All bits in the FOPT register are readable but are not writable.

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

### NOTE

User margin levels can be used to check that Flash memory contents have adequate margin for normal level read operations. If unexpected results are encountered when checking Flash memory contents at user margin levels, a potential loss of information has been detected.

### 28.4.6.13 Set Field Margin Level Command

The Set Field Margin Level command, valid in special modes only, causes the Memory Controller to set the margin level specified for future read operations of the P-Flash or EEPROM block.

Upon clearing CCIF to launch the Set Field Margin Level command, the Memory Controller will set the Table 28-57. Set Field Margin Level Command FCCOB Requirements

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

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

# Chapter 31 240 KByte Flash Module (S12FTMRG240K2V1)

| Revision<br>Number | Revision<br>Date | Sections<br>Affected                                                   | Description of Changes                                        |
|--------------------|------------------|------------------------------------------------------------------------|---------------------------------------------------------------|
| V01.06             | 23 Jun 2010      | 31.4.6.2/31-115<br>9<br>31.4.6.12/31-11<br>66<br>31.4.6.13/31-11<br>67 | Updated description of the commands RD1BLK, MLOADU and MLOADF |
| V01.07             | 20 aug 2010      | 31.4.6.2/31-115<br>9<br>31.4.6.12/31-11<br>66<br>31.4.6.13/31-11<br>67 | Updated description of the commands RD1BLK, MLOADU and MLOADF |
| Rev.1.27           | 31 Jan 2011      | 31.3.2.9/31-114<br>2                                                   | Updated description of protection on Section 31.3.2.9         |

#### Table 31-1. Revision History

# 31.1 Introduction

The FTMRG240K2 module implements the following:

- 240Kbytes of P-Flash (Program Flash) memory
- 4Kbytes of EEPROM memory

The Flash memory is ideal for single-supply applications allowing for field reprogramming without requiring external high voltage sources for program or erase operations. The Flash module includes a memory controller that executes commands to modify Flash memory contents. The user interface to the memory controller consists of the indexed Flash Common Command Object (FCCOB) register which is written to with the command, global address, data, and any required command parameters. The memory controller must complete the execution of a command before the FCCOB register can be written to with a new command.

### CAUTION

A Flash word or phrase must be in the erased state before being programmed. Cumulative programming of bits within a Flash word or phrase is not allowed.

## 31.3.2.9.1 P-Flash Protection Restrictions

The general guideline is that P-Flash protection can only be added and not removed. Table 31-21 specifies all valid transitions between P-Flash protection scenarios. Any attempt to write an invalid scenario to the FPROT register will be ignored. The contents of the FPROT register reflect the active protection scenario. See the FPHS and FPLS bit descriptions for additional restrictions.

| From<br>Protection<br>Scenario | To Protection Scenario <sup>1</sup> |   |   |   |   |   |   |   |  |  |
|--------------------------------|-------------------------------------|---|---|---|---|---|---|---|--|--|
|                                | 0                                   | 1 | 2 | 3 | 4 | 5 | 6 | 7 |  |  |
| 0                              | Х                                   | Х | Х | Х |   |   |   |   |  |  |
| 1                              |                                     | Х |   | Х |   |   |   |   |  |  |
| 2                              |                                     |   | Х | Х |   |   |   |   |  |  |
| 3                              |                                     |   |   | Х |   |   |   |   |  |  |
| 4                              |                                     |   |   | Х | Х |   |   |   |  |  |
| 5                              |                                     |   | Х | Х | Х | Х |   |   |  |  |
| 6                              |                                     | Х |   | Х | Х |   | Х |   |  |  |
| 7                              | Х                                   | Х | Х | Х | Х | Х | Х | Х |  |  |

Table 31-21. P-Flash Protection Scenario Transitions

<sup>1</sup> Allowed transitions marked with X, see Figure 31-14 for a definition of the scenarios.

# 31.3.2.10 EEPROM Protection Register (EEPROT)

The EEPROT register defines which EEPROM sectors are protected against program and erase operations.



<sup>1</sup> Loaded from IFR Flash configuration field, during reset sequence.

The (unreserved) bits of the EEPROT register are writable with the restriction that protection can be added but not removed. Writes must increase the DPS value and the DPOPEN bit can only be written from 1 (protection disabled) to 0 (protection enabled). If the DPOPEN bit is set, the state of the DPS bits is irrelevant.

During the reset sequence, fields DPOPEN and DPS of the EEPROT register are loaded with the contents of the EEPROM protection byte in the Flash configuration field at global address 0x3\_FF0D located in

### 0x0020–0x002F Debug Module (DBG)

| Address  | Name       |   | Bit 7  | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1  | Bit 0  |
|----------|------------|---|--------|-------|-------|-------|-------|-------|--------|--------|
| 0x0029   | DBGXAH     | R | 0      | 0     | 0     | 0     | 0     | 0     | Rit 17 | Bit 16 |
| 070020   | DDG/UIT    | W |        |       |       |       |       |       | DICT   | Dit 10 |
| 0x002A   | DBGXAM     | R | Bit 15 | 14    | 13    | 12    | 11    | 10    | 9      | Bit 8  |
| 00002/1  | DDO/U III  | W | Bit 10 |       | 10    | 12    |       | 10    |        | Dir U  |
| 0x002B   | DBGXAI     | R | Bit 7  | 6     | 5     | 4     | 3     | 2     | 1      | Bit 0  |
| 0.0020   | 886,442    | W | BRT    | Ŭ     | -     | •     |       | -     |        | Dir u  |
| 0x002C   | DBGADH     | R | Bit 15 | 14    | 13    | 12    | 11    | 10    | 9      | Bit 8  |
|          |            | W |        |       |       |       |       |       | -      |        |
| 0x002D   | DBGADI     | R | Bit 7  | 6     | 5     | 4     | 3     | 2     | 1      | Bit 0  |
| 0//0022  |            | W | 2      | Ť     | -     |       | -     | -     |        | 2      |
| 0x002F   | DBGADHM    | R | Bit 15 | 14    | 13    | 12    | 11    | 10    | 9      | Bit 8  |
| 0/0022   | 220,121    | W | Bit To |       |       |       |       |       |        | Dir o  |
| 0x002F   | DBGADI M   | R | Bit 7  | 6     | 5     | 4     | 3     | 2     | 1      | Bit 0  |
| 0//00/21 | BBC, IBEIM | W | Dit i  | Ĵ     | J     | •     | Ŭ     | -     |        | Dir U  |

### 0x0030-0x033 Reserved

| Address | Name     |   | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|----------|---|-------|-------|-------|-------|-------|-------|-------|-------|
| 0x0030- | Reserved | R | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| 0x0033  | Reserved | W |       |       |       |       |       |       |       |       |

# 0x0034–0x003F Clock and Power Management (CPMU) Map 1 of 2

| Address | Name            |                | Bit 7   | Bit 6       | Bit 5       | Bit 4  | Bit 3       | Bit 2    | Bit 1         | Bit 0  |  |
|---------|-----------------|----------------|---------|-------------|-------------|--------|-------------|----------|---------------|--------|--|
| 0x0034  | CPMU<br>SYNR    | R<br>W         | VCOFF   | RQ[1:0]     | SYNDIV[5:0] |        |             |          |               |        |  |
| 0x0035  | CPMU<br>REFDIV  | R<br>W         | REFFF   | RQ[1:0]     | 0           | 0      | REFDIV[3:0] |          |               |        |  |
| 0x0036  | CPMU<br>POSTDIV | R              | 0       | 0           | 0           |        | )]          |          |               |        |  |
|         |                 | W              |         |             |             |        |             |          |               |        |  |
| 0x0037  | CPMUFLG         | <sub>G</sub> R | RTIF    | PORF        | IVRF        | LOCKIF | LOCK        | ILAF     | OSCIF         | UPOSC  |  |
|         |                 | W              | /       | 1.014       | LVIG        |        |             |          |               |        |  |
| 0x0038  | CPMUINT         | R<br>W         | RTIF    | 0           | 0           | LOCKIE | 0           | 0        | OSCIE         | 0      |  |
|         |                 |                |         |             |             |        |             |          |               |        |  |
| 0x0039  | CPMUCLKS        | s R<br>W       |         | PLLSEL PSTP | 0           | 0      | PRE         | PCE      | RTI<br>OSCSEL | COP    |  |
|         |                 |                | I LLOLL |             |             |        |             |          |               | OSCSEL |  |
| 0x003A  | CPMUPLL         | L R<br>W       | 0       | 0           | FM1         | FM0    | 0           | 0        | 0             | 0      |  |
|         |                 |                |         |             |             |        |             |          |               |        |  |
| 0x003B  | CPMURTI         | R              | RTDEC   | RTR6        | RTR5        | RTR4   | RTR3        | RTR2     | RTR1          | RTR0   |  |
|         |                 | W              | NIDLO   |             |             |        |             |          |               |        |  |
| 0x003C  | CPMUCOP         | R<br>W         |         | RSBCK       | 0           | 0      | 0           | 0<br>CR2 | CR1           | CR0    |  |
|         |                 |                | WCOP    |             | WRTMAS      |        |             |          |               |        |  |
|         |                 |                |         |             | K           |        |             |          |               |        |  |

## 0x0070–0x09F Analog to Digital Converter (ADC)

| Address           | Name      |        | Bit 7                                                                                                                           | Bit 6                                                                                                                           | Bit 5                          | Bit 4                          | Bit 3                        | Bit 2                        | Bit 1            | Bit 0 |  |  |  |
|-------------------|-----------|--------|---------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------|--------------------------------|--------------------------------|------------------------------|------------------------------|------------------|-------|--|--|--|
| 0x007A            | ATDSTAT2H | R      |                                                                                                                                 |                                                                                                                                 |                                | CCF                            | [15:8]                       |                              |                  |       |  |  |  |
|                   |           | W      |                                                                                                                                 |                                                                                                                                 |                                | 000                            | 17.01                        |                              |                  |       |  |  |  |
| 0x007B            | ATDSTAT2L | ĸ      |                                                                                                                                 |                                                                                                                                 |                                |                                | [7:0]                        |                              |                  |       |  |  |  |
| 0x007C            | ATDDIENH  | R<br>W |                                                                                                                                 | IEN[15:8]                                                                                                                       |                                |                                |                              |                              |                  |       |  |  |  |
| 0x007D            | ATDDIENL  | R<br>W |                                                                                                                                 | IEN[7:0]                                                                                                                        |                                |                                |                              |                              |                  |       |  |  |  |
| 0x007E            | ATDCMPHTH | R<br>W | CMPHT[15:8]                                                                                                                     |                                                                                                                                 |                                |                                |                              |                              |                  |       |  |  |  |
| 0x007F            | ATDCMPHTL | R<br>W | CMPHT[7:0]                                                                                                                      |                                                                                                                                 |                                |                                |                              |                              |                  |       |  |  |  |
| 0x0080-<br>0x0091 | ATDDR0    | R<br>W |                                                                                                                                 | See Section 16.3.2.12.1, "Left Justified Result Data (DJM=0)"<br>and Section 16.3.2.12.2, "Right Justified Result Data (DJM=1)" |                                |                                |                              |                              |                  |       |  |  |  |
| 0x0082-<br>0x0083 | ATDDR1    | R<br>W |                                                                                                                                 | See Section 16.3.2.12.1, "Left Justified Result Data (DJM=0)"<br>and Section 16.3.2.12.2, "Right Justified Result Data (DJM=1)" |                                |                                |                              |                              |                  |       |  |  |  |
| 0x0084-<br>0x0085 | ATDDR2    | R<br>W |                                                                                                                                 | See Section 16.3.2.12.1, "Left Justified Result Data (DJM=0)"<br>and Section 16.3.2.12.2, "Right Justified Result Data (DJM=1)" |                                |                                |                              |                              |                  |       |  |  |  |
| 0x0086-<br>0x0087 | ATDDR3    | R<br>W |                                                                                                                                 | See Section 16.3.2.12.1, "Left Justified Result Data (DJM=0)"<br>and Section 16.3.2.12.2, "Right Justified Result Data (DJM=1)" |                                |                                |                              |                              |                  |       |  |  |  |
| 0x0088-<br>0x0089 | ATDDR4    | R<br>W |                                                                                                                                 | See Section 16.3.2.12.1, "Left Justified Result Data (DJM=0)"<br>and Section 16.3.2.12.2, "Right Justified Result Data (DJM=1)" |                                |                                |                              |                              |                  |       |  |  |  |
| 0x008A-<br>0x008B | ATDDR5    | R<br>W |                                                                                                                                 | See Section 16.3.2.12.1, "Left Justified Result Data (DJM=0)"<br>and Section 16.3.2.12.2, "Right Justified Result Data (DJM=1)" |                                |                                |                              |                              |                  |       |  |  |  |
| 0x008C-<br>0x008D | ATDDR6    | R<br>W |                                                                                                                                 | See Section 16.3.2.12.1, "Left Justified Result Data (DJM=0)"<br>and Section 16.3.2.12.2, "Right Justified Result Data (DJM=1)" |                                |                                |                              |                              |                  |       |  |  |  |
| 0x008E-<br>0x008F | ATDDR7    | R<br>W |                                                                                                                                 | See Section 16.3.2.12.1, "Left Justified Result Data (DJM=0)"<br>and Section 16.3.2.12.2, "Right Justified Result Data (DJM=1)" |                                |                                |                              |                              |                  |       |  |  |  |
| 0x0090-<br>0x0091 | ATDDR8    | R<br>W |                                                                                                                                 | See Section 16.3.2.12.1, "Left Justified Result Data (DJM=0)"<br>and Section 16.3.2.12.2, "Right Justified Result Data (DJM=1)" |                                |                                |                              |                              |                  |       |  |  |  |
| 0x0092-<br>0x0093 | ATDDR9    | R<br>W |                                                                                                                                 | See S<br>and Se                                                                                                                 | ection 16.3.2<br>ection 16.3.2 | 2.12.1, "Left<br>.12.2, "Right | Justified Re<br>Justified Re | sult Data (D<br>sult Data (D | JM=0)"<br>JM=1)" |       |  |  |  |
| 0x0094-<br>0x0095 | ATDDR10   | R<br>W |                                                                                                                                 | See Section 16.3.2.12.1, "Left Justified Result Data (DJM=0)"<br>and Section 16.3.2.12.2, "Right Justified Result Data (DJM=1)" |                                |                                |                              |                              |                  |       |  |  |  |
| 0x0096-<br>0x0097 | ATDDR11   | R<br>W | See Section 16.3.2.12.1, "Left Justified Result Data (DJM=0)"<br>and Section 16.3.2.12.2, "Right Justified Result Data (DJM=1)" |                                                                                                                                 |                                |                                |                              |                              |                  |       |  |  |  |
| 0x0098-<br>0x0099 | ATDDR12   | R<br>W |                                                                                                                                 | See Section 16.3.2.12.1, "Left Justified Result Data (DJM=0)"<br>and Section 16.3.2.12.2, "Right Justified Result Data (DJM=1)" |                                |                                |                              |                              |                  |       |  |  |  |
| 0x009A-<br>0x009B | ATDDR13   | R<br>W | See Section 16.3.2.12.1, "Left Justified Result Data (DJM=0)"<br>and Section 16.3.2.12.2, "Right Justified Result Data (DJM=1)" |                                                                                                                                 |                                |                                |                              |                              |                  |       |  |  |  |
| 0x009C-<br>0x009D | ATDDR14   | R<br>W |                                                                                                                                 | See Section 16.3.2.12.1, "Left Justified Result Data (DJM=0)"<br>and Section 16.3.2.12.2, "Right Justified Result Data (DJM=1)" |                                |                                |                              |                              |                  |       |  |  |  |
| 0x009E-<br>0x009F | ATDDR15   | R<br>W |                                                                                                                                 | See Section 16.3.2.12.1, "Left Justified Result Data (DJM=0)"<br>and Section 16.3.2.12.2, "Right Justified Result Data (DJM=1)" |                                |                                |                              |                              |                  |       |  |  |  |