# E·XFL



#### 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             | HCS12X                                                                |
| Core Size                  | 16-Bit                                                                |
| Speed                      | 40MHz                                                                 |
| Connectivity               | CANbus, SCI, SPI                                                      |
| Peripherals                | LVD, POR, PWM, WDT                                                    |
| Number of I/O              | 44                                                                    |
| Program Memory Size        | 64KB (64K x 8)                                                        |
| Program Memory Type        | FLASH                                                                 |
| EEPROM Size                | -                                                                     |
| RAM Size                   | 4K x 8                                                                |
| Voltage - Supply (Vcc/Vdd) | 1.72V ~ 5.5V                                                          |
| Data Converters            | A/D 8x12b                                                             |
| Oscillator Type            | External                                                              |
| Operating Temperature      | -40°C ~ 85°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/mc9s12xs64cae |

Email: info@E-XFL.COM

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

# NP

#### **Device Overview S12XS Family**

- Time-out interrupt and peripheral triggers
- Start of timers can be aligned
- Up to 8 channel x 8-bit or 4 channel x 16-bit Pulse Width Modulator
  - Programmable period and duty cycle per channel
  - Center- or left-aligned outputs
  - Programmable clock select logic with a wide range of frequencies
- Serial Peripheral Interface Module (SPI)
  - Configurable for 8 or 16-bit data size
  - Full-duplex or single-wire bidirectional
  - Double-buffered transmit and receive
  - Master or Slave mode
  - MSB-first or LSB-first shifting
  - Serial clock phase and polarity options
- Two Serial Communication Interfaces (SCI)
  - Full-duplex or single wire operation
  - Standard mark/space non-return-to-zero (NRZ) format
  - Selectable IrDA 1.4 return-to-zero-inverted (RZI) format with programmable pulse widths
  - 13-bit baud rate selection
  - Programmable character length
  - Programmable polarity for transmitter and receiver
  - Receive wakeup on active edge
  - Break detect and transmit collision detect supporting LIN
- On-Chip Voltage Regulator
  - Two parallel, linear voltage regulators with bandgap reference
  - Low-voltage detect (LVD) with low-voltage interrupt (LVI)
  - Power-on reset (POR) circuit
  - Low-voltage reset (LVR)
- Low-power wake-up timer (API)
  - Internal oscillator driving a down counter
  - Trimmable to +/-5% accuracy
  - Time-out periods range from 0.2ms to ~13s with a 0.2ms resolution
- Input/Output
  - Up to 91 general-purpose input/output (I/O) pins depending on the package option and 2 inputonly pins
  - Hysteresis and configurable pull up/pull down device on all input pins
  - Configurable drive strength on all output pins
- Package Options
  - 112-pin low-profile quad flat-pack (LQFP)
  - 80-pin quad flat-pack (QFP)





Figure 1-4. S12XS Family Pin Assignments 80-pin QFP Package

S12XS Family Reference Manual, Rev. 1.13



| Port | Pin Name | Pin Function<br>& Priority <sup>1</sup> | I/O | Description                                                                                           | Pin Function after Reset |
|------|----------|-----------------------------------------|-----|-------------------------------------------------------------------------------------------------------|--------------------------|
| М    | PM[7:6]  | GPIO                                    | I/O | General purpose                                                                                       | GPIO                     |
|      | PM5      | (SCK0)                                  | I/O | Serial Peripheral Interface 0 serial clock pin                                                        |                          |
|      |          | GPIO                                    | I/O | General purpose                                                                                       |                          |
|      | PM4      | (MOSI0)                                 | I/O | Serial Peripheral Interface 0 master out/slave in pin                                                 |                          |
|      |          | GPIO                                    | I/O | General purpose                                                                                       |                          |
|      | PM3      | (\$\$0)                                 | I/O | Serial Peripheral Interface 0 slave select output in master mode, input in slave mode or master mode. |                          |
|      |          | GPIO                                    | I/O | General purpose                                                                                       |                          |
|      | PM2      | (MISO0)                                 | I/O | Serial Peripheral Interface 0 master in/slave out pin                                                 |                          |
|      |          | GPIO                                    | I/O | General purpose                                                                                       |                          |
|      | PM1      | TXCAN0                                  | 0   | MSCAN0 transmit pin                                                                                   |                          |
|      |          | (TXD1)                                  | 0   | Serial Communication Interface 1 transmit pin                                                         |                          |
|      |          | GPIO                                    | I/O | General purpose                                                                                       |                          |
|      | PM0      | RXCAN0                                  | I   | MSCAN0 receive pin                                                                                    |                          |
|      |          | (RXD1)                                  | I   | Serial Communication Interface 1 receive pin                                                          |                          |
|      |          | GPIO                                    | I/O | General purpose                                                                                       |                          |

| Table 2-1. Pin | Functions a | nd Priorities | (continued) |
|----------------|-------------|---------------|-------------|
|                |             |               |             |



## 5.4.3 BDM Hardware Commands

Hardware commands are used to read and write target system memory locations and to enter active background debug mode. Target system memory includes all memory that is accessible by the CPU on the SOC which can be on-chip RAM, non-volatile memory (e.g. EEPROM, Flash EEPROM), I/O and control registers, and all external memory.

Hardware commands are executed with minimal or no CPU intervention and do not require the system to be in active BDM for execution, although, they can still be executed in this mode. When executing a hardware command, the BDM sub-block waits for a free bus cycle so that the background access does not disturb the running application program. If a free cycle is not found within 128 clock cycles, the CPU is momentarily frozen so that the BDM can steal a cycle. When the BDM finds a free cycle, the operation does not intrude on normal CPU operation provided that it can be completed in a single cycle. However, if an operation requires multiple cycles the CPU is frozen until the operation is complete, even though the BDM found a free cycle.

The BDM hardware commands are listed in Table 5-6.

The READ\_BD and WRITE\_BD commands allow access to the BDM register locations. These locations are not normally in the system memory map but share addresses with the application in memory. To distinguish between physical memory locations that share the same address, BDM memory resources are enabled just for the READ\_BD and WRITE\_BD access cycle. This allows the BDM to access BDM locations unobtrusively, even if the addresses conflict with the application memory map.

| Command       | Opcode<br>(hex) | Data                              | Description                                                                                                                           |
|---------------|-----------------|-----------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|
| BACKGROUND    | 90              | None                              | Enter background mode if firmware is enabled. If enabled, an ACK will be issued when the part enters active background mode.          |
| ACK_ENABLE    | D5              | None                              | Enable Handshake. Issues an ACK pulse after the command is executed.                                                                  |
| ACK_DISABLE   | D6              | None                              | Disable Handshake. This command does not issue an ACK pulse.                                                                          |
| READ_BD_BYTE  | E4              | 16-bit address<br>16-bit data out | Read from memory with standard BDM firmware lookup table in map.<br>Odd address data on low byte; even address data on high byte.     |
| READ_BD_WORD  | EC              | 16-bit address<br>16-bit data out | Read from memory with standard BDM firmware lookup table in map.<br>Must be aligned access.                                           |
| READ_BYTE     | E0              | 16-bit address<br>16-bit data out | Read from memory with standard BDM firmware lookup table out of map.<br>Odd address data on low byte; even address data on high byte. |
| READ_WORD     | E8              | 16-bit address<br>16-bit data out | Read from memory with standard BDM firmware lookup table out of map.<br>Must be aligned access.                                       |
| WRITE_BD_BYTE | C4              | 16-bit address<br>16-bit data in  | Write to memory with standard BDM firmware lookup table in map.<br>Odd address data on low byte; even address data on high byte.      |
| WRITE_BD_WORD | СС              | 16-bit address<br>16-bit data in  | Write to memory with standard BDM firmware lookup table in map.<br>Must be aligned access.                                            |
| WRITE_BYTE    | C0              | 16-bit address<br>16-bit data in  | Write to memory with standard BDM firmware lookup table out of map.<br>Odd address data on low byte; even address data on high byte.  |

#### Table 5-6. Hardware Commands



S12XE Clocks and Reset Generator (S12XECRGV1)

|            | RTR[6:4] =                  |                             |                             |                              |                              |                              |                               |                               |  |
|------------|-----------------------------|-----------------------------|-----------------------------|------------------------------|------------------------------|------------------------------|-------------------------------|-------------------------------|--|
| RTR[3:0]   | 000<br>(1x10 <sup>3</sup> ) | 001<br>(2x10 <sup>3</sup> ) | 010<br>(5x10 <sup>3</sup> ) | 011<br>(10x10 <sup>3</sup> ) | 100<br>(20x10 <sup>3</sup> ) | 101<br>(50x10 <sup>3</sup> ) | 110<br>(100x10 <sup>3</sup> ) | 111<br>(200x10 <sup>3</sup> ) |  |
| 0110 (÷7)  | 7x10 <sup>3</sup>           | 14x10 <sup>3</sup>          | 35x10 <sup>3</sup>          | 70x10 <sup>3</sup>           | 140x10 <sup>3</sup>          | 350x10 <sup>3</sup>          | 700x10 <sup>3</sup>           | 1.4x10 <sup>6</sup>           |  |
| 0111 (÷8)  | 8x10 <sup>3</sup>           | 16x10 <sup>3</sup>          | 40x10 <sup>3</sup>          | 80x10 <sup>3</sup>           | 160x10 <sup>3</sup>          | 400x10 <sup>3</sup>          | 800x10 <sup>3</sup>           | 1.6x10 <sup>6</sup>           |  |
| 1000 (÷9)  | 9x10 <sup>3</sup>           | 18x10 <sup>3</sup>          | 45x10 <sup>3</sup>          | 90x10 <sup>3</sup>           | 180x10 <sup>3</sup>          | 450x10 <sup>3</sup>          | 900x10 <sup>3</sup>           | 1.8x10 <sup>6</sup>           |  |
| 1001 (÷10) | 10 x10 <sup>3</sup>         | 20x10 <sup>3</sup>          | 50x10 <sup>3</sup>          | 100x10 <sup>3</sup>          | 200x10 <sup>3</sup>          | 500x10 <sup>3</sup>          | 1x10 <sup>6</sup>             | 2x10 <sup>6</sup>             |  |
| 1010 (÷11) | 11 x10 <sup>3</sup>         | 22x10 <sup>3</sup>          | 55x10 <sup>3</sup>          | 110x10 <sup>3</sup>          | 220x10 <sup>3</sup>          | 550x10 <sup>3</sup>          | 1.1x10 <sup>6</sup>           | 2.2x10 <sup>6</sup>           |  |
| 1011 (÷12) | 12x10 <sup>3</sup>          | 24x10 <sup>3</sup>          | 60x10 <sup>3</sup>          | 120x10 <sup>3</sup>          | 240x10 <sup>3</sup>          | 600x10 <sup>3</sup>          | 1.2x10 <sup>6</sup>           | 2.4x10 <sup>6</sup>           |  |
| 1100 (÷13) | 13x10 <sup>3</sup>          | 26x10 <sup>3</sup>          | 65x10 <sup>3</sup>          | 130x10 <sup>3</sup>          | 260x10 <sup>3</sup>          | 650x10 <sup>3</sup>          | 1.3x10 <sup>6</sup>           | 2.6x10 <sup>6</sup>           |  |
| 1101 (÷14) | 14x10 <sup>3</sup>          | 28x10 <sup>3</sup>          | 70x10 <sup>3</sup>          | 140x10 <sup>3</sup>          | 280x10 <sup>3</sup>          | 700x10 <sup>3</sup>          | 1.4x10 <sup>6</sup>           | 2.8x10 <sup>6</sup>           |  |
| 1110 (÷15) | 15x10 <sup>3</sup>          | 30x10 <sup>3</sup>          | 75x10 <sup>3</sup>          | 150x10 <sup>3</sup>          | 300x10 <sup>3</sup>          | 750x10 <sup>3</sup>          | 1.5x10 <sup>6</sup>           | 3x10 <sup>6</sup>             |  |
| 1111 (÷16) | 16x10 <sup>3</sup>          | 32x10 <sup>3</sup>          | 80x10 <sup>3</sup>          | 160x10 <sup>3</sup>          | 320x10 <sup>3</sup>          | 800x10 <sup>3</sup>          | 1.6x10 <sup>6</sup>           | 3.2x10 <sup>6</sup>           |  |

Table 8-11. RTI Frequency Divide Rates for RTDEC=1

## 8.3.2.9 S12XECRG COP Control Register (COPCTL)

This register controls the COP (Computer Operating Properly) watchdog.

Module Base + 0x0008

|                    | 7    | 6     | 5       | 4 | 3   | 2   | 1   | 0   |
|--------------------|------|-------|---------|---|-----|-----|-----|-----|
| R                  | R    | 0     | 0       | 0 | CDO | 001 | CDO |     |
| W                  | WCOP | RODUN | WRTMASK |   |     | GR2 | GRI | CRU |
| Reset <sup>1</sup> | 0    | 0     | 0       | 0 | 0   | 0   | 0   | 0   |

1. Refer to Device User Guide (Section: S12XECRG) for reset values of WCOP, CR2, CR1 and CR0.

= Unimplemented or Reserved

#### Figure 8-11. S12XECRG COP Control Register (COPCTL)

Read: Anytime

Write:

- 1. RSBCK: anytime in special modes; write to "1" but not to "0" in all other modes
- 2. WCOP, CR2, CR1, CR0:
  - Anytime in special modes
  - Write once in all other modes
    - Writing CR[2:0] to "000" has no effect, but counts for the "write once" condition.
    - Writing WCOP to "0" has no effect, but counts for the "write once" condition.



```
Pulse-Width Modulator (S12PWM8B8CV1)
```

Write: Anytime (any value written causes PWM counter to be reset to \$00).

## 13.3.2.13 PWM Channel Period Registers (PWMPERx)

There is a dedicated period register for each channel. The value in this register determines the period of the associated PWM channel.

The period registers for each channel are double buffered so that if they change while the channel is enabled, the change will NOT take effect until one of the following occurs:

- The effective period ends
- The counter is written (counter resets to \$00)
- The channel is disabled

In this way, the output of the PWM will always be either the old waveform or the new waveform, not some variation in between. If the channel is not enabled, then writes to the period register will go directly to the latches as well as the buffer.

#### NOTE

Reads of this register return the most recent value written. Reads do not necessarily return the value of the currently active period due to the double buffering scheme.

See Section 13.4.2.3, "PWM Period and Duty" for more information.

To calculate the output period, take the selected clock source period for the channel of interest (A, B, SA, or SB) and multiply it by the value in the period register for that channel:

- Left aligned output (CAEx = 0)
- PWMx Period=Channel Clock Period \* PWMPERx Center Aligned Output (CAEx=1) PWMx Period = Channel Clock Period \* (2 \* PWMPERx)

For boundary case programming values, please refer to Section 13.4.2.8, "PWM Boundary Cases".

Module Base + 0x0014 = PWMPER0, 0x0015 = PWMPER1, 0x0016 = PWMPER2, 0x0017 = PWMPER3 Module Base + 0x0018 = PWMPER4, 0x0019 = PWMPER5, 0x001A = PWMPER6, 0x001B = PWMPER7





Read: Anytime

Write: Anytime



## 14.4.5 Transmitter



Figure 14-16. Transmitter Block Diagram

## 14.4.5.1 Transmitter Character Length

The SCI transmitter can accommodate either 8-bit or 9-bit data characters. The state of the M bit in SCI control register 1 (SCICR1) determines the length of data characters. When transmitting 9-bit data, bit T8 in SCI data register high (SCIDRH) is the ninth bit (bit 8).

## 14.4.5.2 Character Transmission

To transmit data, the MCU writes the data bits to the SCI data registers (SCIDRH/SCIDRL), which in turn are transferred to the transmitter shift register. The transmit shift register then shifts a frame out through the TXD pin, after it has prefaced them with a start bit and appended them with a stop bit. The SCI data registers (SCIDRH and SCIDRL) are the write-only buffers between the internal data bus and the transmit shift register.



# 14.4.6 Receiver



Figure 14-20. SCI Receiver Block Diagram

## 14.4.6.1 Receiver Character Length

The SCI receiver can accommodate either 8-bit or 9-bit data characters. The state of the M bit in SCI control register 1 (SCICR1) determines the length of data characters. When receiving 9-bit data, bit R8 in SCI data register high (SCIDRH) is the ninth bit (bit 8).

## 14.4.6.2 Character Reception

During an SCI reception, the receive shift register shifts a frame in from the RXD pin. The SCI data register is the read-only buffer between the internal data bus and the receive shift register.

After a complete frame shifts into the receive shift register, the data portion of the frame transfers to the SCI data register. The receive data register full flag, RDRF, in SCI status register 1 (SCISR1) becomes set,



#### Serial Communication Interface (S12SCIV5)

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

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

 Table 14-18. Data Bit Recovery

#### NOTE

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

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

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

Table 14-19. Stop Bit Recovery



#### Serial Peripheral Interface (S12SPIV5)



 $\mathbf{t}_{L}$  = Minimum leading time before the first SCK edge

 $\bar{t_T}$  = Minimum trailing time after the last SCK edge

 $t_{I}$  = Minimum idling time between transfers (minimum  $\overline{SS}$  high time)

 $t_L$ ,  $t_T$ , and  $t_I$  are guaranteed for the master mode and required for the slave mode.

Figure 15-12. SPI Clock Format 0 (CPHA = 0), with 8-bit Transfer Width selected (XFRW = 0)



## 17.4.11.1 Low-Voltage Interrupt (LVI)

In FPM, VREG\_3V3 monitors the input voltage  $V_{DDA}$ . Whenever  $V_{DDA}$  drops below level  $V_{LVIA}$ , the status bit LVDS is set to 1. On the other hand, LVDS is reset to 0 when  $V_{DDA}$  rises above level  $V_{LVID}$ . An interrupt, indicated by flag LVIF = 1, is triggered by any change of the status bit LVDS if interrupt enable bit LVIE = 1.

#### NOTE

On entering the Reduced Power Mode, the LVIF is not cleared by the VREG\_3V3.

## 17.4.11.2 HTI - High Temperature Interrupt

In FPM VREG monitors the die temperature  $T_{DIE}$ . Whenever  $T_{DIE}$  exceeds level  $T_{HTIA}$  the status bit HTDS is set to 1. Vice versa, HTDS is reset to 0 when  $T_{DIE}$  get below level  $T_{HTID}$ . An interrupt, indicated by flag HTIF=1, is triggered by any change of the status bit HTDS if interrupt enable bit HTIE=1.

#### NOTE

On entering the Reduced Power Mode the HTIF is not cleared by the VREG.

## 17.4.11.3 Autonomous Periodical Interrupt (API)

As soon as the configured timeout period of the API has elapsed, the APIF bit is set. An interrupt, indicated by flag APIF = 1, is triggered if interrupt enable bit APIE = 1.





## 18.3.2.2 Flash Security Register (FSEC)

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



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

During the reset sequence, the FSEC register is loaded with the contents of the Flash security byte in the Flash configuration field at global address 0x7F\_FF0F located in P-Flash memory (see Table 18-3) as indicated by reset condition F in Figure 18-6. If a double bit fault is detected while reading the P-Flash phrase containing the Flash security byte during the reset sequence, all bits in the FSEC register will be set to leave the Flash module in a secured state with backdoor key access disabled.

| Table | 18-8. | <b>FSEC</b> | Field | Descri | ptions |
|-------|-------|-------------|-------|--------|--------|
|-------|-------|-------------|-------|--------|--------|

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

#### Table 18-9. Flash KEYEN States

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

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

#### Table 18-10. Flash Security States

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



keys stored in the Flash memory via the Memory Controller. If the keys presented in the Verify Backdoor Access Key command match the backdoor keys stored in the Flash memory, the SEC bits in the FSEC register (see Table 18-10) will be changed to unsecure the MCU. Key values of 0x0000 and 0xFFFF are not permitted as backdoor keys. While the Verify Backdoor Access Key command is active, P-Flash block 0 will not be available for read access and will return invalid data.

The user code stored in the P-Flash memory must have a method of receiving the backdoor keys from an external stimulus. This external stimulus would typically be through one of the on-chip serial ports.

If the KEYEN[1:0] bits are in the enabled state (see Section 18.3.2.2), the MCU can be unsecured by the backdoor key access sequence described below:

- 1. Follow the command sequence for the Verify Backdoor Access Key command as explained in Section 18.4.2.11
- 2. If the Verify Backdoor Access Key command is successful, the MCU is unsecured and the SEC[1:0] bits in the FSEC register are forced to the unsecure state of 10

The Verify Backdoor Access Key command is monitored by the Memory Controller and an illegal key will prohibit future use of the Verify Backdoor Access Key command. A reset of the MCU is the only method to re-enable the Verify Backdoor Access Key command.

After the backdoor keys have been correctly matched, the MCU will be unsecured. After the MCU is unsecured, the sector containing the Flash security byte can be erased and the Flash security byte can be reprogrammed to the unsecure state, if desired.

In the unsecure state, the user has full control of the contents of the backdoor keys by programming addresses  $0x7F_F00-0x7F_F07$  in the Flash configuration field.

The security as defined in the Flash security byte (0x7F\_FF0F) is not changed by using the Verify Backdoor Access Key command sequence. The backdoor keys stored in addresses 0x7F\_FF00-0x7F\_FF07 are unaffected by the Verify Backdoor Access Key command sequence. After the next reset of the MCU, the security state of the Flash module is determined by the Flash security byte (0x7F\_FF0F). The Verify Backdoor Access Key command sequence has no effect on the program and erase protections defined in the Flash protection register, FPROT.

# 18.5.2 Unsecuring the MCU in Special Single Chip Mode using BDM

The MCU can be unsecured in special single chip mode by erasing the P-Flash and D-Flash memory by one of the following methods:

- Reset the MCU into special single chip mode, delay while the erase test is performed by the BDM, send BDM commands to disable protection in the P-Flash and D-Flash memory, and execute the Erase All Blocks command write sequence to erase the P-Flash and D-Flash memory.
- Reset the MCU into special expanded wide mode, disable protection in the P-Flash and D-Flash memory and run code from external memory to execute the Erase All Blocks command write sequence to erase the P-Flash and D-Flash memory.

After the CCIF flag sets to indicate that the Erase All Blocks operation has completed, reset the MCU into special single chip mode. The BDM will execute the Erase Verify All Blocks command write sequence to verify that the P-Flash and D-Flash memory is erased. If the P-Flash and D-Flash memory are verified as

#### 128 KByte Flash Module (S12XFTMR128K1V1)

| CCOBIX[2:0] | FCCOB Parameters                                  |                                                   |  |  |  |  |
|-------------|---------------------------------------------------|---------------------------------------------------|--|--|--|--|
| 000         | 0x09                                              | Global address [22:16] to<br>identify Flash block |  |  |  |  |
| 001         | Global address [15:0] in Flash block to be erased |                                                   |  |  |  |  |

Upon clearing CCIF to launch the Erase Flash Block command, the Memory Controller will erase the selected Flash block and verify that it is erased. The CCIF flag will set after the Erase Flash Block operation has completed.

| Register | Error Bit | Error Condition                                                                                         |  |  |  |  |
|----------|-----------|---------------------------------------------------------------------------------------------------------|--|--|--|--|
|          |           | Set if CCOBIX[2:0] != 001 at command launch                                                             |  |  |  |  |
|          |           | Set if command not available in current mode (see Table 19-28)                                          |  |  |  |  |
|          | ACCERR    | Set if an invalid global address [22:16] is supplied                                                    |  |  |  |  |
| FSTAT    |           | Set if the supplied P-Flash address is not phrase-aligned or if the D-Flash address is not word-aligned |  |  |  |  |
|          | FPVIOL    | Set if an area of the selected Flash block is protected                                                 |  |  |  |  |
|          | MGSTAT1   | Set if any errors have been encountered during the verify operation                                     |  |  |  |  |
|          | MGSTAT0   | Set if any non-correctable errors have been encountered during the verify operation                     |  |  |  |  |

Table 19-46. Erase Flash Block Command Error Handling

## 19.4.2.9 Erase P-Flash Sector Command

The Erase P-Flash Sector operation will erase all addresses in a P-Flash sector.

Table 19-47. Erase P-Flash Sector Command FCCOB Requirements

| CCOBIX[2:0] | FCCOB Parameters                                                                                                         |                                                                  |  |  |  |  |  |
|-------------|--------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------|--|--|--|--|--|
| 000         | 0x0A                                                                                                                     | Global address [22:16] to identify<br>P-Flash block to be erased |  |  |  |  |  |
| 001         | Global address [15:0] anywhere within the sector to be erased.<br>Refer to Section 19.1.2.1 for the P-Flash sector size. |                                                                  |  |  |  |  |  |

Upon clearing CCIF to launch the Erase P-Flash Sector command, the Memory Controller will erase the selected Flash sector and then verify that it is erased. The CCIF flag will be set after the Erase P-Flash Sector operation has completed.



| ECMD   | Command                         | Function on D Flock Momeny                                                                                                                                                                                                                      |
|--------|---------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| FCIVID | Commanu                         |                                                                                                                                                                                                                                                 |
| 0x01   | Erase Verify All<br>Blocks      | Verify that all P-Flash (and D-Flash) blocks are erased.                                                                                                                                                                                        |
| 0x02   | Erase Verify Block              | Verify that a P-Flash block is erased.                                                                                                                                                                                                          |
| 0x03   | Erase Verify<br>P-Flash Section | Verify that a given number of words starting at the address provided are erased.                                                                                                                                                                |
| 0x04   | Read Once                       | Read a dedicated 64 byte field in the nonvolatile information register in P-Flash block 0 that was previously programmed using the Program Once command.                                                                                        |
| 0x06   | Program P-Flash                 | Program a phrase in a P-Flash block.                                                                                                                                                                                                            |
| 0x07   | Program Once                    | Program a dedicated 64 byte field in the nonvolatile information register in P-Flash block 0 that is allowed to be programmed only once.                                                                                                        |
| 0x08   | Erase All Blocks                | Erase all P-Flash (and D-Flash) blocks.<br>An erase of all Flash blocks is only possible when the FPLDIS, FPHDIS, and FPOPEN<br>bits in the FPROT register and the DPOPEN bit in the DFPROT register are set prior to<br>launching the command. |
| 0x09   | Erase Flash Block               | Erase a P-Flash (or D-Flash) block.<br>An erase of the full P-Flash block is only possible when FPLDIS, FPHDIS and FPOPEN<br>bits in the FPROT register are set prior to launching the command.                                                 |
| 0x0A   | Erase P-Flash<br>Sector         | Erase all bytes in a P-Flash sector.                                                                                                                                                                                                            |
| 0x0B   | Unsecure Flash                  | Supports a method of releasing MCU security by erasing all P-Flash (and D-Flash) blocks and verifying that all P-Flash (and D-Flash) blocks are erased.                                                                                         |
| 0x0C   | Verify Backdoor<br>Access Key   | Supports a method of releasing MCU security by verifying a set of security keys.                                                                                                                                                                |
| 0x0D   | Set User Margin<br>Level        | Specifies a user margin read level for all P-Flash blocks.                                                                                                                                                                                      |
| 0x0E   | Set Field Margin<br>Level       | Specifies a field margin read level for all P-Flash blocks (special modes only).                                                                                                                                                                |

#### Table 20-29. P-Flash Commands

## 20.4.1.5 D-Flash Commands

Table 20-30 summarizes the valid D-Flash commands along with the effects of the commands on the D-Flash block.

| FCMD | Command                    | Function on D-Flash Memory                                                                                                                                                                                                                      |
|------|----------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0x01 | Erase Verify All<br>Blocks | Verify that all D-Flash (and P-Flash) blocks are erased.                                                                                                                                                                                        |
| 0x02 | Erase Verify Block         | Verify that the D-Flash block is erased.                                                                                                                                                                                                        |
| 0x08 | Erase All Blocks           | Erase all D-Flash (and P-Flash) blocks.<br>An erase of all Flash blocks is only possible when the FPLDIS, FPHDIS, and FPOPEN<br>bits in the FPROT register and the DPOPEN bit in the DFPROT register are set prior to<br>launching the command. |
| 0x09 | Erase Flash Block          | Erase a D-Flash (or P-Flash) block.<br>An erase of the full D-Flash block is only possible when DPOPEN bit in the DFPROT register is set prior to launching the command.                                                                        |

#### Table 20-30. D-Flash Commands



#### Electrical Characteristics

The VDDX, VSSX pin pairs [2:1] supply the I/O pins.

VDDR supplies the internal voltage regulator.

VDDPLL, VSSPLL pin pair supply the oscillator and the PLL.

VSS1, VSS2 and VSS3 are internally connected by metal.

All VDDX pins are internally connected by metal.

All VSSX pins are internally connected by metal.

VDDA is connected to all VDDX pins by diodes for ESD protection such that VDDX must not exceed VDDA by more than a diode voltage drop. VDDA can exceed VDDX by more than a diode drop in order to support applications with a 5V A/D converter range and 3.3V I/O pin range.

VSSA and VSSX are connected by anti-parallel diodes for ESD protection.

#### NOTE

In the following context  $V_{DD35}$  is used for either VDDA, VDDR, and VDDX;  $V_{SS35}$  is used for either VSSA and VSSX unless otherwise noted.

 $I_{DD35}$  denotes the sum of the currents flowing into the VDDA and VDDR pins. The Run mode current in the VDDX domain is external load dependent.

 $V_{DD}$  is used for VDD,  $V_{SS}$  is used for VSS1, VSS2 and VSS3.

V<sub>DDPLL</sub> is used for VDDPLL, V<sub>SSPLL</sub> is used for VSSPLL

 $I_{\mbox{\scriptsize DD}}$  is used for the sum of the currents flowing into VDD, VDDF and VDDPLL.

## A.1.3 Pins

There are four groups of functional pins.

## A.1.3.1 I/O Pins

The I/O pins have a level in the range of 3.13V to 5.5V. This class of pins is comprised of all port I/O pins, the analog inputs, BKGD and the RESET pins. Some functionality may be disabled. For example the BKGD pin pull up is always enabled.

## A.1.3.2 Analog Reference

This group is made up by the  $V_{RH}$  and  $V_{RL}$  pins.

## A.1.3.3 Oscillator

The pins EXTAL, XTAL dedicated to the oscillator have a nominal 1.8V level. They are supplied by VDDPLL.



**Electrical Characteristics** 

| Num | С | Rating                                                                            | Symbol          | Min | Тур | Max | Unit |
|-----|---|-----------------------------------------------------------------------------------|-----------------|-----|-----|-----|------|
|     |   | LQFP 112                                                                          |                 |     | 1   | 1   |      |
| 1   | D | Thermal resistance LQFP 112, single sided PCB <sup>2</sup>                        | θ <sub>JA</sub> | _   | _   | 62  | °C/W |
| 2   | D | Thermal resistance LQFP 112, double sided PCB with 2 internal planes <sup>3</sup> | θ <sub>JA</sub> | _   | _   | 51  | °C/W |
| 3   | D | Junction to Board LQFP 112                                                        | $\theta_{JB}$   | _   | _   | 39  | °C/W |
| 4   | D | Junction to Case LQFP 112 <sup>4</sup>                                            | θ <sub>JC</sub> | _   | —   | 16  | °C/W |
| 5   | D | Junction to Package Top LQFP 112 <sup>5</sup>                                     | Ψ <sub>JT</sub> | _   | —   | 3   | °C/W |
|     |   | QFP 80                                                                            |                 |     |     |     |      |
| 6   | D | Thermal resistance QFP 80, single sided PCB <sup>2</sup>                          | θ <sub>JA</sub> | _   |     | 57  | °C/W |
| 7   | D | Thermal resistance QFP 80, double sided PCB with 2 internal planes <sup>3</sup>   | θ <sub>JA</sub> | —   | _   | 45  | °C/W |
| 8   | D | Junction to Board QFP 80                                                          | θ <sub>JB</sub> | _   | _   | 29  | °C/W |
| 9   | D | Junction to Case QFP 80 <sup>4</sup>                                              | θ <sub>JC</sub> | _   | _   | 20  | °C/W |
| 10  | D | Junction to Package Top QFP 80 <sup>5</sup>                                       | Ψ <sub>JT</sub> |     | —   | 5   | °C/W |
|     |   | LQFP 64                                                                           |                 |     |     |     |      |
| 11  | D | Thermal resistance LQFP 64, single sided PCB <sup>2</sup>                         | θ <sub>JA</sub> | —   | _   | 68  | °C/W |
| 12  | D | Thermal resistance LQFP 64, double sided PCB with 2 internal planes <sup>3</sup>  | θ <sub>JA</sub> | —   | _   | 50  | °C/W |
| 13  | D | Junction to Board LQFP 64                                                         | θ <sub>JB</sub> |     | —   | 32  | °C/W |
| 14  | D | Junction to Case LQFP 64 <sup>4</sup>                                             | θ <sub>JC</sub> |     | _   | 15  | °C/W |
| 15  | D | Junction to Package Top LQFP 64 <sup>5</sup>                                      | Ψ <sub>JT</sub> | _   | _   | 3   | °C/W |

| Table A-5. Thermal Package | Characteristics (9S12XS256) <sup>1</sup> |
|----------------------------|------------------------------------------|
|----------------------------|------------------------------------------|

1

2

3

The values for thermal resistance are achieved by package simulations Junction to ambient thermal resistance,  $\theta_{JA}$  was simulated to be equivalent to the JEDEC specification JESD51-2 in a horizontal configuration in natural convection. Junction to ambient thermal resistance,  $\theta_{JA}$  was simulated to be equivalent to the JEDEC specification JESD51-7 in a horizontal configuration in natural convection. Junction to case thermal resistance was simulated to be equivalent to the measured values using the cold plate technique with the cold plate temperature used as the "case" temperature. This basic cold plate measurement technique is described by MIL-STD 883D, Method 1012.1. This is the correct thermal metric to use to calculate thermal performance when the package is being used with a best sink 4 being used with a heat sink.

Thermal characterization parameter  $\Psi_{JT}$  is the "resistance" from junction to reference point thermocouple on top center of the case as defined in JESD51-2.  $\Psi_{JT}$  is a useful value to use to estimate junction temperature in a steady state customer 5 enviroment.





| Conditions are as shown in Table A-4, with 40MHz bus and f <sub>NVMOP</sub> = 1MHz unless otherwise noted. |   |                                                        |                     |     |                  |                    |                  |
|------------------------------------------------------------------------------------------------------------|---|--------------------------------------------------------|---------------------|-----|------------------|--------------------|------------------|
| Num                                                                                                        | С | Rating                                                 | Symbol              | Min | Тур              | Max                | Unit             |
| 1                                                                                                          | D | External oscillator clock                              | f <sub>NVMOSC</sub> | 2   | _                | 40 <sup>1</sup>    | MHz              |
| 2                                                                                                          | D | Bus frequency for programming or erase operations      | f <sub>NVMBUS</sub> | 1   | _                | 40                 | MHz              |
| 3                                                                                                          | D | Operating frequency                                    | f <sub>NVMOP</sub>  | 800 | _                | 1050               | kHz              |
| 4                                                                                                          | D | P-Flash phrase programming                             | t <sub>bwpgm</sub>  | _   | 171              | 183                | μs               |
| 6                                                                                                          | Р | P-Flash sector erase time                              | t <sub>era</sub>    | _   | 20               | 21                 | ms               |
| 7                                                                                                          | Ρ | Erase All Blocks (Mass erase) time                     | t <sub>mass</sub>   | _   | 101              | 102                | ms               |
| 7a                                                                                                         | D | Unsecure Flash                                         | t <sub>uns</sub>    | _   | 101              | 102                | ms               |
| 8                                                                                                          | D | P-Flash erase verify (blank check) time <sup>2</sup>   | t <sub>check</sub>  | _   | _                | 33500 <sup>2</sup> | t <sub>cyc</sub> |
| 9a                                                                                                         | D | D-Flash word programming 1 word                        | t <sub>dpgm</sub>   | _   | 97               | 104                | μs               |
| 9b                                                                                                         | D | D-Flash word programming 2 words                       | t <sub>dpgm</sub>   | _   | 167              | 181                | μs               |
| 9c                                                                                                         | D | D-Flash word programming 3 words                       | t <sub>dpgm</sub>   | _   | 237              | 258                | μs               |
| 9d                                                                                                         | D | D-Flash word programming 4 words                       | t <sub>dpgm</sub>   | _   | 307              | 335                | μs               |
| 9e                                                                                                         | D | D-Flash word programming 4 words crossing row boundary | t <sub>dpgm</sub>   | _   | 335              | 363                | μs               |
| 10                                                                                                         | D | D-Flash sector erase time                              | t <sub>eradf</sub>  | _   | 5.2 <sup>3</sup> | 21                 | ms               |
| 11                                                                                                         | D | D-Flash erase verify (blank check) time                | t <sub>check</sub>  | _   | —                | 17500              | t <sub>cyc</sub> |

#### Table A-18. NVM Timing Characteristics

Restrictions for oscillator in crystal mode apply. Valid for both "Erase verify all" or "Erase verify block" on 256K block without failing locations 1 2

This is a typical value for a new device 3

#### **NVM Reliability Parameters** A.3.2

The reliability of the NVM blocks is guaranteed by stress test during qualification, constant process monitors and burn-in to screen early life failures.

The data retention and program/erase cycling failure rates are specified at the operating conditions noted. The program/erase cycle count on the sector is incremented every time a sector or mass erase event is executed.

The standard shipping condition for both the D-Flash and P-Flash memory is erased with security disabled. However it is recommended that each block or sector is erased before factory programming to ensure that the full data retention capability is achieved. Data retention time is measured from the last erase operation.



## 0x0240–0x027F Port Integration Module (PIM) Map 5 of 5

| Address | Name     |        | Bit 7        | Bit 6        | Bit 5        | Bit 4        | Bit 3        | Bit 2        | Bit 1        | Bit 0        |
|---------|----------|--------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|--------------|
| 0x0260  | PTH      | R<br>W | PTH7         | PTH6         | PTH5         | PTH4         | PTH3         | PTH2         | PTH1         | PTH0         |
| 0x0261  | PTIH     | R<br>W | PTIH7        | PTIH6        | PTIH5        | PTIH4        | PTIH3        | PTIH2        | PTIH1        | PTIH0        |
| 0x0262  | DDRH     | R<br>W | DDRH7        | DDRH6        | DDRH5        | DDRH4        | DDRH3        | DDRH2        | DDRH1        | DDRH0        |
| 0x0263  | RDRH     | R<br>W | RDRH7        | RDRH6        | RDRH5        | RDRH4        | RDRH3        | RDRH2        | RDRH1        | RDRH0        |
| 0x0264  | PERH     | R<br>W | PERH7        | PERH6        | PERH5        | PERH4        | PERH3        | PERH2        | PERH1        | PERH0        |
| 0x0265  | PPSH     | R<br>W | PPSH7        | PPSH6        | PPSH5        | PPSH4        | PPSH3        | PPSH2        | PPSH1        | PPSH0        |
| 0x0266  | PIEH     | R<br>W | PIEH7        | PIEH6        | PIEH5        | PIEH4        | PIEH3        | PIEH2        | PIEH1        | PIEH0        |
| 0x0267  | PIFH     | R<br>W | PIFH7        | PIFH6        | PIFH5        | PIFH4        | PIFH3        | PIFH2        | PIFH1        | PIFH0        |
| 0x0268  | PTJ      | R<br>W | PTJ7         | PTJ6         | 0            | 0            | 0            | 0            | PTJ1         | PTJ0         |
| 0x0269  | PTIJ     | R      | PTIJ7        | PTIJ6        | 0            | 0            | 0            | 0            | PTIJ1        | PTIJ0        |
| 0/10200 |          | W      |              |              | 0            | 0            | 0            | 0            |              |              |
| 0x026A  | DDRJ     | W      | DDRJ7        | DDRJ6        | 0            | 0            | 0            | 0            | DDRJ1        | DDRJ0        |
| 0x026B  | RDRJ     | R<br>W | RDRJ7        | RDRJ6        | 0            | 0            | 0            | 0            | RDRJ1        | RDRJ0        |
| 0x026C  | PERJ     | R<br>W | PERJ7        | PERJ6        | 0            | 0            | 0            | 0            | PERJ1        | PERJ0        |
| 0x026D  | PPSJ     | R<br>W | PPSJ7        | PPSJ6        | 0            | 0            | 0            | 0            | PPSJ1        | PPSJ0        |
| 0x026E  | PIEJ     | R<br>W | PIEJ7        | PIEJ6        | 0            | 0            | 0            | 0            | PIEJ1        | PIEJ0        |
| 0x026f  | PIFJ     | R<br>W | PIFJ7        | PIFJ6        | 0            | 0            | 0            | 0            | PIFJ1        | PIFJ0        |
| 0x0270  | PTOADO   | R      | PT0AD0       |
| 0,0210  | 1 10/120 | W      | 7            | 6            | 5            | 4            | 3            | 2            | 1            | 0            |
| 0x0271  | PT1AD0   | R<br>W | PT1AD0<br>7  | PT1AD0<br>6  | PT1AD0<br>5  | PT1AD0<br>4  | PT1AD0<br>3  | PT1AD0<br>2  | PT1AD0<br>1  | PT1AD0<br>0  |
| 0x0272  | DDR0AD0  | R<br>W | DDR0AD0<br>7 | DDR0AD0<br>6 | DDR0AD0<br>5 | DDR0AD0<br>4 | DDR0AD0<br>3 | DDR0AD0<br>2 | DDR0AD0<br>1 | DDR0AD0<br>0 |
| 0x0273  | DDR1AD0  | R<br>W | DDR1AD0<br>7 | DDR1AD0<br>6 | DDR1AD0<br>5 | DDR1AD0<br>4 | DDR1AD0<br>3 | DDR1AD0<br>2 | DDR1AD0<br>1 | DDR1AD0<br>0 |
| 0x0274  | RDR0AD0  | R<br>W | RDR0AD0<br>7 | RDR0AD0<br>6 | RDR0AD0<br>5 | RDR0AD0<br>4 | RDR0AD0<br>3 | RDR0AD0<br>2 | RDR0AD0<br>1 | RDR0AD0<br>0 |
| 0x0275  | RDR1AD0  | R<br>W | RDR1AD0<br>7 | RDR1AD0<br>6 | RDR1AD0<br>5 | RDR1AD0<br>4 | RDR1AD0<br>3 | RDR1AD0<br>2 | RDR1AD0<br>1 | RDR1AD0<br>0 |



# Appendix F Ordering Information

# F.1 Ordering Information

The following figure provides an ordering part number example for the devices covered by this data book. There are two options when ordering a device. Customers must choose between ordering either the mask-specific part number or the generic / mask-independent part number. Ordering the mask-specific part number enables the customer to specify which particular maskset they will receive whereas ordering the generic maskset means that FSL will ship the currently preferred maskset (which may change over time). In either case, the marking on the device will always show the generic / mask-independent peritoneums and the mask set number.

## NOTE

The max length for the part number is 15 characters. Due to this limitation, in some situations, some characters are omitted. The mask identifier suffix and the Tape & Reel suffix are often both omitted from the part number which is actually marked on the device.

For specific part numbers to order, please contact your local sales office. The below figure illustrates the structure of a typical mask-specific ordering number for the S12XS family devices.



Figure F-1. Order Part Number Example

S12XS Family Reference Manual, Rev. 1.13