



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                      | 50MHz                                                                    |
| Connectivity               | CANbus, EBI/EMI, I <sup>2</sup> C, IrDA, 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) | 1.72V ~ 5.5V                                                             |
| Data Converters            | A/D 16x12b                                                               |
| Oscillator Type            | External                                                                 |
| Operating Temperature      | -40°C ~ 85°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/mc9s12xeq512calr |

Email: info@E-XFL.COM

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



is loaded with valid data from the D-Flash EEE partition. Completion of this phase is indicated by the CCIF flag in the FTM FSTAT register becoming set. If the CPU accesses any EEE RAM location before the CCIF flag is set, the CPU is stalled until the FTM reset sequence is complete and the EEE RAM data is valid. Once the CCIF flag is set, indicating the end of this phase, the EEE RAM can be accessed without impacting the CPU and FTM commands can be executed.

# 1.6.3.3 Reset While Flash Command Active

If a reset occurs while any Flash command is in progress, that command will be immediately aborted. The state of the word being programmed or the sector/block being erased is not guaranteed.

# 1.6.3.4 I/O Pins

Refer to the PIM block description for reset configurations of all peripheral module ports.

## 1.6.3.5 Memory

The RAM arrays are not initialized out of reset.

## 1.6.3.6 COP Configuration

The COP timeout rate bits CR[2:0] and the WCOP bit in the COPCTL register are loaded on rising edge of  $\overline{\text{RESET}}$  from the Flash register FOPT. See Table 1-15 and Table 1-16 for coding. The FOPT register is loaded from the Flash configuration field byte at global address \$7FFF0E during the reset sequence.

If the MCU is secured the COP timeout rate is always set to the longest period (CR[2:0] = 111) after COP reset.

| NV[2:0] in<br>FOPT Register | CR[2:0] in<br>COPCTL Register |
|-----------------------------|-------------------------------|
| 000                         | 111                           |
| 001                         | 110                           |
| 010                         | 101                           |
| 011                         | 100                           |
| 100                         | 011                           |
| 101                         | 010                           |
| 110                         | 001                           |
| 111                         | 000                           |

Table 1-15. Initial COP Rate Configuration

#### Table 1-16. Initial WCOP Configuration

| NV[3] in<br>FOPT Register | WCOP in<br>COPCTL Register |
|---------------------------|----------------------------|
| 1                         | 0                          |
| 0                         | 1                          |

|                 |                     | EBI Signal      |                                          |                                                                          | Available in Modes |    |     |     |     |     |  |
|-----------------|---------------------|-----------------|------------------------------------------|--------------------------------------------------------------------------|--------------------|----|-----|-----|-----|-----|--|
| Signal          | I <sup>(1)</sup> /O | (T)ir<br>(F)unc | ne <sup>(2)</sup><br>tion <sup>(3)</sup> | Description                                                              |                    | SS | NX  | ES  | EX  | ST  |  |
| RE              | 0                   | _               | _                                        | Read Enable, indicates external read access                              | No                 | No | Yes | No  | No  | No  |  |
| ADDR[22:20]     | 0                   | Т               | _                                        | External address                                                         | No                 | No | Yes | Yes | Yes | Yes |  |
| ACC[2:0]        | 0                   |                 | —                                        | Access source                                                            | No                 | No | No  | Yes | Yes | Yes |  |
| ADDR[19:16]     | 0                   | Т               |                                          | External address                                                         | No                 | No | Yes | Yes | Yes | Yes |  |
| IQSTAT[3:0]     | 0                   |                 |                                          | Instruction Queue Status                                                 | No                 | No | No  | Yes | Yes | Yes |  |
| ADDR[15:1]      | 0                   | Т               | —                                        | External address                                                         | No                 | No | Yes | Yes | Yes | Yes |  |
| IVD[15:1]       | 0                   |                 | —                                        | Internal visibility read data                                            | No                 | No | No  | Yes | Yes | Yes |  |
| ADDR0           | 0                   | Т               | F                                        | External address                                                         | No                 | No | No  | Yes | Yes | Yes |  |
| IVD0            | 0                   |                 |                                          | Internal visibility read data                                            | No                 | No | No  | Yes | Yes | Yes |  |
| UDS             | 0                   | _               |                                          | Upper Data Select, indicates external access to the high byte DATA[15:8] | No                 | No | Yes | No  | No  | No  |  |
| LSTRB           | 0                   |                 | F                                        | Low Strobe, indicates valid data on DATA[7:0]                            | No                 | No | No  | Yes | Yes | Yes |  |
| LDS             | 0                   |                 |                                          | Lower Data Select, indicates external access to the low byte DATA[7:0]   | No                 | No | Yes | No  | No  | No  |  |
| RW              | 0                   |                 | F                                        | Read/Write, indicates the direction of internal data transfers           | No                 | No | No  | Yes | Yes | Yes |  |
| WE              | 0                   | _               |                                          | Write Enable, indicates external write access                            | No                 | No | Yes | No  | No  | No  |  |
| <u>CS</u> [3:0] | 0                   | _               | _                                        | Chip select                                                              | No                 | No | Yes | No  | Yes | No  |  |
| DATA[15:8]      | I/O                 |                 | _                                        | Bidirectional data (even address)                                        | No                 | No | Yes | Yes | Yes | Yes |  |
| DATA[7:0]       | I/O                 |                 |                                          | Bidirectional data (odd address)                                         | No                 | No | Yes | Yes | Yes | Yes |  |
| EWAIT           | I                   | _               | —                                        | External control for external bus access stretches (adding wait states)  | No                 | No | Yes | No  | Yes | No  |  |

| Table 5-2. External System Signals Associated with XE | EBI |
|-------------------------------------------------------|-----|
|-------------------------------------------------------|-----|

1. All inputs are capable of reducing input threshold level

2. Time-multiplex means that the respective signals share the same pin on chip level and are active alternating in a dedicated time slot (in modes where applicable).

3. Function-multiplex means that one of the respective signals sharing the same pin on chip level continuously uses the pin depending on configuration and reset state.





# 7.4.6 BDM Serial Interface

The BDM communicates with external devices serially via the BKGD pin. During reset, this pin is a mode select input which selects between normal and special modes of operation. After reset, this pin becomes the dedicated serial interface pin for the BDM.

The BDM serial interface is timed using the clock selected by the CLKSW bit in the status register see Section 7.3.2.1, "BDM Status Register (BDMSTS)". This clock will be referred to as the target clock in the following explanation.

The BDM serial interface uses a clocking scheme in which the external host generates a falling edge on the BKGD pin to indicate the start of each bit time. This falling edge is sent for every bit whether data is transmitted or received. Data is transferred most significant bit (MSB) first at 16 target clock cycles per bit. The interface times out if 512 clock cycles occur between falling edges from the host.

The BKGD pin is a pseudo open-drain pin and has an weak on-chip active pull-up that is enabled at all times. It is assumed that there is an external pull-up and that drivers connected to BKGD do not typically drive the high level. Since R-C rise time could be unacceptably long, the target system and host provide brief driven-high (speedup) pulses to drive BKGD to a logic 1. The source of this speedup pulse is the host for transmit cases and the target for receive cases.

The timing for host-to-target is shown in Figure 7-8 and that of target-to-host in Figure 7-9 and Figure 7-10. All four cases begin when the host drives the BKGD pin low to generate a falling edge. Since the host and target are operating from separate clocks, it can take the target system up to one full clock

<sup>1.</sup> Target clock cycles are cycles measured using the target MCU's serial clock rate. See Section 7.4.6, "BDM Serial Interface" and Section 7.3.2.1, "BDM Status Register (BDMSTS)" for information on how serial clock rate is selected.



# 8.4.1 S12XDBG Operation

Arming the S12XDBG module by setting ARM in DBGC1 allows triggering, and storing of data in the trace buffer and can be used to cause breakpoints to the CPU12X or the XGATE module. The DBG module is made up of four main blocks, the comparators, control logic, the state sequencer, and the trace buffer.

The comparators monitor the bus activity of the CPU12X and XGATE. Comparators can be configured to monitor address and databus. Comparators can also be configured to mask out individual data bus bits during a compare and to use R/W and word/byte access qualification in the comparison. When a match with a comparator register value occurs the associated control logic can trigger the state sequencer to another state (see Figure 8-22). Either forced or tagged triggers are possible. Using a forced trigger, the trigger is generated immediately on a comparator match. Using a tagged trigger, at a comparator match, the instruction opcode is tagged and only if the instruction reaches the execution stage of the instruction queue is a trigger generated. In the case of a transition to Final State, bus tracing is triggered and/or a breakpoint can be generated. Tracing of both CPU12X and/or XGATE bus activity is possible.

Independent of the state sequencer, a breakpoint can be triggered by the external  $\overline{TAGHI}$  /  $\overline{TAGLO}$  signals or by an XGATE S/W breakpoint request or by writing to the TRIG bit in the DBGC1 control register.

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

# 8.4.2 Comparator Modes

The S12XDBG contains four comparators, A, B, C, and D. Each comparator can be configured to monitor CPU12X or XGATE buses. Each comparator compares the selected address bus with the address stored in DBGXAH, DBGXAM, and DBGXAL. Furthermore, comparators A and C also compare the data buses to the data stored in DBGXDH, DBGXDL and allow masking of individual data bus bits.

S12X comparator matches are disabled in BDM and during BDM accesses.

The comparator match control logic configures comparators to monitor the buses for an exact address or an address range. The comparator configuration is controlled by the control register contents and the range control by the DBGC2 contents.

On a match a trigger can initiate a transition to another state sequencer state (see Section 8.4.3"). The comparator control register also allows the type of access to be included in the comparison through the use of the RWE, RW, SZE, and SZ bits. The RWE bit controls whether read or write comparison is enabled for the associated comparator and the RW bit selects either a read or write access for a valid match. Similarly the SZE and SZ bits allows the size of access (word or byte) to be considered in the compare. Only comparators B and D feature SZE and SZ.

The TAG bit in each comparator control register is used to determine the triggering condition. By setting TAG, the comparator will qualify a match with the output of opcode tracking logic and a trigger occurs before the tagged instruction executes (tagged-type trigger). Whilst tagging, the RW, RWE, SZE, and SZ bits are ignored and the comparator register must be loaded with the exact opcode address.

If the TAG bit is clear (forced type trigger) a comparator match is generated when the selected address appears on the system address bus. If the selected address is an opcode address, the match is generated



Chapter 10 XGATE (S12XGATEV3)

|                |        | 127     | 126     | 125     | 124     | 123     | 122     | 121     | 120     | 119     | 118     | 117     | 116     | 115     | 114     | 113     | 112     |
|----------------|--------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|---------|
| 0x0008<br>XGIF | R<br>W | 0       | 0       | 0       | 0       | 0       | 0       | 0       | XGIF_78 | XGF_77  | XGIF_76 | XGIF_75 | XGIF_74 | XGIF_73 | XGIF_72 | XGIF_71 | XGIF_70 |
|                |        | 111     | 110     | 109     | 108     | 107     | 106     | 105     | 104     | 103     | 102     | 101     | 100     | 99      | 98      | 97      | 96      |
| 0x000A<br>XGIF | R<br>W | XGIF_6F | XGIF_6E | XGIF_6D | XGIF_6C | XGIF_6B | XGIF_6A | XGIF_69 | XGIF_68 | XGF_67  | XGIF_66 | XGIF_65 | XGIF_64 | XGIF_63 | XGIF_62 | XGIF_61 | XGIF_60 |
|                | -      | 95      | 94      | 93      | 92      | 91      | 90      | 89      | 88      | 87      | 86      | 85      | 84      | 83      | 82      | 81      | 80      |
| 0x000C<br>XGIF | R<br>W | XGIF_5F | XGIF_5E | XGIF_5D | XGIF_5C | XGIF_5B | XGIF_5A | XGIF_59 | XGIF_58 | XGF_57  | XGIF_56 | XGIF_55 | XGIF_54 | XGIF_53 | XGIF_52 | XGIF_51 | XGIF_50 |
|                |        | 79      | 78      | 77      | 76      | 75      | 74      | 73      | 72      | 71      | 70      | 69      | 68      | 67      | 66      | 65      | 64      |
| 0x000E<br>XGIF | R<br>W | XGIF_4F | XGIF_4E | XGIF_4D | XGIF_4C | XGIF_4B | XGIF_4A | XGIF_49 | XGIF_48 | XGF _47 | XGIF_46 | XGIF_45 | XGIF_44 | XGIF_43 | XGIF_42 | XGIF_41 | XGIF_40 |
|                |        | 63      | 62      | 61      | 60      | 59      | 58      | 57      | 56      | 55      | 54      | 53      | 52      | 51      | 50      | 49      | 48      |
| 0x0010<br>XGIF | R<br>W | XGIF_3F | XGIF_3E | XGIF_3D | XGIF_3C | XGIF_3B | XGIF_3A | XGIF_39 | XGIF_38 | XGF _37 | XGIF_36 | XGIF_35 | XGIF_34 | XGIF_33 | XGIF_32 | XGIF_31 | XGIF_30 |
|                |        | 47      | 46      | 45      | 44      | 43      | 42      | 41      | 40      | 39      | 38      | 37      | 36      | 35      | 34      | 33      | 32      |
| 0x0012<br>XGIF | R<br>W | XGIF_2F | XGIF_2E | XGIF_2D | XGIF_2C | XGIF_2B | XGIF_2A | XGIF_29 | XGIF_28 | XGF _27 | XGIF_26 | XGIF_25 | XGIF_24 | XGIF_23 | XGIF_22 | XGIF_21 | XGIF_20 |
|                | -      | 31      | 30      | 29      | 28      | 27      | 26      | 25      | 24      | 23      | 22      | 21      | 20      | 19      | 18      | 17      | 16      |
| 0x0014<br>XGIF | R<br>W | XGIF_1F | XGIF_1E | XGIF_1D | XGIF_1C | XGIF_1B | XGIF_1A | XGIF_19 | XGIF_18 | XGF_17  | XGIF_16 | XGIF_15 | XGIF_14 | XGIF_13 | XGIF_12 | XGIF_11 | XGIF_10 |
|                | -      | 15      | 14      | 13      | 12      | 11      | 10      | 9       | 8       | 7       | 6       | 5       | 4       | 3       | 2       | 1       | 0       |
| 0x0016<br>XGIF | R<br>W | XGIF_0F | XGIF_0E | XGIF_0D | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       | 0       |
|                | [      |         |         | npleme  | nted or | r Reser | ved     |         |         |         |         |         |         |         |         |         |         |

Figure 10-2. XGATE Register Summary (Sheet 2 of 3)

# NP

# 10.8.2.5 Bit Field Operations

This addressing mode is used to identify the position and size of a bit field for insertion or extraction. The width and offset are coded in the lower byte of the source register 2, RS2. The content of the upper byte is ignored. An offset of 0 denotes the right most position and a width of 0 denotes 1 bit. These instructions are very useful to extract, insert, clear, set or toggle portions of a 16 bit word



#### Figure 10-26. Bit Field Addressing

BFEXT R3,R4,R5 ; R5: W4+1 bits with offset O4, will be extracted from R4 into R3

# 10.8.2.6 Special Instructions for DMA Usage

The XGATE offers a number of additional instructions for flag manipulation, program flow control and debugging:

- 1. SIF: Set a channel interrupt flag
- 2. SSEM: Test and set a hardware semaphore
- 3. CSEM: Clear a hardware semaphore
- 4. BRK: Software breakpoint
- 5. NOP: No Operation
- 6. RTS: Terminate the current thread

# 10.8.3 Cycle Notation

Table 10-23 show the XGATE access detail notation. Each code letter equals one XGATE cycle. Each letter implies additional wait cycles if memories or peripherals are not accessible. Memories or peripherals are not accessible if they are blocked by the S12X\_CPU. In addition to this Peripherals are only accessible every other XGATE cycle. Uppercase letters denote 16 bit operations. Lowercase letters denote 8 bit operations. The XGATE is able to perform two bus or wait cycles per S12X\_CPU cycle.





# Store Word to Memory

STW

# Operation

 $\begin{array}{ll} RS & \Rightarrow M[RB, \#OFFS5] \\ RS & \Rightarrow M[RB, RI] \\ RS & \Rightarrow M[RB, RI]; & RI+2 \Rightarrow RI; \\ RI-2 \Rightarrow RI; & RS & \Rightarrow M[RB, RI]^1 \end{array}$ 

Stores the content of register RS to memory.

# **CCR Effects**



- N: Not affected.
- Z: Not affected.
- V: Not affected.
- C: Not affected.

# **Code and CPU Cycles**

| Source Form          | Address<br>Mode |   | Machine Code |   |   |   |    |    |      |    | Cycles |    |
|----------------------|-----------------|---|--------------|---|---|---|----|----|------|----|--------|----|
| STW RS, (RB, #OFFS5) | IDO5            | 0 | 1            | 0 | 1 | 1 | RS | RB | OFFS | S5 |        | PW |
| STW RS, (RB, RI)     | IDR             | 0 | 1            | 1 | 1 | 1 | RS | RB | RI   | 0  | 0      | PW |
| STW RS, (RB, RI+)    | IDR+            | 0 | 1            | 1 | 1 | 1 | RS | RB | RI   | 0  | 1      | PW |
| STW RS, (RB, -RI)    | -IDR            | 0 | 1            | 1 | 1 | 1 | RS | RB | RI   | 1  | 0      | PW |

1. If the same general purpose register is used as index (RI) and source register (RS), the unmodified content of the source register is written to the memory: RS ⇒ M[RB, RS–2]; RS–2 ⇒ RS



| f <sub>OSC</sub> | REFDIV[5:0] | f <sub>REF</sub> | REFFRQ[1:0] | SYNDIV[5:0] | f <sub>vco</sub> | VCOFRQ[1:0] | POSTDIV[4:0] | f <sub>PLL</sub> | f <sub>BUS</sub> |
|------------------|-------------|------------------|-------------|-------------|------------------|-------------|--------------|------------------|------------------|
| 4MHz             | \$01        | 2MHz             | 01          | \$18        | 100MHz           | 11          | \$00         | 100MHz           | 50 MHz           |
| 8MHz             | \$03        | 2MHz             | 01          | \$18        | 100MHz           | 11          | \$00         | 100MHz           | 50 MHz           |
| 4MHz             | \$00        | 4MHz             | 01          | \$09        | 80MHz            | 01          | \$00         | 80MHz            | 40MHz            |
| 8MHz             | \$00        | 8MHz             | 10          | \$04        | 80MHz            | 01          | \$00         | 80MHz            | 40MHz            |
| 4MHz             | \$00        | 4MHz             | 01          | \$03        | 32MHz            | 00          | \$01         | 16MHz            | 8MHz             |
| 4MHz             | \$01        | 2MHz             | 01          | \$18        | 100MHz           | 11          | \$01         | 50MHz            | 25MHz            |

Table 11-14. Examples of IPLL Divider Settings<sup>(1)</sup>

f<sub>PLL</sub> and f<sub>BUS</sub> values in this table may exceed maximum allowed frequencies for some devices. Refer to device information for maximum values.

#### 11.4.1.1.1 **IPLL** Operation

The oscillator output clock signal (OSCCLK) is fed through the reference programmable divider and is divided in a range of 1 to 64 (REFDIV+1) to output the REFCLK. The VCO output clock, (VCOCLK) is fed back through the programmable loop divider and is divided in a range of 2 to 128 in increments of [2 x (SYNDIV +1)] to output the FBCLK. The VCOCLK is fed to the final programmable divider and is divided in a range of 1,2,4,6,8,... to 62 (2\*POSTDIV) to output the PLLCLK. See Figure 11-15.

The phase detector then compares the FBCLK, with the REFCLK. Correction pulses are generated based on the phase difference between the two signals. The loop filter then slightly alters the DC voltage on the internal filter capacitor, based on the width and direction of the correction pulse.

The user must select the range of the REFCLK frequency and the range of the VCOCLK frequency to ensure that the correct IPLL loop bandwidth is set.

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

If IPLL LOCK interrupt requests are enabled, the software can wait for an interrupt request and then check the LOCK bit. If interrupt requests are disabled, software can poll the LOCK bit continuously (during IPLL start-up, usually) or at periodic intervals. In either case, only when the LOCK bit is set, the PLLCLK can be selected as the source for the system and core clocks. If the IPLL is selected as the source for the system and core clocks and the LOCK bit is clear, the IPLL has suffered a severe noise hit and the software must take appropriate action, depending on the application.

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



# 13.3.2.3 ATD Control Register 2 (ATDCTL2)

Writes to this register will abort current conversion sequence.





#### Figure 13-5. ATD Control Register 2 (ATDCTL2)

Read: Anytime

Write: Anytime

| Field        | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 6<br>AFFC    | <ul> <li>ATD Fast Flag Clear All</li> <li>0 ATD flag clearing done by write 1 to respective CCF[n] flag.</li> <li>1 Changes all ATD conversion complete flags to a fast clear sequence.<br/>For compare disabled (CMPE[n]=0) a read access to the result register will cause the associated CCF[n] flag to clear automatically.<br/>For compare enabled (CMPE[n]=1) a write access to the result register will cause the associated CCF[n] flag to clear automatically.</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  |
| 5<br>ICLKSTP | <ul> <li>Internal Clock in Stop Mode Bit — This bit enables A/D conversions in stop mode. When going into stop mode and ICLKSTP=1 the ATD conversion clock is automatically switched to the internally generated clock ICLK. Current conversion sequence will seamless continue. Conversion speed will change from prescaled bus frequency to the ICLK frequency (see ATD Electrical Characteristics in device description). The prescaler bits PRS4-0 in ATDCTL4 have no effect on the ICLK frequency. For conversions during stop mode the automatic compare interrupt or the sequence complete interrupt can be used to inform software handler about changing A/D values. External trigger will not work while converting in stop mode. For conversions during transition from Run to Stop Mode or vice versa the result is not written to the results register, no CCF flag is set and no compare is done. When converting in Stop Mode (ICLKSTP=1) an ATD Stop Recovery time t<sub>ATDSTPRCV</sub> is required to switch back to bus clock based ATDCLK when leaving Stop Mode. Do not access ATD registers during this time.</li> <li>0 If A/D conversion sequence is ongoing when going into stop mode.</li> <li>1 A/D continues to convert in stop mode using internally generated clock (ICLK)</li> </ul> |
| 4<br>ETRIGLE | <b>External Trigger Level/Edge Control</b> — This bit controls the sensitivity of the external trigger signal. See Table 13-8 for details.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |
| 3<br>ETRIGP  | <b>External Trigger Polarity</b> — This bit controls the polarity of the external trigger signal. See Table 13-8 for details.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
| 2<br>ETRIGE  | <ul> <li>External Trigger Mode Enable — This bit enables the external trigger on one of the AD channels or one of the ETRIG3-0 inputs as described in Table 13-6. If external trigger source is one of the AD channels, the digital input buffer of this channel is enabled. The external trigger allows to synchronize the start of conversion with external events. External trigger will not work while converting in stop mode.</li> <li>0 Disable external trigger</li> <li>1 Enable external trigger</li> </ul>                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |

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



# NOTE

When TFFCA = 1, the flag cannot be cleared via the normal flag clearing mechanism (writing a one to the flag). Reference Section 14.3.2.6, "Timer System Control Register 1 (TSCR1)".

All bits reset to zero.

#### Table 14-25. MCFLG Field Descriptions

| Field            | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>MCZF        | <b>Modulus Counter Underflow Flag</b> — The flag is set when the modulus down-counter reaches 0x0000.<br>The flag indicates when interrupt conditions have occurred. The flag can be cleared via the normal flag clearing mechanism (writing a one to the flag) or via the fast flag clearing mechanism (Reference TFFCA bit in Section 14.3.2.6, "Timer System Control Register 1 (TSCR1)").                                                                       |
| 3:0<br>POLF[3:0] | <ul> <li>First Input Capture Polarity Status — These are read only bits. Writes to these bits have no effect.</li> <li>Each status bit gives the polarity of the first edge which has caused an input capture to occur after capture latch has been read.</li> <li>Each POLFx corresponds to a timer PORTx input.</li> <li>The first input capture has been caused by a falling edge.</li> <li>The first input capture has been caused by a rising edge.</li> </ul> |

# 14.3.2.21 ICPAR — Input Control Pulse Accumulators Register (ICPAR)

Module Base + 0x0028



#### Figure 14-44. Input Control Pulse Accumulators Register (ICPAR)

Read: Anytime

Write: Anytime.

All bits reset to zero.

The 8-bit pulse accumulators PAC3 and PAC2 can be enabled only if PAEN in PACTL is cleared. If PAEN is set, PA3EN and PA2EN have no effect.

The 8-bit pulse accumulators PAC1 and PAC0 can be enabled only if PBEN in PBCTL is cleared. If PBEN is set, PA1EN and PA0EN have no effect.

#### Table 14-26. ICPAR Field Descriptions

| Field            | Description                                                                                                                                       |
|------------------|---------------------------------------------------------------------------------------------------------------------------------------------------|
| 3:0<br>PA[3:0]EN | <ul> <li>8-Bit Pulse Accumulator 'x' Enable</li> <li>8-Bit Pulse Accumulator is disabled.</li> <li>8-Bit Pulse Accumulator is enabled.</li> </ul> |



When the transmit shift register is not transmitting a frame, the TXD pin goes to the idle condition, logic 1. If at any time software clears the TE bit in SCI control register 2 (SCICR2), the transmitter enable signal goes low and the transmit signal goes idle.

If software clears TE while a transmission is in progress (TC = 0), the frame in the transmit shift register continues to shift out. To avoid accidentally cutting off the last frame in a message, always wait for TDRE to go high after the last frame before clearing TE.

To separate messages with preambles with minimum idle line time, use this sequence between messages:

- 1. Write the last byte of the first message to SCIDRH/L.
- 2. Wait for the TDRE flag to go high, indicating the transfer of the last frame to the transmit shift register.
- 3. Queue a preamble by clearing and then setting the TE bit.
- 4. Write the first byte of the second message to SCIDRH/L.

# 20.4.5.3 Break Characters

Writing a logic 1 to the send break bit, SBK, in SCI control register 2 (SCICR2) loads the transmit shift register with a break character. A break character contains all logic 0s and has no start, stop, or parity bit. Break character length depends on the M bit in SCI control register 1 (SCICR1). As long as SBK is at logic 1, transmitter logic continuously loads break characters into the transmit shift register. After software clears the SBK bit, the shift register finishes transmitting the last break character and then transmits at least one logic 1. The automatic logic 1 at the end of a break character guarantees the recognition of the start bit of the next frame.

The SCI recognizes a break character when there are 10 or 11(M = 0 or M = 1) consecutive zero received. Depending if the break detect feature is enabled or not receiving a break character has these effects on SCI registers.

If the break detect feature is disabled (BKDFE = 0):

- Sets the framing error flag, FE
- Sets the receive data register full flag, RDRF
- Clears the SCI data registers (SCIDRH/L)
- May set the overrun flag, OR, noise flag, NF, parity error flag, PE, or the receiver active flag, RAF (see 3.4.4 and 3.4.5 SCI Status Register 1 and 2)

If the break detect feature is enabled (BKDFE = 1) there are two scenarios<sup>1</sup>

The break is detected right from a start bit or is detected during a byte reception.

- Sets the break detect interrupt flag, BKDIF
- Does not change the data register full flag, RDRF or overrun flag OR
- Does not change the framing error flag FE, parity error flag PE.
- Does not clear the SCI data registers (SCIDRH/L)
- May set noise flag NF, or receiver active flag RAF.

1. A Break character in this context are either 10 or 11 consecutive zero received bits

| CCOBIX[2:0] | FCCOB Parameters                   |                                                                    |  |  |  |  |  |  |
|-------------|------------------------------------|--------------------------------------------------------------------|--|--|--|--|--|--|
| 000         | 0x0F                               | Not required                                                       |  |  |  |  |  |  |
| 001         | Number of 256 byte sectors for the | Number of 256 byte sectors for the D-Flash user partition (DFPART) |  |  |  |  |  |  |
| 010         | Number of 256 byte sectors for bu  | Iffer RAM EEE partition (ERPART)                                   |  |  |  |  |  |  |

#### Table 25-63. Full Partition D-Flash Command FCCOB Requirements

Upon clearing CCIF to launch the Full Partition D-Flash command, the following actions are taken to define a partition within the D-Flash block for direct access (DFPART) and a partition within the buffer RAM for EEE use (ERPART):

- Validate the DFPART and ERPART values provided:
  - DFPART <= 128 (maximum number of 256 byte sectors in D-Flash block)
  - ERPART <= 16 (maximum number of 256 byte sectors in buffer RAM)
  - If ERPART > 0, 128 DFPART >= 12 (minimum number of 256 byte sectors in the D-Flash block required to support EEE)
  - If ERPART > 0, ((128-DFPART)/ERPART) >= 8 (minimum ratio of D-Flash EEE space to buffer RAM EEE space to support EEE)
- Erase the D-Flash block and the EEE nonvolatile information register
- Program DFPART to the EEE nonvolatile information register at global address 0x12\_0000 (see Table 25-7)
- Program a duplicate DFPART to the EEE nonvolatile information register at global address 0x12\_0002 (see Table 25-7)
- Program ERPART to the EEE nonvolatile information register at global address 0x12\_0004 (see Table 25-7)
- Program a duplicate ERPART to the EEE nonvolatile information register at global address 0x12\_0006 (see Table 25-7)

The D-Flash user partition will start at global address  $0x10_{0000}$ . The buffer RAM EEE partition will end at global address  $0x13_{FFFF}$ . After the Full Partition D-Flash operation has completed, the CCIF flag will set.

Running the Full Partition D-Flash command a second time will result in the previous partition values and the entire D-Flash memory being erased. The data value written corresponds to the number of 256 byte sectors allocated for either direct D-Flash access (DFPART) or buffer RAM EEE access (ERPART).

ter 25 256 KByte Flash Module (S12XFTM256K2V1)

# 25.4.3 Interrupts

The Flash module can generate an interrupt when a Flash command operation has completed or when a Flash command operation has detected an EEE error or an ECC fault.

| Interrupt Source                   | Interrupt Flag                 | Local Enable                   | Global (CCR)<br>Mask |
|------------------------------------|--------------------------------|--------------------------------|----------------------|
| Flash Command Complete             | CCIF<br>(FSTAT register)       | CCIE<br>(FCNFG register)       | l Bit                |
| Flash EEE Erase Error              | ERSERIF<br>(FERSTAT register)  | ERSERIE<br>(FERCNFG register)  | l Bit                |
| Flash EEE Program Error            | PGMERIF<br>(FERSTAT register)  | PGMERIE<br>(FERCNFG register)  | l Bit                |
| Flash EEE Protection Violation     | EPVIOLIF<br>(FERSTAT register) | EPVIOLIE<br>(FERCNFG register) | l Bit                |
| Flash EEE Error Type 1 Violation   | ERSVIF1<br>(FERSTAT register)  | ERSVIE1<br>(FERCNFG register)  | l Bit                |
| Flash EEE Error Type 0 Violation   | ERSVIF0<br>(FERSTAT register)  | ERSVIE0<br>(FERCNFG register)  | l Bit                |
| ECC Double Bit Fault on Flash Read | DFDIF<br>(FERSTAT register)    | DFDIE<br>(FERCNFG register)    | l Bit                |
| ECC Single Bit Fault on Flash Read | SFDIF<br>(FERSTAT register)    | SFDIE<br>(FERCNFG register)    | l Bit                |

Table 25-79. Flash Interrupt Sources

# NOTE

Vector addresses and their relative interrupt priority are determined at the MCU level.

# 25.4.3.1 Description of Flash Interrupt Operation

The Flash module uses the CCIF flag in combination with the CCIE interrupt enable bit to generate the Flash command interrupt request. The Flash module uses the ERSEIF, PGMEIF, EPVIOLIF, ERSVIF1, ERSVIF0, DFDIF and SFDIF flags in combination with the ERSEIE, PGMEIE, EPVIOLIE, ERSVIE1, ERSVIE0, DFDIE and SFDIE interrupt enable bits to generate the Flash error interrupt request. For a detailed description of the register bits involved, refer to Section 25.3.2.5, "Flash Configuration Register (FCNFG)", Section 25.3.2.6, "Flash Error Configuration Register (FERCNFG)", Section 25.3.2.7, "Flash Status Register (FSTAT)", and Section 25.3.2.8, "Flash Error Status Register (FERSTAT)".

The logic used for generating the Flash module interrupts is shown in Figure 25-27.



| Register | Error Bit | Error Condition                                                         |
|----------|-----------|-------------------------------------------------------------------------|
| FSTAT    |           | Set if CCOBIX[2:0] != 001 at command launch                             |
|          |           | Set if a Load Data Field command sequence is currently active           |
|          | ACCENT    | Set if command not available in current mode (see Table 26-30)          |
|          |           | Set if an invalid phrase index is supplied                              |
|          | FPVIOL    | None                                                                    |
|          | MGSTAT1   | Set if any errors have been encountered during the read                 |
|          | MGSTAT0   | Set if any non-correctable errors have been encountered during the read |
| FERSTAT  | EPVIOLIF  | None                                                                    |

Table 26-40. Read Once Command Error Handling

# 26.4.2.5 Load Data Field Command

The Load Data Field command is executed to provide FCCOB parameters for multiple P-Flash blocks for a future simultaneous program operation in the P-Flash memory space.

| CCOBIX[2:0] | FCCOB Parameters                                                         |  |  |  |  |  |  |  |
|-------------|--------------------------------------------------------------------------|--|--|--|--|--|--|--|
| 000         | 0x05 Global address [22:16]<br>identify P-Flash block                    |  |  |  |  |  |  |  |
| 001         | Global address [15:0] of phrase location to be programmed <sup>(1)</sup> |  |  |  |  |  |  |  |
| 010         | Word 0                                                                   |  |  |  |  |  |  |  |
| 011         | Word 1                                                                   |  |  |  |  |  |  |  |
| 100         | Word 2                                                                   |  |  |  |  |  |  |  |
| 101         | Word 3                                                                   |  |  |  |  |  |  |  |

Table 26-41. Load Data Field Command FCCOB Requirements

1. Global address [2:0] must be 000

Upon clearing CCIF to launch the Load Data Field command, the FCCOB registers will be transferred to the Memory Controller and be programmed in the block specified at the global address given with a future Program P-Flash command launched on a P-Flash block. The CCIF flag will set after the Load Data Field operation has completed. Note that once a Load Data Field command sequence has been initiated, the Load Data Field command sequence will be cancelled if any command other than Load Data Field or the future Program P-Flash is launched. Similarly, if an error occurs after launching a Load Data Field or Program P-Flash command, the associated Load Data Field command sequence will be cancelled.

ter 27 512 KByte Flash Module (S12XFTM512K3V1)



Figure 27-3. EEE Resource Memory Map

The Full Partition D-Flash command (see Section 27.4.2.15) is used to program the EEE nonvolatile information register fields where address  $0x12\_0000$  defines the D-Flash partition for user access and address  $0x12\_0004$  defines the buffer RAM partition for EEE operations.







Offset Module Base + 0x0011



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

# 28.3.2.16 Flash Reserved1 Register (FRSV1)

This Flash register is reserved for factory testing.



Figure 28-24. Flash Reserved1 Register (FRSV1)

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

# 28.3.2.17 Flash Reserved2 Register (FRSV2)

This Flash register is reserved for factory testing.



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



## 28.4.1.2.1 Define FCCOB Contents

The FCCOB parameter fields must be loaded with all required parameters for the Flash command being executed. Access to the FCCOB parameter fields is controlled via the CCOBIX bits in the FCCOBIX register (see Section 28.3.2.3).

The contents of the FCCOB parameter fields are transferred to the Memory Controller when the user clears the CCIF command completion flag in the FSTAT register (writing 1 clears the CCIF to 0). The CCIF flag will remain clear until the Flash command has completed. Upon completion, the Memory Controller will return CCIF to 1 and the FCCOB register will be used to communicate any results. The flow for a generic command write sequence is shown in Figure 28-26.

```
ter 29
```

ter 29 1024 KByte Flash Module (S12XFTM1024K5V2)

Offset Module Base + 0x0011



Figure 29-23. Flash Reserved0 Register (FRSV0)

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

# 29.3.2.16 Flash Reserved1 Register (FRSV1)

This Flash register is reserved for factory testing.



Figure 29-24. Flash Reserved1 Register (FRSV1)

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

# 29.3.2.17 Flash Reserved2 Register (FRSV2)

This Flash register is reserved for factory testing.



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



specification at room temperature followed by hot temperature, unless specified otherwise in the device specification.

| Model          | Description                                     | Symbol | Value  | Unit |
|----------------|-------------------------------------------------|--------|--------|------|
| Human Body     | Series resistance                               | R1     | 1500   | Ohm  |
|                | Storage capacitance                             | С      | 100    | pF   |
|                | Number of pulse per pin<br>Positive<br>Negative |        | 1<br>1 |      |
| Charged Device | Number of pulse per pin<br>Positive<br>Negative |        | 3<br>3 |      |
| Latch-up       | Minimum input voltage limit                     |        | -2.5   | V    |
|                | Maximum input voltage limit                     |        | 7.5    | V    |

#### Table A-3. ESD and Latch-Up Protection Characteristics

| Num | С | Rating                                                                       | Symbol           | Min          | Мах | Unit |
|-----|---|------------------------------------------------------------------------------|------------------|--------------|-----|------|
| 1   | С | Human Body Model (HBM)                                                       | V <sub>HBM</sub> | 2000         | —   | V    |
| 2   | С | Charge Device Model (CDM) corner pins<br>Charge Device Model (CDM) edge pins | V <sub>CDM</sub> | 750<br>500   | _   | V    |
| 3   | С | Latch-up current at T <sub>A</sub> = 125°C<br>Positive<br>Negative           | I <sub>LAT</sub> | +100<br>-100 |     | mA   |
| 4   | С | Latch-up current at T <sub>A</sub> = 27°C<br>Positive<br>Negative            | I <sub>LAT</sub> | +200<br>-200 | _   | mA   |



## 0x02F0–0x02F7 Voltage Regulator (VREG\_3V3) Map

| Address  | Name       |   | Bit 7   | Bit 6  | Bit 5  | Bit 4  | Bit 3  | Bit 2  | Bit 1 | Bit 0 |  |
|----------|------------|---|---------|--------|--------|--------|--------|--------|-------|-------|--|
| 0×02E0   | VREGHTCI   | R | 0       | 0      | VSEI   |        | НТЕМ   | HTDS   |       |       |  |
| 0,021 0  | MEGINOL    | W |         |        | VOLL   | VAL    |        |        |       |       |  |
| 0x02E1   | VBEGCTBI   | R | 0       | 0      | 0      | 0      | 0      | LVDS   | IVIE  | IVIE  |  |
| 07021 1  | VILLOOTTLE | W |         |        |        |        |        |        |       |       |  |
| 0x02E2   | VREGAPICI  | R | APICI K | 0      | 0      | APIFES | APIFA  | APIFF  | APIE  | APIF  |  |
| 0,0212   | VILLANTIOL |   | / 1021  |        |        | /      | ,      | /      | /     | /     |  |
| 0x02E3   | VREGAPITR  | R | APITR5  | APITR4 | APITR3 | APITR2 | APITR1 | APITR0 | 0     | 0     |  |
| 0/1021 0 |            |   | W       |        |        |        |        |        |       |       |  |
| 0x02F4   | VREGAPIRH  | R | APIR15  | APIR14 | APIR13 | APIR12 | APIR11 | APIR10 | APIR9 | APIR8 |  |
|          |            | W |         |        |        |        |        |        |       |       |  |
| 0x02F5   | VREGAPIRL  | R | APIR7   | APIR6  | APIR5  | APIR4  | APIR3  | APIR2  | APIR1 | APIR0 |  |
|          | -          | W |         |        |        |        | _      |        |       | _     |  |
| 0x02F6   | Reserved   | R | 0       | 0      | 0      | 0      | 0      | 0      | 0     | 0     |  |
|          | 1.0001700  | W |         |        |        |        |        |        |       |       |  |
| 0x02F7   | VREGHTTR   | R | HTOEN   | 0      | 0      | 0      | HTTB3  | HTTB2  | HTTR1 | HTTR0 |  |
|          |            | W | OEN     |        |        |        |        |        |       |       |  |

# 0x02F8–0x02FF Reserved

| Address                    | Name     |   | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|----------------------------|----------|---|-------|-------|-------|-------|-------|-------|-------|-------|
| 0x02F8–<br>0x02FF Reserved | Recorved | R | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
|                            | w        |   |       |       |       |       |       |       |       |       |

#### 0x0300–0x0327 Pulse Width Modulator 8-Bit 8-Channel (PWM) Map (Sheet 1 of 3)

| Address | Name        | _      | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-------------|--------|-------|-------|-------|-------|-------|-------|-------|-------|
| 0x0300  | PWME        | R<br>W | PWME7 | PWME6 | PWME5 | PWME4 | PWME3 | PWME2 | PWME1 | PWME0 |
| 0x0301  | PWMPOL      | R<br>W | PPOL7 | PPOL6 | PPOL5 | PPOL4 | PPOL3 | PPOL2 | PPOL1 | PPOL0 |
| 0x0302  | PWMCLK      | R<br>W | PCLK7 | PCLK6 | PCLK5 | PCLK4 | PCLK3 | PCLK2 | PCLK1 | PCLK0 |
| 0x0303  | PWMPRCLK    | R<br>W | 0     | PCKB2 | PCKB1 | PCKB0 | 0     | PCKA2 | PCKA1 | PCKA0 |
| 0x0304  | PWMCAE      | R<br>W | CAE7  | CAE6  | CAE5  | CAE4  | CAE3  | CAE2  | CAE1  | CAE0  |
| 0x0305  | PWMCTL      | R<br>W | CON67 | CON45 | CON23 | CON01 | PSWAI | PFRZ  | 0     | 0     |
| 020206  | PWMTST      | R      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| 0x0300  | Test Only   | w      |       |       |       |       |       |       |       |       |
| 0x0307  | 807 PWMPRSC | R      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| 070307  |             |        | W     |       |       |       |       |       |       |       |
| 0x0308  | PWMSCLA     | R<br>W | Bit 7 | 6     | 5     | 4     | 3     | 2     | 1     | Bit 0 |
| 0x0309  | PWMSCLB     | R<br>W | Bit 7 | 6     | 5     | 4     | 3     | 2     | 1     | Bit 0 |

MC9S12XE-Family Reference Manual Rev. 1.25