



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                      | 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        | 512KB (512K x 8)                                                        |
| Program Memory Type        | FLASH                                                                   |
| EEPROM Size                | 4K x 8                                                                  |
| RAM Size                   | 32K 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/product-detail/nxp-semiconductors/mc9s12xdp512mal |

Email: info@E-XFL.COM

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



### **Section Number**

Title

|     | 9.4.4 Operation in Stop Mode           | . 412 |
|-----|----------------------------------------|-------|
| 9.5 | Resets                                 | . 413 |
| 9.6 | Interrupts                             | . 413 |
| 9.7 | Initialization/Application Information | . 413 |
|     | 9.7.1 IIC Programming Examples         | . 413 |

## Chapter 10

# Freescale's Scalable Controller Area Network (S12MSCANV3)

| 10.1 | Introduction                                 |  |
|------|----------------------------------------------|--|
|      | 10.1.1 Glossary                              |  |
|      | 10.1.2 Block Diagram                         |  |
|      | 10.1.3 Features                              |  |
|      | 10.1.4 Modes of Operation                    |  |
| 10.2 | External Signal Description                  |  |
|      | 10.2.1 RXCAN — CAN Receiver Input Pin        |  |
|      | 10.2.2 TXCAN — CAN Transmitter Output Pin    |  |
|      | 10.2.3 CAN System                            |  |
| 10.3 | Memory Map and Register Definition           |  |
|      | 10.3.1 Module Memory Map                     |  |
|      | 10.3.2 Register Descriptions                 |  |
|      | 10.3.3 Programmer's Model of Message Storage |  |
| 10.4 | Functional Description                       |  |
|      | 10.4.1 General                               |  |
|      | 10.4.2 Message Storage                       |  |
|      | 10.4.3 Identifier Acceptance Filter          |  |
|      | 10.4.4 Modes of Operation                    |  |
|      | 10.4.5 Low-Power Options                     |  |
|      | 10.4.6 Reset Initialization                  |  |
|      | 10.4.7 Interrupts                            |  |
| 10.5 | Initialization/Application Information       |  |
|      | 10.5.1 MSCAN initialization                  |  |
|      | 10.5.2 Bus-Off Recovery                      |  |

## Chapter 11

# Serial Communication Interface (S12SCIV5)

| 11.1 | Introduction                | 477 |
|------|-----------------------------|-----|
|      | 11.1.1 Glossary             | 477 |
|      | 11.1.2 Features             | 477 |
|      | 11.1.3 Modes of Operation   | 478 |
|      | 11.1.4 Block Diagram        | 478 |
| 11.2 | External Signal Description | 480 |
|      | 11.2.1 TXD — Transmit Pin   | 480 |



# **Section Number**

Title

## Page

| 20.4 | Functional Description        | . 768 |
|------|-------------------------------|-------|
|      | 20.4.1 S12XDBG Operation      | . 768 |
|      | 20.4.2 Comparator Modes       | . 769 |
|      | 20.4.3 Trigger Modes          | . 772 |
|      | 20.4.4 State Sequence Control | . 774 |
|      | 20.4.5 Trace Buffer Operation | . 775 |
|      | 20.4.6 Tagging                | . 782 |
|      | 20.4.7 Breakpoints            | . 783 |

## Chapter 21 External Bus Interface (S12XEBIV2)

| 21.1 | Introduc   | ction                                       |     |
|------|------------|---------------------------------------------|-----|
|      | 21.1.1     | Features                                    |     |
|      | 21.1.2     | Modes of Operation                          |     |
|      | 21.1.3     | Block Diagram                               |     |
| 21.2 | External   | l Signal Description                        |     |
| 21.3 | Memory     | Map and Register Definition                 |     |
|      | 21.3.1     | Module Memory Map                           |     |
|      | 21.3.2     | Register Descriptions                       |     |
| 21.4 | Function   | nal Description                             |     |
|      | 21.4.1     | Operating Modes and External Bus Properties |     |
|      | 21.4.2     | Internal Visibility                         |     |
|      | 21.4.3     | Accesses to Port Replacement Registers      |     |
|      | 21.4.4     | Stretched External Bus Accesses             |     |
|      | 21.4.5     | Data Select and Data Direction Signals      |     |
|      | 21.4.6     | Low-Power Options                           | 801 |
| 21.5 | Initializa | ation/Application Information               | 801 |
|      | 21.5.1     | Normal Expanded Mode                        | 802 |
|      | 21.5.2     | Emulation Modes                             | 803 |

# Chapter 22

# DP512 Port Integration Module (S12XDP512PIMV2)

| 22.1 | Introduction                       | 807 |
|------|------------------------------------|-----|
|      | 22.1.1 Features                    | 808 |
|      | 22.1.2 Block Diagram               | 808 |
| 22.2 | External Signal Description        | 810 |
|      | 22.2.1 Signal Properties           | 810 |
| 22.3 | Memory Map and Register Definition | 817 |
|      | 22.3.1 Module Memory Map           | 817 |
|      | 22.3.2 Register Descriptions       | 820 |
| 22.4 | Functional Description             | 881 |
|      | 22.4.1 Registers                   | 881 |
|      |                                    |     |



| Pin        | Pin             | Pin        | Pin        | Pin        | Pin<br>Name<br>Function 5 Supply CTRL Reset<br>State State |               | Description |                                                                         |
|------------|-----------------|------------|------------|------------|------------------------------------------------------------|---------------|-------------|-------------------------------------------------------------------------|
| Function 1 | Function 2      | Function 3 | Function 4 | Function 5 |                                                            |               | Description |                                                                         |
| PE0        | XIRQ            | _          | _          | —          | V <sub>DDR</sub>                                           | PUCR          | Up          | Port E input, non-maskable interrupt                                    |
| PH7        | KWH7            | SS2        | TXD5       | —          | V <sub>DDR</sub>                                           | PERH/PPSH     | Disabled    | Port H I/O, interrupt, SS of SPI2, TXD of SCI5                          |
| PH6        | KWH6            | SCK2       | RXD5       | _          | V <sub>DDR</sub>                                           | PERH/<br>PPSH | Disabled    | Port H I/O, interrupt, SCK of SPI2, RXD of SCI5                         |
| PH5        | KWH5            | MOSI2      | TXD4       | _          | V <sub>DDR</sub>                                           | PERH/<br>PPSH | Disabled    | Port H I/O, interrupt, MOSI of SPI2, TXD of SCI4                        |
| PH4        | KWH4            | MISO2      | RXD4       | _          | V <sub>DDR</sub>                                           | PERH/PPSH     | Disabled    | Port H I/O, interrupt, MISO of SPI2, RXD of SCI4                        |
| PH3        | KWH3            | SS1        | _          |            | V <sub>DDR</sub>                                           | PERH/PPSH     | Disabled    | Port H I/O, interrupt, SS of SPI1                                       |
| PH2        | KWH2            | SCK1       | _          | _          | V <sub>DDR</sub>                                           | PERH/PPSH     | Disabled    | Port H I/O, interrupt, SCK of SPI1                                      |
| PH1        | KWH1            | MOSI1      |            | _          | V <sub>DDR</sub>                                           | PERH/PPSH     | Disabled    | Port H I/O, interrupt, MOSI of SPI1                                     |
| PH0        | KWH0            | MISO1      |            | _          | V <sub>DDR</sub>                                           | PERH/PPSH     | Disabled    | Port H I/O, interrupt, MISO of SPI1                                     |
| PJ7        | KWJ7            | TXCAN4     | SCL0       | TXCAN0     | V <sub>DDX</sub>                                           | PERJ/<br>PPSJ | Up          | Port J I/O, interrupt, TX of<br>CAN4, SCL of IIC0, TX of<br>CAN0        |
| PJ6        | KWJ6            | RXCAN4     | SDA0       | RXCAN0     | V <sub>DDX</sub>                                           | PERJ/<br>PPSJ | Up          | Port J I/O, interrupt, RX of<br>CAN4, SDA of IIC0, RX of<br>CAN0        |
| PJ5        | KWJ5            | SCL1       | CS2        | _          | V <sub>DDX</sub>                                           | PERJ/<br>PPSJ | Up          | Port J I/O, interrupt, SCL of IIC1, chip select 2                       |
| PJ4        | KWJ4            | SDA1       | CS0        | —          | V <sub>DDX</sub>                                           | PERJ/<br>PPSJ | Up          | Port J I/O, interrupt, SDA of IIC1, chip select 0                       |
| PJ2        | KWJ2            | CS1        | _          | _          | V <sub>DDX</sub>                                           | PERJ/<br>PPSJ | Up          | Port J I/O, interrupt, chip select 1                                    |
| PJ1        | KWJ1            | TXD2       | _          | —          | V <sub>DDX</sub>                                           | PERJ/<br>PPSJ | Up          | Port J I/O, interrupt, TXD of SCI2                                      |
| PJ0        | KWJ0            | RXD2       | CS3        | _          | V <sub>DDX</sub>                                           | PERJ/<br>PPSJ | Up          | Port J I/O, interrupt, RXD of SCI2                                      |
| PK7        |                 | _          |            | _          | V <sub>DDX</sub>                                           | PUCR          | Up          | Port K I/O                                                              |
| PK[5:4]    | _               | —          | —          |            | V <sub>DDX</sub>                                           | PUCR          | Up          | Port K I/O                                                              |
| PK7        | EWAIT           | ROMCTL     | _          | _          | V <sub>DDX</sub>                                           | PUCR          | Up          | Port K I/O, EWAIT input,<br>ROM on control                              |
| PK[6:4]    | ADDR<br>[22:20] | ACC[2:0]   | _          |            | V <sub>DDX</sub>                                           | PUCR Up       |             | Port K I/O, extended<br>addresses, access source<br>for external access |
| PK3        | ADDR19          | IQSTAT3    |            |            | V <sub>DDX</sub>                                           | PUCR          | Up          | Extended address, PIPE status                                           |

| Table 1-7. Signal Properties Sur | nmary (Sheet 2 of 4) |
|----------------------------------|----------------------|
|----------------------------------|----------------------|

| Address Offset                                          | ess Offset Use                              |     |  |
|---------------------------------------------------------|---------------------------------------------|-----|--|
| 0x0000                                                  | ATD Control Register 0 (ATDCTL0)            |     |  |
| 0x0001                                                  | ATD Control Register 1 (ATDCTL1)            | R/W |  |
| 0x0002                                                  | ATD Control Register 2 (ATDCTL2)            | R/W |  |
| 0x0003                                                  | ATD Control Register 3 (ATDCTL3)            | R/W |  |
| 0x0004                                                  | ATD Control Register 4 (ATDCTL4)            | R/W |  |
| 0x0005                                                  | ATD Control Register 5 (ATDCTL5)            | R/W |  |
| 0x0006                                                  | ATD Status Register 0 (ATDSTAT0)            | R/W |  |
| 0x0007                                                  | Unimplemented                               |     |  |
| 0x0008                                                  | ATD Test Register 0 (ATDTEST0) <sup>1</sup> | R   |  |
| 0x0009                                                  | ATD Test Register 1 (ATDTEST1)              | R/W |  |
| 0x000A                                                  | ATD Status Register 2 (ATDSTAT2)            | R   |  |
| 0x000B                                                  | ATD Status Register 1 (ATDSTAT1)            | R   |  |
| 0x000C                                                  | ATD Input Enable Register 0 (ATDDIEN0)      | R/W |  |
| 0x000D                                                  | ATD Input Enable Register 1 (ATDDIEN1)      | R/W |  |
| 0x000E Port Data Register 0 (PORTAD0)                   |                                             | R   |  |
| 0x000F                                                  | Port Data Register 1 (PORTAD1)              | R   |  |
| 0x0010, 0x0011 ATD Result Register 0 (ATDDR0H, ATDDR0L) |                                             | R/W |  |
| 0x0012, 0x0013 ATD Result Register 1 (ATDDR1H, ATDDR1L) |                                             | R/W |  |
| 0x0014, 0x0015 ATD Result Register 2 (ATDDR2H, ATDDR2L) |                                             | R/W |  |
| 0x0016, 0x0017 ATD Result Register 3 (ATDDR3H, ATDDR3L) |                                             | R/W |  |
| 0x0018, 0x0019                                          | ATD Result Register 4 (ATDDR4H, ATDDR4L)    | R/W |  |
| 0x001A, 0x001B                                          | ATD Result Register 5 (ATDDR5H, ATDDR5L)    | R/W |  |
| 0x001C, 0x001D                                          | ATD Result Register 6 (ATDDR6H, ATDDR6L)    | R/W |  |
| 0x001E, 0x001F                                          | ATD Result Register 7 (ATDDR7H, ATDDR7L)    | R/W |  |
| 0x0020, 0x0021                                          | ATD Result Register 8 (ATDDR8H, ATDDR8L)    | R/W |  |
| 0x0022, 0x0023                                          | ATD Result Register 9 (ATDDR9H, ATDDR9L)    | R/W |  |
| 0x0024, 0x0025                                          | ATD Result Register 10 (ATDDR10H, ATDDR10L) | R/W |  |
| 0x0026, 0x0027                                          | ATD Result Register 11 (ATDDR11H, ATDDR11L) | R/W |  |
| 0x0028, 0x0029                                          | ATD Result Register 12 (ATDDR12H, ATDDR12L) | R/W |  |
| 0x002A, 0x002B                                          | ATD Result Register 13 (ATDDR13H, ATDDR13L) | R/W |  |
| 0x002C, 0x002D                                          | ATD Result Register 14 (ATDDR14H, ATDDR14L) | R/W |  |
| 0x002E, 0x002F                                          | ATD Result Register 15 (ATDDR15H, ATDDR15L) | R/W |  |

#### Table 4-1. ATD10B16CV4 Memory Map

<sup>1</sup> ATDTEST0 is intended for factory test purposes only.

### NOTE

Register Address = Base Address + Address Offset, where the Base Address is defined at the MCU level and the Address Offset is defined at the module level.



## 6.8.1.4 Immediate 4 Bit Wide (IMM4)

The 4 bit wide immediate addressing mode is supported by all shift instructions.

```
RD = RD * imm4
```

Examples:

LSL R4,#1 ; R4 = R4 << 1; shift register R4 by 1 bit to the left LSR R4,#3 ; R4 = R4 >> 3; shift register R4 by 3 bits to the right

## 6.8.1.5 Immediate 8 Bit Wide (IMM8)

The 8 bit wide immediate addressing mode is supported by four major commands (ADD, SUB, LD, CMP).

RD = RD \* imm8

Examples:

| ADDL | R1,#1 | ; | adds an 8 bit value to register R1                           |
|------|-------|---|--------------------------------------------------------------|
| SUBL | R2,#2 | ; | subtracts an 8 bit value from register R2                    |
| LDH  | R3,#3 | ; | loads an 8 bit immediate into the high byte of Register R3   |
| CMPL | R4,#4 | ; | compares the low byte of register R4 with an immediate value |

### 6.8.1.6 Immediate 16 Bit Wide (IMM16)

The 16 bit wide immediate addressing mode is a construct to simplify assembler code. Instructions which offer this mode are translated into two opcodes using the eight bit wide immediate addressing mode.

RD = RD \* imm16

Examples:

LDW R4,#\$1234 ; translated to LDL R4,#\$34; LDH R4,#\$12 ADD R4,#\$5678 ; translated to ADDL R4,#\$78; ADDH R4,#\$56

## 6.8.1.7 Monadic Addressing (MON)

In this addressing mode only one operand is explicitly given. This operand can either be the source (f(RD)), the target (RD = f()), or both source and target of the operation (RD = f(RD)).

Examples:

JALR1; PC = R1, R1 = PC+2SIFR2; Trigger IRQ associated with the channel number in R2.L



Compare



### Operation

 $RS2 - RS1 \implies NONE \text{ (translates to SUB R0, RS1, RS2)}$ 

 $RD - IMM16 \implies NONE$  (translates to CMPL RD, #IMM16[7:0]; CPCH RD, #IMM16[15:8])

Subtracts two 16 bit values and discards the result.

### **CCR Effects**

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

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. RS1[15] & <u>RS2[15]</u> & result[15] | <u>RS1[15]</u> & RS2[15] & result[15] RD[15] & <u>IMM16[15]</u> & result[15] | <u>RD[15]</u> & <u>IMM16[15]</u> & result[15]
- C: Set if there is a carry from the bit 15 of the result; cleared otherwise. RS1[15] & RS2[15] | RS1[15] & result[15] | RS2[15] & result[15] RD[15] & IMM16[15] | RD[15] & result[15] | IMM16[15] & result[15]

### Code and CPU Cycles

| Source Form    | Address<br>Mode |   | Machine Code |   |   |   |               | Cycles |                |     |   |   |   |
|----------------|-----------------|---|--------------|---|---|---|---------------|--------|----------------|-----|---|---|---|
| CMP RS1, RS2   | TRI             | 0 | 0            | 0 | 1 | 1 | 0 0           | 0      | RS1            | RS2 | 0 | 0 | Р |
| CMP RS, #IMM16 | IMM8            | 1 | 1            | 0 | 1 | 0 | RS IMM16[7:0] |        |                | Р   |   |   |   |
|                | IMM8            | 1 | 1            | 0 | 1 | 1 | RS            |        | RS IMM16[15:8] |     |   |   | Р |



| Register<br>Name |        | Bit 7  | 6                           | 5      | 4      | 3      | 2      | 1     | Bit 0 |  |
|------------------|--------|--------|-----------------------------|--------|--------|--------|--------|-------|-------|--|
| TSCR2            | R<br>W | ΤΟΙ    | 0                           | 0      | 0      | TCRE   | PR2    | PR1   | PR0   |  |
| TFLG1            | R<br>W | C7F    | C6F                         | C5F    | C4F    | C3F    | C2F    | C1F   | C0F   |  |
| TFLG2            | R<br>W | TOF    | 0                           | 0      | 0      | 0      | 0      | 0     | 0     |  |
| TC0 (High)       | R<br>W | Bit 15 | Bit 14                      | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 |  |
| TC0 (Low)        | R<br>W | Bit 7  | Bit 6                       | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1 | Bit 0 |  |
| TC1 (High)       | R<br>W | Bit 15 | Bit 14                      | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 |  |
| TC1 (Low)        | R<br>W | Bit 7  | Bit 6                       | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1 | Bit 0 |  |
| TC2 (High)       | R<br>W | Bit 15 | Bit 14                      | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 |  |
| TC2 (Low)        | R<br>W | Bit 7  | Bit 6                       | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1 | Bit 0 |  |
| TC3 (High)       | R<br>W | Bit 15 | Bit 14                      | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 |  |
| TC3 (Low)        | R<br>W | Bit 7  | Bit 6                       | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1 | Bit 0 |  |
| TC4 (High)       | R<br>W | Bit 15 | Bit 14                      | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 |  |
| TC4 (Low)        | R<br>W | Bit 7  | Bit 6                       | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1 | Bit 0 |  |
| TC5 (High)       | R<br>W | Bit 15 | Bit 14                      | Bit 13 | Bit 12 | Bit 11 | Bit 10 | Bit 9 | Bit 8 |  |
| TC5 (Low)        | R<br>W | Bit 7  | Bit 6                       | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1 | Bit 0 |  |
|                  | [      |        | = Unimplemented or Reserved |        |        |        |        |       |       |  |

### Figure 7-2. ECT Register Summary (Sheet 2 of 5)

MC9S12XDP512 Data Sheet, Rev. 2.21



# 7.3.2.10 Timer Interrupt Enable Register (TIE)



## Figure 7-15. Timer Interrupt Enable Register (TIE)

Read or write: Anytime

All bits reset to zero.

The bits C7I–C0I correspond bit-for-bit with the flags in the TFLG1 status register.

#### Table 7-13. TIE Field Descriptions

| Field   | Description                                                             |
|---------|-------------------------------------------------------------------------|
| 7:0     | Input Capture/Output Compare "x" Interrupt Enable                       |
| C[7:0]I | 0 The corresponding flag is disabled from causing a hardware interrupt. |
|         | 1 The corresponding flag is enabled to cause an interrupt.              |



Chapter 7 Enhanced Capture Timer (S12ECT16B8CV2)

| PTMPS7 | PTMPS6 | PTMPS5 | PTMPS4 | PTMPS3 | PTMPS2 | PTMPS1 | PTMPS0 | Prescaler<br>Division<br>Rate |
|--------|--------|--------|--------|--------|--------|--------|--------|-------------------------------|
| 0      | 0      | 0      | 0      | 0      | 1      | 1      | 1      | 8                             |
| 0      | 0      | 0      | 0      | 1      | 1      | 1      | 1      | 16                            |
| 0      | 0      | 0      | 1      | 1      | 1      | 1      | 1      | 32                            |
| 0      | 0      | 1      | 1      | 1      | 1      | 1      | 1      | 64                            |
| 0      | 1      | 1      | 1      | 1      | 1      | 1      | 1      | 128                           |
| 1      | 1      | 1      | 1      | 1      | 1      | 1      | 1      | 256                           |

#### Table 7-34. Precision Timer Modulus Counter Prescaler Select Examples when PRNT = 1 (continued)

## 7.3.2.27 16-Bit Pulse Accumulator B Control Register (PBCTL)

|       | 7                           | 6    | 5 | 4 | 3 | 2 | 1     | 0 |
|-------|-----------------------------|------|---|---|---|---|-------|---|
| R     | 0                           | DREN | 0 | 0 | 0 | 0 |       | 0 |
| W     |                             | PDEN |   |   |   |   | FDOVI |   |
| Reset | 0                           | 0    | 0 | 0 | 0 | 0 | 0     | 0 |
|       | = Unimplemented or Reserved |      |   |   |   |   |       |   |

#### Figure 7-49. 16-Bit Pulse Accumulator B Control Register (PBCTL)

Read: Anytime

Write: Anytime

All bits reset to zero.

#### Table 7-35. PBCTL Field Descriptions

| Field      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |
|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6<br>PBEN  | <ul> <li>Pulse Accumulator B System Enable — PBEN is independent from TEN. With timer disabled, the pulse accumulator can still function unless pulse accumulator is disabled.</li> <li>0 16-bit pulse accumulator system disabled. 8-bit PAC1 and PAC0 can be enabled when their related enable bits in ICPAR are set.</li> <li>1 Pulse accumulator B system enabled. The two 8-bit pulse accumulators PAC1 and PAC0 are cascaded to form the PACB 16-bit pulse accumulator B. When PACB is enabled, the PACN1 and PACN0 registers contents are respectively the high and low byte of the PACB.</li> <li>PA1EN and PA0EN control bits in ICPAR have no effect. The PACB shares the input pin with IC0.</li> </ul> |
| 1<br>PBOVI | Pulse Accumulator B Overflow Interrupt Enable         0 Interrupt inhibited         1 Interrupt requested if PBOVF is set                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |



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



SPI operation in wait mode is a configurable low power mode, controlled by the SPISWAI bit located in the SPICR2 register. In wait mode, if the SPISWAI bit is clear, the SPI operates like in run mode. If the SPISWAI bit is set, the SPI goes into a power conservative state, with the SPI clock generation turned off. If the SPI is configured as a master, any transmission in progress stops, but is resumed after CPU goes into run mode. If the SPI is configured as a slave, reception and transmission of a byte continues, so that the slave stays synchronized to the master.

• Stop mode

The SPI is inactive in stop mode for reduced power consumption. If the SPI is configured as a master, any transmission in progress stops, but is resumed after CPU goes into run mode. If the SPI is configured as a slave, reception and transmission of a byte continues, so that the slave stays synchronized to the master.

This is a high level description only, detailed descriptions of operating modes are contained in Section 12.4.7, "Low Power Mode Options".

# 12.1.4 Block Diagram

Figure 12-1 gives an overview on the SPI architecture. The main parts of the SPI are status, control and data registers, shifter logic, baud rate generator, master/slave control logic, and port control logic.





Figure 15-8. BDM Host-to-Target Serial Bit Timing

The receive cases are more complicated. Figure 15-9 shows the host receiving a logic 1 from the target system. Since the host is asynchronous to the target, there is up to one clock-cycle delay from the host-generated falling edge on BKGD to the perceived start of the bit time in the target. The host holds the BKGD pin low long enough for the target to recognize it (at least two target clock cycles). The host must release the low drive before the target drives a brief high speedup pulse seven target clock cycles after the perceived start of the bit time. The host should sample the bit level about 10 target clock cycles after it started the bit time.



Figure 15-9. BDM Target-to-Host Serial Bit Timing (Logic 1)

MC9S12XDP512 Data Sheet, Rev. 2.21

18 Memory Mapping Control (S12XMMCV3)

Table 18-21 shows the address boundaries of each chip select and the relationship with the implemented resources (internal) parameters.

| Chip Selects              | Bottom Address | Top Address                             |
|---------------------------|----------------|-----------------------------------------|
| CS3                       | 0x00_0800      | 0x0F_FFFF minus RAMSIZE <sup>1</sup>    |
| CS2                       | 0x10_0000      | 0x13_FFFF minus EEPROMSIZE <sup>2</sup> |
| CS2 <sup>3</sup>          | 0x14_0000      | 0x1F_FFF                                |
| CS1                       | 0x20_0000      | 0x3F_FFF                                |
| $\overline{\text{CS0}}^4$ | 0x40_0000      | 0x7F_FFFF minus FLASHSIZE <sup>5</sup>  |

Table 18-21. Global Chip Selects Memory Space

<sup>1</sup> External RPAGE accesses in (NX, EX and ST)

<sup>2</sup> External EPAGE accesses in (NX, EX and ST)

<sup>3</sup> When ROMHM is set (see ROMHM in Table 18-19) the  $\overline{CS2}$  is asserted in the space occupied by this on-chip memory block.

<sup>4</sup> When the internal NVM is enabled (see ROMON in Section 18.3.2.5, "MMC Control Register (MMCCTL1)) the CS0 is not asserted in the space occupied by this on-chip memory block.

<sup>5</sup> External PPAGE accesses in (NX, EX and ST)

#### Figure 18-23. Local to Implemented Global Address Mapping (Without GPAGE)

## 18.4.2.4 XGATE Memory Map Scheme

### 18.4.2.4.1 Expansion of the XGATE Local Address Map

The XGATE 64 Kbyte memory space allows access to internal resources only (Registers, RAM, and FLASH). The 2 Kilobyte register address range is the same register address range as for the CPU and the BDM module . XGATE can access the FLASH in single chip modes, even when the MCU is secured. In expanded modes, XGATE can not access the FLASH when MCU is secured.

The local address of the XGATE RAM access is translated to the global RAM address range. The XGATE shares the RAM resource with the CPU and the BDM module . The local address of the XGATE FLASH access is translated to the global address as shown in Figure 18-24. For the implemented memory spaces and addresses please refer to Table 1-4 and Table 1-5.

### <sup>1</sup>19 S12X Debug (S12XDBGV2) Module

When program control returns from a tagged breakpoint using an RTI or BDM GO command without program counter modification it will return to the instruction whose tag generated the breakpoint. Thus care must be taken to avoid re triggering a breakpoint at the same location. This can be done by reconfiguring the DBG module in the SWI routine, (SWI configuration), or by executing a TRACE command before the GO (BDM configuration) to increment the program flow past the tagged instruction.

Comparators should not be configured for the vector address range while tagging, since these addresses are not opcode addresses





## 20.3.2.7.1 Debug State Control Register 1 (DBGSCR1)

Address: 0x0027



Read: Anytime

Write: Anytime when S12XDBG not armed.

This register is visible at 0x0027 only with COMRV[1:0] = 00. The state control register 1 selects the targeted next state whilst in State1. The matches refer to the match channels of the comparator match control logic as depicted in Figure 20-1 and described in Section 20.3.2.8.1". Comparators must be enabled by setting the comparator enable bit in the associated DBGXCTL control register.

Table 20-20. DBGSCR1 Field Descriptions

| Field          | Description                                                                             |
|----------------|-----------------------------------------------------------------------------------------|
| 3–0<br>SC[3:0] | These bits select the targeted next state whilst in State1, based upon the match event. |

| Table 20-21. State1 S | equencer Next State Selection |
|-----------------------|-------------------------------|
|-----------------------|-------------------------------|

| SC[3:0] | Description                                                                           |
|---------|---------------------------------------------------------------------------------------|
| 0000    | Any match triggers to state2                                                          |
| 0001    | Any match triggers to state3                                                          |
| 0010    | Any match triggers to Final State                                                     |
| 0011    | Match2 triggers to State2 Other matches have no effect                                |
| 0100    | Match2 triggers to State3 Other matches have no effect                                |
| 0101    | Match2 triggers to Final State Other matches have no effect                           |
| 0110    | Match0 triggers to State2 Match1 triggers to State3 Other matches have no effect      |
| 0111    | Match1 triggers to State3 Match0 triggers Final State Other matches have no effect    |
| 1000    | Match0 triggers to State2 Match2 triggers to State3 Other matches have no effect      |
| 1001    | Match2 triggers to State3 Match0 triggers Final State Other matches have no effect    |
| 1010    | Match1 triggers to State2 Match3 triggers to State3 Other matches have no effect      |
| 1011    | Match3 triggers to State3 Match1 triggers to Final State Other matches have no effect |
| 1100    | Match3 has no effect All other matches (M0,M1,M2) trigger to State2                   |
| 1101    | Reserved                                                                              |
| 1110    | Reserved                                                                              |
| 1111    | Reserved                                                                              |

The trigger priorities described in Table 20-38 dictate that in the case of simultaneous matches, the match on the lower channel number (0,1,2,3) has priority. The SC[3:0] encoding ensures that a match leading to final state has priority over all other matches.



# 22.3.2.45 Port P Interrupt Flag Register (PIFP)





Read: Anytime.

Write: Anytime.

Each flag is set by an active edge on the associated input pin. This could be a rising or a falling edge based on the state of the PPSP register. To clear this flag, write logic level "1" to the corresponding bit in the PIFP register. Writing a "0" has no effect.

Table 22-44. PIFP Field Descriptions

| Field     | Description                                                                                                                                                                                                                        |
|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7–0       | <ul> <li>Interrupt Flags Port P</li> <li>0 No active edge pending. Writing a "0" has no effect.</li> <li>1 Active edge on the associated bit has occurred (an interrupt will occur if the associated enable bit is set).</li></ul> |
| PIFP[7:0] | Writing a logic level "1" clears the associated flag.                                                                                                                                                                              |



### **External Signal Description**

This section lists and describes the signals that do connect off-chip.

## 23.0.3 Signal Properties

Table 23-1 shows all the pins and their functions that are controlled by the PIM. *Refer to Section*, *"Functional Description" for the availability of the individual pins in the different package options.* 

### NOTE

If there is more than one function associated with a pin, the priority is indicated by the position in the table from top (highest priority) to bottom (lowest priority).

| Port | Pin Name | Pin Function and Priority                   | I/O | Description                                                                            | Pin Function<br>after Reset    |
|------|----------|---------------------------------------------|-----|----------------------------------------------------------------------------------------|--------------------------------|
| —    | BKGD     | MODC <sup>1</sup>                           | Ι   | MODC input during RESET                                                                | BKGD                           |
|      |          | BKGD                                        | I/O | S12X_BDM communication pin                                                             |                                |
| A    | PA[7:0]  | ADDR[15:8]<br>mux<br>IVD[15:8] <sup>2</sup> | 0   | High-order external bus address output<br>(multiplexed with IVIS data)                 | Mode<br>dependent <sup>3</sup> |
|      |          | GPIO                                        | I/O | General-purpose I/O                                                                    |                                |
| В    | PB[7:1]  | ADDR[7:1]<br>mux<br>IVD[7:1] <sup>2</sup>   | 0   | Low-order external bus address output<br>(multiplexed with IVIS data)                  | Mode<br>dependent <sup>3</sup> |
|      |          | GPIO                                        | I/O | General-purpose I/O                                                                    |                                |
|      | PB[0]    | ADDR[0]<br>mux<br>IVD0 <sup>2</sup>         | 0   | Low-order external bus address output<br>(multiplexed with IVIS data)                  |                                |
|      |          | UDS                                         | 0   | Upper data strobe                                                                      |                                |
|      |          | GPIO                                        | I/O | General-purpose I/O                                                                    |                                |
| С    | PC[7:0]  | DATA[15:8]                                  | I/O | High-order bidirectional data input/output<br>Configurable for reduced input threshold | Mode<br>dependent <sup>3</sup> |
|      |          | GPIO                                        | I/O | General-purpose I/O                                                                    |                                |
| D    | PD[7:0]  | DATA[7:0]                                   | I/O | Low-order bidirectional data input/output<br>Configurable for reduced input threshold  | Mode<br>dependent <sup>3</sup> |
|      |          | GPIO                                        | I/O | General-purpose I/O                                                                    |                                |

Table 23-1. Pin Functions and Priorities (Sheet 1 of 7)



Figure 29-17. Flash Data Low Register (FDATALO)

All FDATAHI and FDATALO bits are readable but are not writable. At the completion of a data compress operation, the resulting 16-bit signature is stored in the FDATA registers. The data compression signature is readable in the FDATA registers until a new command write sequence is started.

## 29.3.2.11 RESERVED1

This register is reserved for factory testing and is not accessible.



Figure 29-18. RESERVED1

All bits read 0 and are not writable.

## 29.3.2.12 RESERVED2

This register is reserved for factory testing and is not accessible.



Figure 29-19. RESERVED2

All bits read 0 and are not writable.

## 29.3.2.13 RESERVED3

This register is reserved for factory testing and is not accessible.

MC9S12XDP512 Data Sheet, Rev. 2.21



| Num     | С | Rating                                                                           | Symbol          | Min | Тур | Max                              | Unit |  |  |  |
|---------|---|----------------------------------------------------------------------------------|-----------------|-----|-----|----------------------------------|------|--|--|--|
| LQFP144 |   |                                                                                  |                 |     |     |                                  |      |  |  |  |
| 1       | Т | Thermal resistance LQFP144, single sided PCB <sup>2</sup>                        | θ <sub>JA</sub> | —   | —   | 41                               | °C/W |  |  |  |
| 2       | Т | Thermal resistance LQFP144, double sided PCB with 2 internal planes <sup>3</sup> | θ <sub>JA</sub> | —   | —   | 32                               | °C/W |  |  |  |
| 3       |   | Junction to Board LQFP 144                                                       | $\theta_{JB}$   | —   | —   | 22                               | °C/W |  |  |  |
| 4       |   | Junction to Case LQFP 144 <sup>4</sup>                                           | θ <sub>JC</sub> | —   | —   | 7/4                              | °C/W |  |  |  |
| 5       |   | Junction to Package Top LQFP144 <sup>5</sup>                                     | Ψ <sub>JT</sub> | _   | _   | 3                                | °C/W |  |  |  |
| LQFP112 |   |                                                                                  |                 |     |     |                                  |      |  |  |  |
| 6       | Т | Thermal resistance LQFP112, single sided PCB <sup>2</sup>                        | θ <sub>JA</sub> |     | _   | 43 <sup>3</sup> /49 <sup>4</sup> | °C/W |  |  |  |
| 7       | Т | Thermal resistance LQFP112, double sided PCB with 2 internal planes <sup>5</sup> | θ <sub>JA</sub> | _   | _   | 32 <sup>3</sup> /39 <sup>4</sup> | °C/W |  |  |  |
| 8       |   | Junction to Board LQFP112                                                        | θ <sub>JB</sub> |     | _   | 22 <sup>3</sup> /27 <sup>4</sup> | °C/W |  |  |  |
| 9       |   | Junction to Case LQFP112 <sup>4</sup>                                            | θ <sub>JC</sub> | _   | _   | 7 <sup>3</sup> /11 <sup>4</sup>  | °C/W |  |  |  |
| 10      |   | Junction to Package Top LQFP112 <sup>5</sup>                                     | Ψ <sub>JT</sub> | —   | _   | 3/2                              | °C/W |  |  |  |
| QFP80   |   |                                                                                  |                 |     |     |                                  |      |  |  |  |
| 11      | Т | Thermal resistance QFP 80, single sided PCB <sup>2</sup>                         | θ <sub>JA</sub> | —   | —   | 45 <sup>3</sup> /49 <sup>4</sup> | °C/W |  |  |  |
| 12      | Т | Thermal resistance QFP 80, double sided PCB with 2 internal planes <sup>3</sup>  | θ <sub>JA</sub> | —   | _   | 33 <sup>3</sup> /36 <sup>4</sup> | °C/W |  |  |  |
| 13      | Т | Junction to Board QFP 80                                                         | θ <sub>JB</sub> | —   | —   | 19 <sup>3</sup> /20 <sup>4</sup> | °C/W |  |  |  |
| 14      | Т | Junction to Case QFP 80 <sup>6</sup>                                             | θ <sub>JC</sub> | —   | —   | 11 <sup>3</sup> /14 <sup>4</sup> | °C/W |  |  |  |
| 15      | Т | Junction to Package Top QFP 807                                                  | Ψ <sub>JT</sub> | —   | —   | 3                                | °C/W |  |  |  |

| Table A | -5. | Thermal | Package | Characteristics <sup>1</sup> |
|---------|-----|---------|---------|------------------------------|
|---------|-----|---------|---------|------------------------------|

<sup>1</sup> The values for thermal resistance are achieved by package simulations

<sup>2</sup> 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.

<sup>3</sup> Maskset L15Y / M84E in LQFP112 or QFP80

<sup>4</sup> Maskset M42E in LQFP112 or QFP80

<sup>5</sup> 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.

<sup>6</sup> 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 heat sink.

<sup>7</sup> 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 environment.



| Conditions are shown in Table A-4 unless otherwise noted |   |                                                            |                    |     |      |      |                |  |
|----------------------------------------------------------|---|------------------------------------------------------------|--------------------|-----|------|------|----------------|--|
| Num                                                      | С | Rating                                                     | Symbol             | Min | Тур  | Max  | Unit           |  |
| 1                                                        | Р | Self clock mode frequency                                  | f <sub>SCM</sub>   | 1   | _    | 5.5  | MHz            |  |
| 2                                                        | D | VCO locking range                                          | f <sub>VCO</sub>   | 8   | —    | 80   | MHz            |  |
| 3                                                        | D | Lock detector transition from acquisition to tracking mode | $ \Delta_{trk} $   | 3   | —    | 4    | % <sup>1</sup> |  |
| 4                                                        | D | Lock detection                                             | $ \Delta_{Lock} $  | 0   | —    | 1.5  | % <sup>1</sup> |  |
| 5                                                        | D | Unlock detection                                           | $ \Delta_{unl} $   | 0.5 | —    | 2.5  | % <sup>1</sup> |  |
| 6                                                        | D | Lock detector transition from tracking to acquisition mode | $ \Delta_{unt} $   | 6   | —    | 8    | % <sup>1</sup> |  |
| 7                                                        | С | PLLON total stabilization delay (auto mode) <sup>2</sup>   | t <sub>stab</sub>  | _   | 0.24 | —    | ms             |  |
| 8                                                        | D | PLLON acquisition mode stabilization delay <sup>2</sup>    | t <sub>acq</sub>   | _   | 0.09 | —    | ms             |  |
| 9                                                        | D | PLLON tracking mode stabilization delay <sup>2</sup>       | t <sub>al</sub>    | _   | 0.16 | —    | ms             |  |
| 10                                                       | D | Fitting parameter VCO loop gain                            | K <sub>1</sub>     | —   | -195 | —    | MHz/V          |  |
| 11                                                       | D | Fitting parameter VCO loop frequency                       | f <sub>1</sub>     | _   | 126  | _    | MHz            |  |
| 12                                                       | D | Charge pump current acquisition mode                       | i <sub>ch</sub>    | _   | 38.5 | —    | μA             |  |
| 13                                                       | D | Charge pump current tracking mode                          | ∣i <sub>ch</sub> ∣ | _   | 3.5  | —    | μA             |  |
| 14                                                       | С | Jitter fit parameter 1 <sup>2</sup>                        | j <sub>1</sub>     |     | 0.9  | 1.3  | %              |  |
| 15                                                       | С | Jitter fit parameter 2 <sup>2</sup>                        | j <sub>2</sub>     |     | 0.02 | 0.12 | %              |  |

#### Table A-23. PLL Characteristics

<sup>1</sup> % deviation from target frequency

 $^2$  f<sub>osc</sub> = 4 MHz, f<sub>BUS</sub> = 40 MHz equivalent f<sub>VCO</sub> = 80 MHz: REFDV = #\$00, SYNR = #\$09, C<sub>S</sub> = 4.7 nF, C<sub>P</sub> = 470 pF, R<sub>S</sub> = 4.7 k\Omega

# A.6 MSCAN

#### Table A-24. MSCAN Wake-up Pulse Characteristics

| Conditions are shown in Table A-4 unless otherwise noted |   |                                      |                  |     |     |     |      |  |
|----------------------------------------------------------|---|--------------------------------------|------------------|-----|-----|-----|------|--|
| Num                                                      | С | Rating                               | Symbol           | Min | Тур | Max | Unit |  |
| 1                                                        | Р | MSCAN wakeup dominant pulse filtered | t <sub>WUP</sub> | _   | _   | 2   | μs   |  |
| 2                                                        | Р | MSCAN wakeup dominant pulse pass     | t <sub>WUP</sub> | 5   | —   | —   | μs   |  |