

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

E·XFI

| Product Status             | Active                                                      |
|----------------------------|-------------------------------------------------------------|
| Core Processor             | HCS12X                                                      |
| Core Size                  | 16-Bit                                                      |
| Speed                      | 80MHz                                                       |
| Connectivity               | CANbus, EBI/EMI, I <sup>2</sup> C, IrDA, LINbus, SCI, SPI   |
| Peripherals                | LVD, POR, PWM, WDT                                          |
| Number of I/O              | 91                                                          |
| Program Memory Size        | 128KB (128K x 8)                                            |
| Program Memory Type        | FLASH                                                       |
| EEPROM Size                | 2K x 8                                                      |
| RAM Size                   | 8K x 8                                                      |
| Voltage - Supply (Vcc/Vdd) | 2.35V ~ 5.5V                                                |
| Data Converters            | A/D 16x10b                                                  |
| Oscillator Type            | External                                                    |
| Operating Temperature      | -40°C ~ 125°C (TA)                                          |
| Mounting Type              | Surface Mount                                               |
| Package / Case             | 112-LQFP                                                    |
| Supplier Device Package    | 112-LQFP (20x20)                                            |
| Purchase URL               | https://www.e-xfl.com/pro/item?MUrl=&PartUrl=mc9s12xd128mal |

Email: info@E-XFL.COM

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



## **Section Number**

Title

## Page

| A.3 | NVM, ł   | Flash, and EEPROM 1259                                    |
|-----|----------|-----------------------------------------------------------|
|     | A.3.1    | NVM Timing                                                |
|     | A.3.2    | NVM Reliability                                           |
| A.4 | Voltage  | Regulator                                                 |
|     | A.4.1    | Chip Power-up and Voltage Drops                           |
|     | A.4.2    | Output Loads                                              |
| A.5 | Reset, C | Dscillator, and PLL                                       |
|     | A.5.1    | Startup                                                   |
|     | A.5.2    | Oscillator                                                |
|     | A.5.3    | Phase Locked Loop                                         |
| A.6 | MSCAN    | N                                                         |
| A.7 | SPI Tin  | ning                                                      |
|     | A.7.1    | Master Mode                                               |
|     | A.7.2    | Slave Mode                                                |
| A.8 | Externa  | 1 Bus Timing                                              |
|     | A.8.1    | Normal Expanded Mode (External Wait Feature Disabled)     |
|     | A.8.2    | Normal Expanded Mode (External Wait Feature Enabled)      |
|     | A.8.3    | Emulation Single-Chip Mode (Without Wait States)          |
|     | A.8.4    | Emulation Expanded Mode (With Optional Access Stretching) |
|     | A.8.5    | External Tag Trigger Timing                               |

# Appendix B

# Package Information

| <b>B</b> .1 | 144-Pin LQFP         | 1291 |
|-------------|----------------------|------|
| <b>B</b> .2 | 112-Pin LQFP Package | 1292 |
| <b>B.3</b>  | 80-Pin QFP Package   | 1293 |

# Appendix C Recommended PCB Layout

# Appendix D

# Using L15Y Silicon

## Appendix E Derivative Differences

| E.1 | Memory Sizes and Package Options S12XD - Family       | 1300   |
|-----|-------------------------------------------------------|--------|
| E.2 | Memory Sizes and Package Options S12XA & S12XB Family | . 1302 |
| E.3 | MC9S12XD-Family Flash Configuration                   | 1303   |
| E.4 | MC9S12XD/A/B -Family SRAM & EEPROM Configuration      | 1304   |
| E.5 | Peripheral Sets S12XD - Family                        | 1305   |
| E.6 | Peripheral Sets S12XA & S12XB - Family                | . 1306 |



## 2.4.2.2 Self Clock Mode

The VCO has a minimum operating frequency,  $f_{SCM}$ . If the external clock frequency is not available due to a failure or due to long crystal start-up time, the bus clock and the core clock are derived from the VCO running at minimum operating frequency; this mode of operation is called self clock mode. This requires CME = 1 and SCME = 1. If the MCU was clocked by the PLL clock prior to entering self clock mode, the PLLSEL bit will be cleared. If the external clock signal has stabilized again, the CRG will automatically select OSCCLK to be the system clock and return to normal mode. Section 2.4.1.4, "Clock Quality Checker" for more information on entering and leaving self clock mode.

## NOTE

In order to detect a potential clock loss the CME bit should be always enabled (CME = 1)!

If CME bit is disabled and the MCU is configured to run on PLL clock (PLLCLK), a loss of external clock (OSCCLK) will not be detected and will cause the system clock to drift towards the VCO's minimum frequency  $f_{SCM}$ . As soon as the external clock is available again the system clock ramps up to its PLL target frequency. If the MCU is running on external clock any loss of clock will cause the system to go static.

## 2.4.3 Low Power Options

This section summarizes the low power options available in the CRG.

## 2.4.3.1 Run Mode

The RTI can be stopped by setting the associated rate select bits to 0.

The COP can be stopped by setting the associated rate select bits to 0.

## 2.4.3.2 Wait Mode

The WAI instruction puts the MCU in a low power consumption stand-by mode depending on setting of the individual bits in the CLKSEL register. All individual wait mode configuration bits can be superposed. This provides enhanced granularity in reducing the level of power consumption during wait mode. Table 2-11 lists the individual configuration bits and the parts of the MCU that are affected in wait mode

|     | PLLWAI  | RTIWAI  | COPWAI  |  |
|-----|---------|---------|---------|--|
| PLL | Stopped | —       | _       |  |
| RTI |         | Stopped |         |  |
| COP | —       | —       | Stopped |  |

 Table 2-11. MCU Configuration During Wait Mode

After executing the WAI instruction the core requests the CRG to switch MCU into wait mode. The CRG then checks whether the PLLWAI bit is asserted (Figure 2-21). Depending on the configuration, the CRG switches the system and core clocks to OSCCLK by clearing the PLLSEL bit and disables the PLL. As soon as all clocks are switched off wait mode is active.

# 4.3.2.6 ATD Control Register 5 (ATDCTL5)

This register selects the type of conversion sequence and the analog input channels sampled. Writes to this register will abort current conversion sequence and start a new conversion sequence. If external trigger is enabled (ETRIGE = 1) an initial write to ATDCTL5 is required to allow starting of a conversion sequence which will then occur on each trigger event. Start of conversion means the beginning of the sampling phase.

| _      | 7   | 6    | 5    | 4    | 3  | 2  | 1  | 0  |
|--------|-----|------|------|------|----|----|----|----|
| R<br>W | DJM | DSGN | SCAN | MULT | CD | СС | СВ | CA |
| Reset  | 0   | 0    | 0    | 0    | 0  | 0  | 0  | 0  |

Figure 4-8. ATD Control Register 5 (ATDCTL5)

Read: Anytime

Write: Anytime

| Field     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>DJM  | <ul> <li>Result Register Data Justification — This bit controls justification of conversion data in the result registers.</li> <li>See Section 4.3.2.16, "ATD Conversion Result Registers (ATDDRx)" for details.</li> <li>Left justified data in the result registers.</li> <li>Right justified data in the result registers.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 6<br>DSGN | <ul> <li>Result Register Data Signed or Unsigned Representation — This bit selects between signed and unsigned conversion data representation in the result registers. Signed data is represented as 2's complement. Signed data is not available in right justification. See <st-bold>4.3.2.16 ATD Conversion Result Registers (ATDDRx) for details.</st-bold></li> <li>0 Unsigned data representation in the result registers.</li> <li>1 Signed data representation in the result registers.</li> <li>Table 4-15 summarizes the result data formats available and how they are set up using the control bits.</li> <li>Table 4-16 illustrates the difference between the signed and unsigned, left justified output codes for an input signal range between 0 and 5.12 Volts.</li> </ul> |
| 5<br>SCAN | <ul> <li>Continuous Conversion Sequence Mode — This bit selects whether conversion sequences are performed continuously or only once. If external trigger is enabled (ETRIGE=1) setting this bit has no effect, that means each trigger event starts a single conversion sequence.</li> <li>0 Single conversion sequence</li> <li>1 Continuous conversion sequences (scan mode)</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                  |
| 4<br>MULT | Multi-Channel Sample Mode — When MULT is 0, the ATD sequence controller samples only from the specified analog input channel for an entire conversion sequence. The analog channel is selected by channel selection code (control bits CD/CC/CB/CA located in ATDCTL5). When MULT is 1, the ATD sequence controller samples across channels. The number of channels sampled is determined by the sequence length value (S8C, S4C, S2C, S1C). The first analog channel examined is determined by channel selection code (CC, CB, CA control bits); subsequent channels sampled in the sequence are determined by incrementing the channel selection code or wrapping around to AN0 (channel 0.                                                                                               |

#### Table 4-14. ATDCTL5 Field Descriptions





Add Immediate 8 bit Constant (High Byte)



## Operation

RD + IMM8:\$00  $\Rightarrow RD$ 

Adds the content of high byte of register RD and a signed immediate 8 bit constant using binary addition and stores the result in the high byte of the destination register RD. This instruction can be used after an ADDL for a 16 bit immediate addition.

Example:

| ADDL | R2,#LOWBYTE  |   |    |   |    |   |    |     |           |
|------|--------------|---|----|---|----|---|----|-----|-----------|
| ADDH | R2,#HIGHBYTE | ; | R2 | = | R2 | + | 16 | bit | immediate |

## **CCR Effects**

| Ν | Ζ | V | С |
|---|---|---|---|
|   |   |   |   |

| $\Delta \mid \Delta \mid \Delta \mid \Delta$ |  |
|----------------------------------------------|--|
|----------------------------------------------|--|

- N: Set if bit 15 of the result is set; cleared otherwise.
- Z: Set if the result is \$0000; cleared otherwise.
- V: Set if a two's complement overflow resulted from the operation; cleared otherwise. RD[15]<sub>old</sub> & IMM8[7] & RD[15]<sub>new</sub> | RD[15]<sub>old</sub> & IMM8[7] & RD[15]<sub>new</sub>
- C: Set if there is a carry from the bit 15 of the result; cleared otherwise. RD[15]<sub>old</sub> & IMM8[7] | RD[15]<sub>old</sub> & RD[15]<sub>new</sub> | IMM8[7] & RD[15]<sub>new</sub>

## Code and CPU Cycles

| Source Form    | Address<br>Mode |   |   |   |   |   | Machin | e Code | Cycles |
|----------------|-----------------|---|---|---|---|---|--------|--------|--------|
| ADDH RD, #IMM8 | IMM8            | 1 | 1 | 1 | 0 | 1 | RD     | IMM8   | Р      |



# 7.3 Memory Map and Register Definition

This section provides a detailed description of all memory and registers.

# 7.3.1 Module Memory Map

The memory map for the ECT module is given below in Table 7-1. The address listed for each register is the address offset. The total address for each register is the sum of the base address for the ECT module and the address offset for each register.

| Address<br>Offset | Register                                                 | Access           |
|-------------------|----------------------------------------------------------|------------------|
| 0x0000            | Timer Input Capture/Output Compare Select (TIOS)         | R/W              |
| 0x0001            | Timer Compare Force Register (CFORC)                     | R/W <sup>1</sup> |
| 0x0002            | Output Compare 7 Mask Register (OC7M)                    | R/W              |
| 0x0003            | Output Compare 7 Data Register (OC7D)                    | R/W              |
| 0x0004            | Timer Count Register High (TCNT)                         | R/W <sup>2</sup> |
| 0x0005            | Timer Count Register Low (TCNT)                          | R/W <sup>2</sup> |
| 0x0006            | Timer System Control Register 1 (TSCR1)                  | R/W              |
| 0x0007            | Timer Toggle Overflow Register (TTOV)                    | R/W              |
| 0x0008            | Timer Control Register 1 (TCTL1)                         | R/W              |
| 0x0009            | Timer Control Register 2 (TCTL2)                         | R/W              |
| 0x000A            | Timer Control Register 3 (TCTL3)                         | R/W              |
| 0x000B            | Timer Control Register 4 (TCTL4)                         | R/W              |
| 0x000C            | Timer Interrupt Enable Register (TIE)                    | R/W              |
| 0x000D            | Timer System Control Register 2 (TSCR2)                  | R/W              |
| 0x000E            | Main Timer Interrupt Flag 1 (TFLG1)                      | R/W              |
| 0x000F            | Main Timer Interrupt Flag 2 (TFLG2)                      | R/W              |
| 0x0010            | Timer Input Capture/Output Compare Register 0 High (TC0) | R/W <sup>3</sup> |
| 0x0011            | Timer Input Capture/Output Compare Register 0 Low (TC0)  | R/W <sup>3</sup> |
| 0x0012            | Timer Input Capture/Output Compare Register 1 High (TC1) | R/W <sup>3</sup> |
| 0x0013            | Timer Input Capture/Output Compare Register 1 Low (TC1)  | R/W <sup>3</sup> |
| 0x0014            | Timer Input Capture/Output Compare Register 2 High (TC2) | R/W <sup>3</sup> |
| 0x0015            | Timer Input Capture/Output Compare Register 2 Low (TC2)  | R/W <sup>3</sup> |
| 0x0016            | Timer Input Capture/Output Compare Register 3 High (TC3) | R/W <sup>3</sup> |
| 0x0017            | Timer Input Capture/Output Compare Register 3 Low (TC3)  | R/W <sup>3</sup> |
| 0x0018            | Timer Input Capture/Output Compare Register 4 High (TC4) | R/W <sup>3</sup> |
| 0x0019            | Timer Input Capture/Output Compare Register 4 Low (TC4)  | R/W <sup>3</sup> |
| 0x001A            | Timer Input Capture/Output Compare Register 5 High (TC5) | R/W <sup>3</sup> |
| 0x001B            | Timer Input Capture/Output Compare Register 5 Low (TC5)  | R/W <sup>3</sup> |
| 0x001C            | Timer Input Capture/Output Compare Register 6 High (TC6) | R/W <sup>3</sup> |
| 0x001D            | Timer Input Capture/Output Compare Register 6 Low (TC6)  | R/W <sup>3</sup> |



Chapter 9 Inter-Integrated Circuit (IICV2) Block Description





#### Read: Anytime

Write: Anytime in initialization mode (INITRQ = 1 and INITAK = 1), except bits IDHITx, which are read-only

| Field            | Description                                                                                                                                                                                                                                                                                                         |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5:4<br>IDAM[1:0] | Identifier Acceptance Mode — The CPU sets these flags to define the identifier acceptance filter organization (see Section 10.4.3, "Identifier Acceptance Filter"). Table 10-17 summarizes the different settings. In filter closed mode, no message is accepted such that the foreground buffer is never reloaded. |

#### Table 10-16. CANIDAC Register Field Descriptions

2:0 Identifier Acceptance Hit Indicator — The MSCAN sets these flags to indicate an identifier acceptance hit (see IDHIT[2:0] Section 10.4.3, "Identifier Acceptance Filter"). Table 10-18 summarizes the different settings.

| Table 10-17. Identifie | r Acceptance | Mode Settings |
|------------------------|--------------|---------------|
|------------------------|--------------|---------------|

| IDAM1 | IDAM0 | Identifier Acceptance Mode     |  |
|-------|-------|--------------------------------|--|
| 0     | 0     | Two 32-bit acceptance filters  |  |
| 0     | 1     | Four 16-bit acceptance filters |  |
| 1     | 0     | Eight 8-bit acceptance filters |  |
| 1     | 1     | Filter closed                  |  |

#### Table 10-18. Identifier Acceptance Hit Indication

| IDHIT2 | IDHIT1 | IDHIT0 | Identifier Acceptance Hit |
|--------|--------|--------|---------------------------|
| 0      | 0      | 0      | Filter 0 hit              |
| 0      | 0      | 1      | Filter 1 hit              |
| 0      | 1      | 0      | Filter 2 hit              |
| 0      | 1      | 1      | Filter 3 hit              |
| 1      | 0      | 0      | Filter 4 hit              |
| 1      | 0      | 1      | Filter 5 hit              |
| 1      | 1      | 0      | Filter 6 hit              |
| 1      | 1      | 1      | Filter 7 hit              |

The IDHITx indicators are always related to the message in the foreground buffer (RxFG). When a message gets shifted into the foreground buffer of the receiver FIFO the indicators are updated as well.

## 10.3.2.13 MSCAN Reserved Register

This register is reserved for factory testing of the MSCAN module and is not available in normal system operation modes.



- <sup>1</sup> Not applicable for receive buffers
- <sup>2</sup> Read-only for CPU
- <sup>3</sup> Read-only for CPU

Figure 10-24 shows the common 13-byte data structure of receive and transmit buffers for extended identifiers. The mapping of standard identifiers into the IDR registers is shown in Figure 10-25.

All bits of the receive and transmit buffers are 'x' out of reset because of RAM-based implementation<sup>1</sup>. All reserved or unused bits of the receive and transmit buffers always read 'x'.

<sup>1.</sup> Exception: The transmit priority registers are 0 out of reset.



#### Chapter 10 Freescale's Scalable Controller Area Network (S12MSCANV3)



#### Figure 10-42. 8-bit Maskable Identifier Acceptance Filters



#### Chapter 11 Serial Communication Interface (S12SCIV5)

## 11.3.2.8 SCI Status Register 2 (SCISR2)



Figure 11-11. SCI Status Register 2 (SCISR2)

### Read: Anytime

Write: Anytime

#### Table 11-11. SCISR2 Field Descriptions

| Field      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>AMAP  | Alternative Map — This bit controls which registers sharing the same address space are accessible. In the reset condition the SCI behaves as previous versions. Setting AMAP=1 allows the access to another set of control and status registers and hides the baud rate and SCI control Register 1.<br>0 The registers labelled SCIBDH (0x0000),SCIBDL (0x0001), SCICR1 (0x0002) are accessible<br>1 The registers labelled SCIASR1 (0x0000),SCIACR1 (0x0001), SCIACR2 (0x00002) are accessible                                                                              |
| 4<br>TXPOL | <ul> <li>Transmit Polarity — This bit control the polarity of the transmitted data. In NRZ format, a one is represented by a mark and a zero is represented by a space for normal polarity, and the opposite for inverted polarity. In IrDA format, a zero is represented by short high pulse in the middle of a bit time remaining idle low for a one for normal polarity, and a zero is represented by short low pulse in the middle of a bit time remaining idle high for a one for inverted polarity.</li> <li>0 Normal polarity</li> <li>1 Inverted polarity</li> </ul> |
| 3<br>RXPOL | <ul> <li>Receive Polarity — This bit control the polarity of the received data. In NRZ format, a one is represented by a mark and a zero is represented by a space for normal polarity, and the opposite for inverted polarity. In IrDA format, a zero is represented by short high pulse in the middle of a bit time remaining idle low for a one for normal polarity, and a zero is represented by short low pulse in the middle of a bit time remaining idle high for a one for inverted polarity.</li> <li>0 Normal polarity</li> <li>1 Inverted polarity</li> </ul>     |
| 2<br>BRK13 | <ul> <li>Break Transmit Character Length — This bit determines whether the transmit break character is 10 or 11 bit respectively 13 or 14 bits long. The detection of a framing error is not affected by this bit.</li> <li>0 Break character is 10 or 11 bit long</li> <li>1 Break character is 13 or 14 bit long</li> </ul>                                                                                                                                                                                                                                                |
| 1<br>TXDIR | <ul> <li>Transmitter Pin Data Direction in Single-Wire Mode — This bit determines whether the TXD pin is going to be used as an input or output, in the single-wire mode of operation. This bit is only relevant in the single-wire mode of operation.</li> <li>0 TXD pin to be used as an input in single-wire mode</li> <li>1 TXD pin to be used as an output in single-wire mode</li> </ul>                                                                                                                                                                               |
| 0<br>RAF   | <ul> <li>Receiver Active Flag — RAF is set when the receiver detects a logic 0 during the RT1 time period of the start bit search. RAF is cleared when the receiver detects an idle character.</li> <li>0 No reception in progress</li> <li>1 Reception in progress</li> </ul>                                                                                                                                                                                                                                                                                               |







Figure 12-9. Reception with SPIF Serviced too Late



## 16.3.1.3 Interrupt Request Configuration Address Register (INT\_CFADDR)





### Read: Anytime

Write: Anytime

#### Table 16-5. INT\_CFADDR Field Descriptions

| Field                  | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–4<br>INT_CFADDR[7:4] | <ul> <li>Interrupt Request Configuration Data Register Select Bits — These bits determine which of the 128 configuration data registers are accessible in the 8 register window at INT_CFDATA0-7. The hexadecimal value written to this register corresponds to the upper nibble of the lower byte of the interrupt vector, i.e., writing 0xE0 to this register selects the configuration data register block for the 8 interrupt vector requests starting with vector (vector base + 0x00E0) to be accessible as INT_CFDATA0-7.</li> <li>Note: Writing all 0s selects non-existing configuration registers. In this case write accesses to INT_CFDATA0-7 will be ignored and read accesses will return all 0.</li> </ul> |



# Chapter 17 Memory Mapping Control (S12XMMCV2)

# 17.1 Introduction

This section describes the functionality of the module mapping control (MMC) sub-block of the S12X platform. The block diagram of the MMC is shown in Figure 1-1.

The MMC module controls the multi-master priority accesses, the selection of internal resources and external space. Internal buses including internal memories and peripherals are controlled in this module. The local address space for each master is translated to a global memory space.

## 17.1.1 Features

The main features of this block are:

- Paging capability to support a global 8 Mbytes memory address space
- Bus arbitration between the masters CPU, BDM, and XGATE
- Simultaneous accesses to different resources<sup>1</sup> (internal, external, and peripherals) (see Figure 1-1)
- Resolution of target bus access collision
- Access restriction control from masters to some targets (e.g., RAM write access protection for user specified areas)
- MCU operation mode control
- MCU security control
- Separate memory map schemes for each master CPU, BDM, and XGATE
- ROM control bits to enable the on-chip FLASH or ROM selection
- Port replacement registers access control
- Generation of system reset when CPU accesses an unimplemented address (i.e., an address which does not belong to any of the on-chip modules) in single-chip modes

## 17.1.2 Modes of Operation

This subsection lists and briefly describes all operating modes supported by the MMC.

## 17.1.2.1 Power Saving Modes

• Run mode

MMC is functional during normal run mode.

<sup>1.</sup> Resources are also called targets.



# 19.3.1.6 Debug Count Register (DBGCNT)



## Read: Anytime

Write: Never

#### Table 19-17. DBGCNT Field Descriptions

| Field           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6–0<br>CNT[6:0] | <b>Count Value</b> — The CNT bits [6:0] indicate the number of valid data 64-bit data lines stored in the trace buffer.<br>Table 19-18 shows the correlation between the CNT bits and the number of valid data lines in the trace buffer.<br>When the CNT rolls over to 0, the TBF bit in DBGSR is set and incrementing of CNT will continue in end-trigger<br>or mid-trigger mode. The DBGCNT register is cleared when ARM in DBGC1 is written to a 1. The DBGCNT<br>register is cleared by power-on-reset initialization but is not cleared by other system resets. Thus should a reset<br>occur during a debug session, the DBGCNT register still indicates after the reset, the number of valid trace buffer<br>entries stored before the reset occurred. The DBGCNT register is not decremented when reading from the trace<br>buffer. |

| TBF (DBGSR) | CNT[6:0]                                     | Description                                                                                                |
|-------------|----------------------------------------------|------------------------------------------------------------------------------------------------------------|
| 0           | 0000000                                      | No data valid                                                                                              |
| 0           | 0000001                                      | 32 bits of one line valid <sup>1</sup>                                                                     |
| 0           | 0000010                                      | 1 line valid                                                                                               |
| 0           | 0000011<br>0000100<br>0000110<br><br>1111100 | 1.5 lines valid <sup>1</sup><br>2 lines valid<br>3 lines valid<br><br>62 lines valid                       |
| 0           | 1111110                                      | 63 lines valid                                                                                             |
| 1           | 0000000                                      | 64 lines valid; if using begin-trigger alignment,<br>ARM bit will be cleared and the tracing session ends. |
| 1           | 0000010<br><br><br>1111110                   | 64 lines valid,<br>oldest data has been overwritten by most recent data                                    |

#### Table 19-18. CNT Decoding Table

<sup>1</sup> This applies to normal/loop1 modes when tracing from either CPU or XGATE only.



| 0x0029 | ADDRESS HIGH         | Read/Write |                         |
|--------|----------------------|------------|-------------------------|
| 0x002A | ADDRESS MEDIUM       | Read/Write |                         |
| 0x002B | ADDRESS LOW          | Read/Write |                         |
| 0x002C | DATA HIGH COMPARATOR | Read/Write | Comparator A and C only |
| 0x002D | DATA LOW COMPARATOR  | Read/Write | Comparator A and C only |
| 0x002E | DATA HIGH MASK       | Read/Write | Comparator A and C only |
| 0x002F | DATA LOW MASK        | Read/Write | Comparator A and C only |

#### Table 19-26. Comparator Register Layout

## 19.3.1.11.1 Debug Comparator Control Register (DBGXCTL)

The contents of this register bits 7 and 6 differ depending upon which comparator registers are visible in the 8-byte window of the DBG module register address map

0x0028



Figure 19-13. Debug Comparator Control Register (Comparators A and C)

0x0028



Figure 19-14. Debug Comparator Control Register (Comparators B and D)

Read: Anytime

Write: Anytime when DBG not armed.

Table 19-27. DBGXCTL Field Descriptions

| Field                 | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
|-----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>(COMPB/D)<br>SZE | <ul> <li>Size Comparator Enable Bit — The SZE bit controls whether access size comparison is enabled for the associated comparator. This bit is ignored if the TAG bit in the same register is set.</li> <li>0 Word/Byte access size is not used in comparison</li> <li>1 Word/Byte access size is used in comparison</li> </ul>                                                                                                                                                                                                                                                                                                              |
| 6<br>(COMPA/C)<br>NDB | <ul> <li>Not Data Bus Compare — The NDB bit controls whether the match occurs when the data bus matches the comparator register value or when the data bus differs from the register value. Furthermore database bits can be individually masked using the comparator data mask registers. This bit is only available for comparators A and C. This bit is ignored if the TAG bit in the same register is set. This bit position has an SZ functionality for comparators B and D.</li> <li>0 Match on data bus equivalence to comparator register contents</li> <li>1 Match on data bus difference to comparator register contents</li> </ul> |







All EABHI and EABLO bits read 0 and are not writable in normal modes.

All EABHI and EABLO bits are readable and writable in special modes.

The MCU address bit AB0 is not stored in the EADDR registers since the EEPROM block is not byte addressable.

## 26.3.2.9 EEPROM Data Registers (EDATA)

The EDATAHI and EDATALO registers are the EEPROM data registers.



All EDHI and EDLO bits read 0 and are not writable in normal modes.



# 28.3 Memory Map and Register Definition

This section describes the memory map and registers for the Flash module.

## 28.3.1 Module Memory Map

The Flash memory map is shown in Figure 28-2. The HCS12X architecture places the Flash memory addresses between global addresses 0x78\_0000 and 0x7F\_FFFF. The FPROT register, described in Section 28.3.2.5, "Flash Protection Register (FPROT)", can be set to protect regions in the Flash memory from accidental program or erase. Three separate memory regions, one growing upward from global address 0x7F\_8000 in the Flash memory (called the lower region), one growing downward from global address 0x7F\_FFFF in the Flash memory (called the higher region), and the remaining addresses in the Flash memory, can be activated for protection. The Flash memory addresses covered by these protectable regions are shown in the Flash memory map. The higher address region is mainly targeted to hold the boot loader code since it covers the vector space. The lower address region can be used for EEPROM emulation in an MCU without an EEPROM module since it can be left unprotected while the remaining addresses are protected from program or erase. Default protection settings as well as security information that allows the MCU to restrict access to the Flash module are stored in the Flash configuration field as described in Table 28-1.

| Global Address        | Size<br>(Bytes) | Description                                                                                        |
|-----------------------|-----------------|----------------------------------------------------------------------------------------------------|
| 0x7F_FF00 - 0x7F_FF07 | 8               | Backdoor Comparison Key<br>Refer to Section 28.6.1, "Unsecuring the MCU using Backdoor Key Access" |
| 0x7F_FF08 - 0x7F_FF0C | 5               | Reserved                                                                                           |
| 0x7F_FF0D             | 1               | Flash Protection byte<br>Refer to Section 28.3.2.5, "Flash Protection Register (FPROT)"            |
| 0x7F_FF0E             | 1               | Flash Nonvolatile byte<br>Refer to Section 28.3.2.8, "Flash Control Register (FCTL)"               |
| 0x7F_FF0F             | 1               | Flash Security byte<br>Refer to Section 28.3.2.2, "Flash Security Register (FSEC)"                 |

#### Table 28-1. Flash Configuration Field



| Conditions are 4.5 V < $V_{DD35}$ < 5.5 V Temperature from -40°C to +140°C, unless otherwise noted |   |                    |                  |      |     |      |      |  |  |  |  |  |  |
|----------------------------------------------------------------------------------------------------|---|--------------------|------------------|------|-----|------|------|--|--|--|--|--|--|
| Num                                                                                                | С | Rating             | Symbol           | Min  | Тур | Max  | Unit |  |  |  |  |  |  |
| 1                                                                                                  | Ρ | Input high voltage | VIH              | 1.75 | —   | —    | V    |  |  |  |  |  |  |
| 2                                                                                                  | Р | Input low voltage  | VIL              | _    | —   | 0.75 | V    |  |  |  |  |  |  |
| 3                                                                                                  | С | Input hysteresis   | V <sub>HYS</sub> | _    | 100 | —    | mV   |  |  |  |  |  |  |

#### Table A-8. I/O Characteristics for Port C, D, PE5, PE6, and PK7 for Reduced Input Voltage Thresholds

# A.1.10 Supply Currents

This section describes the current consumption characteristics of the device as well as the conditions for the measurements.

## A.1.10.1 Measurement Conditions

All measurements are without output loads. Unless otherwise noted the currents are measured in single chip mode and the CPU and XGATE code is executed from RAM,  $V_{DD35}=5.5V$ , internal voltage regulator is enabled and the bus frequency is 40MHz using a 4-MHz external clock source (PE7= $\overline{XCLKS}=0$ ). Production testing is performed using a square wave signal at the EXTAL input.



## A.3.1.3 Sector Erase

Erasing a 1024-byte Flash sector or a 4-byte EEPROM sector takes:

$$t_{era} \approx 4000 \cdot \frac{1}{f_{NVMOP}}$$

The setup time can be ignored for this operation.

## A.3.1.4 Mass Erase

Erasing a NVM block takes:

$$t_{mass} \approx 20000 \cdot \frac{1}{f_{NVMOP}}$$

The setup time can be ignored for this operation.

## A.3.1.5 Blank Check

The time it takes to perform a blank check on the Flash or EEPROM is dependent on the location of the first non-blank word starting at relative address zero. It takes one bus cycle per word to verify plus a setup of the command.

 $t_{check} \approx location \cdot t_{cyc} + 10 \cdot t_{cyc}$ 



| Component | Purpose                             | Туре                            | Value    |  |
|-----------|-------------------------------------|---------------------------------|----------|--|
| C1        | V <sub>DD1</sub> filter capacitor   | Ceramic                         | 220 nF   |  |
| C2        | V <sub>DD2</sub> filter capacitor   | Ceramic X7R                     | 220 nF   |  |
| C3        | V <sub>DDA</sub> filter capacitor   | Ceramic X7R                     | >=100 nF |  |
| C4        | V <sub>DDR</sub> filter capacitor   | X7R/tantalum                    | >=100 nF |  |
| C5        | V <sub>DDPLL</sub> filter capacitor | Ceramic X7R                     | 220 nF   |  |
| C6        | V <sub>DDX</sub> filter capacitor   | X7R/tantalum                    | >=100 nF |  |
| C7        | OSC load capacitor                  | Comes from crystal manufacturer |          |  |
| C8        | OSC load capacitor                  | -                               |          |  |
| C9        | PLL loop filter capacitor           | See PLL specification chapter   |          |  |
| C10       | PLL loop filter capacitor           | -                               |          |  |
| C11       | V <sub>DDX</sub> filter capacitor   | X7R/tantalum                    | >=100 nF |  |
| C12       | V <sub>DDX</sub> filter capacitor   | X7R/tantalum                    | >=100 nF |  |
| R1        | PLL loop filter resistor            | See PLL specification chapter   |          |  |
| Q1        | Quartz                              | —                               | —        |  |

| Table C-1. | Recommended | Decoupling | Capa | acitor | Choice |
|------------|-------------|------------|------|--------|--------|
|            |             |            |      |        |        |