



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             | HCS12                                                                    |
| Core Size                  | 16-Bit                                                                   |
| Speed                      | 25MHz                                                                    |
| Connectivity               | EBI/EMI, I <sup>2</sup> C, SCI, SPI                                      |
| Peripherals                | POR, PWM, WDT                                                            |
| Number of I/O              | 60                                                                       |
| Program Memory Size        | 64KB (64K x 8)                                                           |
| Program Memory Type        | FLASH                                                                    |
| EEPROM Size                | -                                                                        |
| RAM Size                   | 4K x 8                                                                   |
| Voltage - Supply (Vcc/Vdd) | 2.35V ~ 2.75V                                                            |
| Data Converters            | A/D 16x10b; D/A 2x8b                                                     |
| Oscillator Type            | Internal                                                                 |
| Operating Temperature      | -40°C ~ 105°C (TA)                                                       |
| Mounting Type              | Surface Mount                                                            |
| Package / Case             | 80-QFP                                                                   |
| Supplier Device Package    | 80-QFP (14x14)                                                           |
| Purchase URL               | https://www.e-xfl.com/product-detail/nxp-semiconductors/mc9s12e64vfue16r |

Email: info@E-XFL.COM

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





Chapter 1 MC9S12E128 Device Overview (MC9S12E128DGV1)

### 0x0180 – 0x01AF TIM2 (Timer 16 Bit 4 Channels) (Sheet 3 of 3)

| Address | Name       |             | Bit 7  | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|------------|-------------|--------|-------|-------|-------|-------|-------|-------|-------|
| 0x019D  | TC6 (lo)   | R<br>W      | Bit 7  | 6     | 5     | 4     | 3     | 2     | 1     | Bit 0 |
| 0x019E  | TC7 (hi)   | R<br>W      | Bit 15 | 14    | 13    | 12    | 11    | 10    | 9     | Bit 8 |
| 0x019F  | TC7 (lo)   | R<br>W      | Bit 7  | 6     | 5     | 4     | 3     | 2     | 1     | Bit 0 |
| 0x01A0  | PACTL      | R<br>W      | 0      | PAEN  | PAMOD | PEDGE | CLK1  | CLK0  | PAOVI | PAI   |
| 0x01A1  | PAFLG      | R<br>W      | 0      | 0     | 0     | 0     | 0     | 0     | PAOVF | PAIF  |
| 0x01A2  | PACNT (hi) | R<br>W      | Bit 15 | 14    | 13    | 12    | 11    | 10    | 9     | Bit 8 |
| 0x01A3  | PACNT (lo) | R<br>W      | Bit 7  | 6     | 5     | 4     | 3     | 2     | 1     | Bit 0 |
| 0x01A4  | Reserved   | R<br>W      | 0      | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| 0x01A5  | Reserved   | R<br>W      | 0      | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| 0x01A6  | Reserved   | R<br>W      | 0      | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| 0x01A7  | Reserved   | R<br>W      | 0      | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| 0x01A8  | Reserved   | R<br>W      | 0      | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| 0x01A9  | Reserved   | R           | 0      | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| 0x01AA  | Reserved   | R           | 0      | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| 0x01AB  | Reserved   | R           | 0      | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| 0x01AC  | Reserved   | R           | 0      | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| 0x01AD  | Reserved   | R           | 0      | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| 0x01AE  | Reserved   | R           | 0      | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| 0x01AF  | Reserved   | W<br>R<br>W | 0      | 0     | 0     | 0     | 0     | 0     | 0     | 0     |



Chapter 1 MC9S12E128 Device Overview (MC9S12E128DGV1)

| Address | Name        |   | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|-------------|---|-------|-------|-------|-------|-------|-------|-------|-------|
| 0,0000  | Beconvod    | R | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| 0x0239  | Reserveu    | w |       |       |       |       |       |       |       |       |
| 020224  | Pacanyad    | R | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| 010234  | Reserveu    | w |       |       |       |       |       |       |       |       |
| 020228  | Pacanyod    | R | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| 0X023D  | Reserveu    | w |       |       |       |       |       |       |       |       |
|         | Reserved    | R | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| 0x0230  | I Cesei veu | w |       |       |       |       |       |       |       |       |
| 0×023D  | Pacanyod    | R | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| 0x023D  | Reserveu    | w |       |       |       |       |       |       |       |       |
| 0×022   | Pacanyod    | R | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| 0x023E  | Reserveu    | w |       |       |       |       |       |       |       |       |
| 0v023E  | Reserved    | R | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| UXUZ3F  | Reserved    | w |       |       |       |       |       |       |       |       |

## 0x0200 – 0x023F PMF (Pulse width Modulator with Fault protection) (Sheet 4 of 4)

### 0x0240 – 0x027F PIM (Port Interface Module) (Sheet 1 of 4)

| Address | Name     |        | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|---------|----------|--------|-------|-------|-------|-------|-------|-------|-------|-------|
| 0x0240  | PTT      | R<br>W | PTT7  | PTT6  | PTT5  | PTT4  | PTT3  | PTT2  | PTT1  | PTT0  |
| 0x02/1  | PTIT     | R      | PTIT7 | PTIT6 | PTIT5 | PTIT4 | PTIT3 | PTIT2 | PTIT1 | PTIT0 |
| 070241  |          | w      |       |       |       |       |       |       |       |       |
| 0x0242  | DDRT     | R<br>W | DDRT7 | DDRT7 | DDRT5 | DDRT4 | DDRT3 | DDRT2 | DDRT1 | DDRT0 |
| 0x0243  | RDRT     | R<br>W | RDRT7 | RDRT6 | RDRT5 | RDRT4 | RDRT3 | RDRT2 | RDRT1 | RDRT0 |
| 0x0244  | PERT     | R<br>W | PERT7 | PERT6 | PERT5 | PERT4 | PERT3 | PERT2 | PERT1 | PERT0 |
| 0x0245  | PPST     | R<br>W | PPST7 | PPST6 | PPST5 | PPST4 | PPST3 | PPST2 | PPST1 | PPST0 |
| 0x0246  | Reserved | R      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| 0.0210  | 10001100 | W      |       |       |       |       |       |       |       |       |
| 0x0247  | Reserved | R      | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
|         |          | W      |       |       |       |       |       |       |       |       |
| 0x0248  | PTS      | R<br>W | PTS7  | PTS6  | PTS5  | PTS4  | PTS3  | PTS2  | PTS1  | PTS0  |
| 0x0240  | PTIS     | R      | PTIS7 | PTIS6 | PTIS5 | PTIS4 | PTIS3 | PTIS2 | PTIS1 | PTIS0 |
| 0X0249  | F113     | w      |       |       |       |       |       |       |       |       |



Chapter 1 MC9S12E128 Device Overview (MC9S12E128DGV1)

also be configured as Keypad Wake-up pins (KWU) and generate interrupts causing the MCU to exit STOP or WAIT mode. Consult the Port Integration Module (PIM) PIM\_9E128 block description chapter and the ATD\_10B16C block description chapter for information about pin configurations.

# 1.4.20 PM7 / SCL — Port M I/O Pin 7

PM7 is a general purpose input or output pin. When the IIC module is enabled it becomes the serial clock line (SCL) for the IIC module (IIC). While in reset and immediately out of reset the PM7 pin is configured as a high impedance input pin. Consult the Port Integration Module (PIM) PIM\_9E128 block description chapter and the IIC block description chapter for information about pin configurations.

# 1.4.21 PM6 / SDA — Port M I/O Pin 6

PM6 is a general purpose input or output pin. When the IIC module is enabled it becomes the Serial Data Line (SDL) for the IIC module (IIC). While in reset and immediately out of reset the PM6 pin is configured as a high impedance input pin. Consult the Port Integration Module (PIM) PIM\_9E128 block description chapter and the IIC block description chapter for information about pin configurations.

# 1.4.22 PM5 / TXD2 — Port M I/O Pin 5

PM5 is a general purpose input or output. When the Serial Communications Interface 2 (SCI2) transmitter is enabled the PM5 pin is configured as the transmit pin TXD2 of SCI2. While in reset and immediately out of reset the PM5 pin is configured as a high impedance input pin. Consult the Port Integration Module (PIM) PIM\_9E128 block description chapter and the SCI block description chapter for information about pin configurations.

# 1.4.23 PM4 / RXD2 — Port M I/O Pin 4

PM4 is a general purpose input or output. When the Serial Communications Interface 2 (SCI2) receiver is enabled the PM4 pin is configured as the receive pin RXD2 of SCI2. While in reset and immediately out of reset the PM4 pin is configured as a high impedance input pin. Consult the Port Integration Module (PIM) PIM\_9E128 block description chapter and the SCI block description chapter for information about pin configurations.

# 1.4.24 PM3 — Port M I/O Pin 3

PM3 is a general purpose input or output pin. While in reset and immediately out of reset the PM3 pin is configured as a high impedance input pin. Consult the Port Integration Module (PIM) PIM\_9E128 block description chapter for information about pin configurations.

# 1.4.25 PM1 / DAO1 — Port M I/O Pin 1

PM1 is a general purpose input or output pin. When the Digital to Analog module 1 (DAC1) is enabled the PM1 pin is configured as the analog output DA01 of DAC1. While in reset and immediately out of reset the PM1 pin is configured as a high impedance input pin. Consult the Port Integration Module (PIM)





NOTE: Oscillator in Colpitts mode.

Figure 1-12. Recommended PCB Layout (80-QFP)





Figure 4-19. Check Window Example

The sequence for clock quality check is shown in Figure 4-20.



Figure 4-20. Sequence for Clock Quality Check

### NOTE

Remember that in parallel to additional actions caused by self-clock mode or clock monitor reset<sup>1</sup> handling the clock quality checker **continues** to check the OSCCLK signal.

<sup>1.</sup> A Clock Monitor Reset will always set the SCME bit to logical'1'



Chapter 8 Serial Communication Interface (SCIV3)



Each data character is contained in a frame that includes a start bit, eight or nine data bits, and a stop bit. Clearing the M bit in SCI control register 1 configures the SCI for 8-bit data characters. A frame with eight data bits has a total of 10 bits. Setting the M bit configures the SCI for nine-bit data characters. A frame with nine data bits has a total of 11 bits

| Start<br>Bit | Data<br>Bits | Address<br>Bits | Parity<br>Bits | Stop<br>Bit |
|--------------|--------------|-----------------|----------------|-------------|
| 1            | 8            | 0               | 0              | 1           |
| 1            | 7            | 0               | 1              | 1           |
| 1            | 7            | 1 <sup>1</sup>  | 0              | 1           |

Table 8-11. Example of 8-bit Data Formats

<sup>1</sup> The address bit identifies the frame as an address character. See Section 8.4.5.6, "Receiver Wakeup".

When the SCI is configured for 9-bit data characters, the ninth data bit is the T8 bit in SCI data register high (SCIDRH). It remains unchanged after transmission and can be used repeatedly without rewriting it. A frame with nine data bits has a total of 11 bits.

| Start<br>Bit | Data<br>Bits | Address<br>Bits | Parity<br>Bits | Stop<br>Bit |
|--------------|--------------|-----------------|----------------|-------------|
| 1            | 9            | 0               | 0              | 1           |
| 1            | 8            | 0               | 1              | 1           |
| 1            | 8            | 1 <sup>1</sup>  | 0              | 1           |

#### Table 8-12. Example of 9-Bit Data Formats

<sup>1</sup> The address bit identifies the frame as an address character. See Section 8.4.5.6, "Receiver Wakeup".



Chapter 8 Serial Communication Interface (SCIV3)

### 8.4.5.5.2 Fast Data Tolerance

Figure 8-23 shows how much a fast received frame can be misaligned. The fast stop bit ends at RT10 instead of RT16 but continues to be sampled at RT8, RT9, and RT10.





For an 8-bit data character, it takes the receiver 9 bit times x 16 RTr cycles + 10 RTr cycles = 154 RTr cycles to finish data sampling of the stop bit.

With the misaligned character shown in Figure 8-23, the receiver counts 154 RTr cycles at the point when the count of the transmitting device is 10 bit times x 16 RTt cycles = 160 RTt cycles.

The maximum percent difference between the receiver count and the transmitter count of a fast 8-bit character with no errors is:

 $((160 - 154) / 160) \ge 100 = 3.75\%$ 

For a 9-bit data character, it takes the receiver 10 bit times x 16 RTr cycles + 10 RTr cycles = 170 RTr cycles to finish data sampling of the stop bit.

With the misaligned character shown in Figure 8-23, the receiver counts 170 RTr cycles at the point when the count of the transmitting device is 11 bit times x 16 RTt cycles = 176 RTt cycles.

The maximum percent difference between the receiver count and the transmitter count of a fast 9-bit character with no errors is:

 $((176 - 170) / 176) \ge 100 = 3.40\%$ 

### 8.4.5.6 Receiver Wakeup

To enable the SCI to ignore transmissions intended only for other receivers in multiple-receiver systems, the receiver can be put into a standby state. Setting the receiver wakeup bit, RWU, in SCI control register 2 (SCICR2) puts the receiver into standby state during which receiver interrupts are disabled. The SCI will continue to load the receive data into the SCIDRH/L registers, but it will not set the RDRF flag.

The transmitting device can address messages to selected receivers by including addressing information in the initial frame or frames of each message.

The WAKE bit in SCI control register 1 (SCICR1) determines how the SCI is brought out of the standby state to process an incoming message. The WAKE bit enables either idle line wakeup or address mark wakeup.



Chapter 10 Inter-Integrated Circuit (IICV2)

# 10.3.2 Register Descriptions

This section consists of register descriptions in address order. Each description includes a standard register diagram with an associated figure number. Details of register bit and field function follow the register diagrams, in bit order.

| Register<br>Name |        | Bit 7                       | 6    | 5     | 4     | 3        | 2     | 1     | Bit 0  |
|------------------|--------|-----------------------------|------|-------|-------|----------|-------|-------|--------|
| IBAD             | R      |                             | ADR6 |       |       |          |       |       | 0      |
|                  | W      |                             |      | ADIG  |       |          | ADITZ | ADITI |        |
| IBFD             | R<br>W | IBC7                        | IBC6 | IBC5  | IBC4  | IBC3     | IBC2  | IBC1  | IBC0   |
| IBCR             | R      | R                           |      |       | - (5) |          | 0     | 0     |        |
|                  | w      | IBEN                        | IBIE | MS/SL | Tx/Rx | /Rx TXAK | RSTA  |       | IBSWAI |
| IBSR             | R      | TCF                         | IAAS | IBB   |       | 0        | SRW   |       | RXAK   |
|                  | w      |                             |      |       | IBAL  |          |       | IBIF  |        |
| IBDR             | R<br>W | D7                          | D6   | D5    | D4    | D3       | D2    | D1    | D0     |
|                  | [      | = Unimplemented or Reserved |      |       |       |          |       |       |        |

### Table 10-1. IIC Register Summary

## 10.3.2.1 IIC Address Register (IBAD)



### Figure 10-2. IIC Bus Address Register (IBAD)

Read and write anytime

This register contains the address the IIC bus will respond to when addressed as a slave; note that it is not the address sent on the bus during the address transfer.

#### Table 10-2. IBAD Field Descriptions

| Field           | Description                                                                                                                                                                    |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:1<br>ADR[7:1] | Slave Address — Bit 1 to bit 7 contain the specific slave address to be used by the IIC bus module. The default mode of IIC bus is slave mode for an address match on the bus. |
| 0<br>Reserved   | Reserved — Bit 0 of the IBAD is reserved for future compatibility. This bit will always read 0.                                                                                |

#### MC9S12E128 Data Sheet, Rev. 1.07



| IBC[7:0]<br>(hex) | SCL Divider<br>(clocks) | SDA Hold<br>(clocks) | SCL Hold<br>(start) | SCL Hold<br>(stop) |
|-------------------|-------------------------|----------------------|---------------------|--------------------|
| A8                | 1280                    | 132                  | 632                 | 644                |
| A9                | 1536                    | 132                  | 760                 | 772                |
| AA                | 1792                    | 260                  | 888                 | 900                |
| AB                | 2048                    | 260                  | 1016                | 1028               |
| AC                | 2304                    | 388                  | 1144                | 1156               |
| AD                | 2560                    | 388                  | 1272                | 1284               |
| AE                | 3072                    | 516                  | 1528                | 1540               |
| AF                | 3840                    | 516                  | 1912                | 1924               |
| B0                | 2560                    | 260                  | 1272                | 1284               |
| B1                | 3072                    | 260                  | 1528                | 1540               |
| B2                | 3584                    | 516                  | 1784                | 1796               |
| B3                | 4096                    | 516                  | 2040                | 2052               |
| B4                | 4608                    | 772                  | 2296                | 2308               |
| B5                | 5120                    | 772                  | 2552                | 2564               |
| B6                | 6144                    | 1028                 | 3064                | 3076               |
| B7                | 7680                    | 1028                 | 3832                | 3844               |
| B8                | 5120                    | 516                  | 2552                | 2564               |
| B9                | 6144                    | 516                  | 3064                | 3076               |
| BA                | 7168                    | 1028                 | 3576                | 3588               |
| BB                | 8192                    | 1028                 | 4088                | 4100               |
| BC                | 9216                    | 1540                 | 4600                | 4612               |
| BD                | 10240                   | 1540                 | 5112                | 5124               |
| BE                | 12288                   | 2052                 | 6136                | 6148               |
| BF                | 15360                   | 2052                 | 7672                | 7684               |

#### Table 10-6. IIC Divider and Hold Values (Sheet 5 of 5)

## 10.3.2.3 IIC Control Register (IBCR)



### Figure 10-5. IIC Bus Control Register (IBCR)

Read and write anytime



## 11.3.2.3 PMF Configure 2 Register (PMFCFG2)



Figure 11-6. PMF Configure 2 Register (PMFCFG2)

Read and write anytime.

Module Base + 0x0002

| Field           | Description                                                                                                                                                                                          |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 5–0<br>MSK[5:0] | <ul> <li>Mask PWMx— Where x is 0, 1, 2, 3, 4, and 5.</li> <li>0 PWMx is unmasked.</li> <li>1 PWMx is masked and the channel is set to a value of 0 percent duty cycle.</li> </ul>                    |
|                 | <b>Note: WARNING</b> When using the TOPNEG/BOTNEG bits and the MSKx bits at the same time, when in complementary mode, it is possible to have both pmf channel outputs of a channel pair set to one. |

#### Table 11-4. PMFCFG2 Field Descriptions



#### Chapter 11 Pulse Width Modulator with Fault Protection (PMF15B6CV2)

In complementary channel operation, there are three additional features:

- Deadtime insertion
- Separate top and bottom pulse width correction for distortions are caused by deadtime inserted and the motor drive characteristics
- Separate top and bottom output polarity control
- Swap functionality

## 11.4.5 Deadtime Generators

While in the complementary mode, each PWM pair can be used to drive top/bottom transistors, as shown in Figure 11-49. Ideally, the PWM pairs are an inversion of each other. When the top PWM channel is active, the bottom PWM channel is inactive, and vice versa.

### NOTE

To avoid a short-circuit on the DC bus and endangering the transistor, there must be no overlap of conducting intervals between top and bottom transistor. But the transistor's characteristics make its switching-off time longer than switching-on time. To avoid the conducting overlap of top and bottom transistors, deadtime needs to be inserted in the switching period.

Deadtime generators automatically insert software-selectable activation delays into each pair of PWM outputs. The deadtime register (PMFDTMx) specifies the number of PWM clock cycles to use for deadtime delay. Every time the deadtime generator inputs changes state, deadtime is inserted. Deadtime forces both PWM outputs in the pair to the inactive state.

A method of correcting this, adding to or subtracting from the PWM value used, is discussed next.



Figure 11-49. Deadtime Generators



Chapter 11 Pulse Width Modulator with Fault Protection (PMF15B6CV2)

Setting the OUTCTLx bits do not disable the PWM generators and current status sensing circuitry. They continue to run, but no longer control the output pins. When the OUTCTLx bits are cleared, the outputs of the PWM generator become the inputs to the deadtime generators at the beginning of the next PWM cycle. Software can drive the PWM outputs even when PWM enable bit (PWMEN) is set to zero.

### NOTE

Avoid an unexpected deadtime insertion by clearing the OUTx bits before setting and after clearing the OUTCTLx bits.



Figure 11-62. Setting OUT0 with OUTCTL Set in Complementary Mode



# 13.3 Memory Map and Register Definition

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

## 13.3.1 Module Memory Map

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

| Address Offset  | Use                                                     | Access           |
|-----------------|---------------------------------------------------------|------------------|
| 0x0000          | Timer Input Capture/Output Compare Select (TIOS)        | R/W              |
| 0x0001          | Timer Compare Force Register (CFORC)                    | R/W <sup>1</sup> |
| 0x0002          | Output Compare 7 Mask Register (OC7M)                   | R/W              |
| 0x0003          | Output Compare 7 Data Register (OC7D)                   | R/W              |
| 0x0004          | Timer Count Register (TCNT(hi))                         | R/W <sup>2</sup> |
| 0x0005          | Timer Count Register (TCNT(lo))                         | R/W <sup>2</sup> |
| 0x0006          | Timer System Control Register1 (TSCR1)                  | R/W              |
| 0x0007          | Timer Toggle Overflow Register (TTOV)                   | R/W              |
| 0x0008          | Timer Control Register1 (TCTL1)                         | R/W              |
| 0x0009          | Reserved                                                | _ 3              |
| 0x000A          | Timer Control Register3 (TCTL3)                         | R/W              |
| 0x000B          | Reserved                                                | _ 3              |
| 0x000C          | Timer Interrupt Enable Register (TIE)                   | R/W              |
| 0x000D          | Timer System Control Register2 (TSCR2)                  | R/W              |
| 0x000E          | Main Timer Interrupt Flag1 (TFLG1)                      | R/W              |
| 0x000F          | Main Timer Interrupt Flag2 (TFLG2)                      | R/W              |
| 0x0010 - 0x0017 | Reserved                                                | _3               |
| 0x0018          | Timer Input Capture/Output Compare Register4 (TC4(hi))  | R/W <sup>4</sup> |
| 0x0019          | Timer Input Capture/Output Compare Register 4 (TC4(lo)) | R/W <sup>4</sup> |
| 0x001A          | Timer Input Capture/Output Compare Register 5 (TC5(hi)) | R/W <sup>4</sup> |
| 0x001B          | Timer Input Capture/Output Compare Register 5 (TC5(lo)) | R/W <sup>4</sup> |
| 0x001C          | Timer Input Capture/Output Compare Register 6 (TC6(hi)) | R/W <sup>4</sup> |
| 0x001D          | Timer Input Capture/Output Compare Register 6 (TC6(lo)) | R/W <sup>4</sup> |
| 0x001E          | Timer Input Capture/Output Compare Register 7 (TC7(hi)) | R/W <sup>4</sup> |
| 0x001F          | Timer Input Capture/Output Compare Register 7 (TC7(lo)) | R/W <sup>4</sup> |
| 0x0020          | 16-Bit Pulse Accumulator Control Register (PACTL)       | R/W              |
| 0x0021          | Pulse Accumulator Flag Register (PAFLG)                 | R/W              |
| 0x0022          | Pulse Accumulator Count Register (PACNT(hi))            | R/W              |
| 0x0023          | Pulse Accumulator Count Register (PACNT(lo))            | R/W              |
| 0x0024 - 0x002C | Reserved                                                | 3                |
| 0x002D          | Timer Test Register (TIMTST)                            | R/W <sup>2</sup> |
| 0x002E – 0x002F | Reserved                                                | 3                |

| Tahla | 12-1  | TIM16B/CV1 | Memory   | Man   |
|-------|-------|------------|----------|-------|
| lable | 13-1. |            | wiennory | iviap |

<sup>1</sup> Always read 0x0000.



#### Chapter 13 Timer Module (TIM16B4CV1)

- <sup>2</sup> Only writable in special modes (test\_mode = 1).
- <sup>3</sup> Write has no effect; return 0 on read
- <sup>4</sup> Write to these registers have no meaning or effect during input capture.

## 13.3.2 Register Descriptions

This section consists of register descriptions in address order. Each description includes a standard register diagram with an associated figure number. Details of register bit and field function follow the register diagrams, in bit order.

| Register<br>Name   |        | Bit 7  | 6      | 5      | 4      | 3      | 2      | 1     | Bit 0 |
|--------------------|--------|--------|--------|--------|--------|--------|--------|-------|-------|
| 0x0000<br>TIOS     | R<br>W | IOS7   | IOS6   | IOS5   | IOS4   | IOS3   | IOS2   | IOS1  | IOS0  |
|                    | _      |        | -      |        |        | -      |        | _     |       |
| 0x0001             | R      | 0      | 0      | 0      | 0      | 0      | 0      | 0     | 0     |
|                    | W      | FOC7   | FOC6   | FOC5   | FOC4   | FOC3   | FOC2   | FOC1  | FOC0  |
| 0x0002<br>OC7M     | R<br>W | OC7M7  | OC7M6  | OC7M5  | OC7M4  | OC7M3  | OC7M2  | OC7M1 | OC7M0 |
| 0x0003<br>OC7D     | R<br>W | OC7D7  | OC7D6  | OC7D5  | OC7D4  | OC7D3  | OC7D2  | OC7D1 | OC7D0 |
| 0x0004<br>TCNTH    | R<br>W | TCNT15 | TCNT14 | TCNT13 | TCNT12 | TCNT11 | TCNT10 | TCNT9 | TCNT8 |
| 0x0005<br>TCNTL    | R<br>W | TCNT7  | TCNT6  | TCNT5  | TCNT4  | TCNT3  | TCNT2  | TCNT1 | TCNT0 |
| 0x0006<br>TSCR2    | R<br>W | TEN    | TSWAI  | TSFRZ  | TFFCA  | 0      | 0      | 0     | 0     |
|                    |        |        |        |        |        |        |        |       |       |
| 0x0007<br>TTOV     | R<br>W | TOV7   | TOV6   | TOV5   | TOV4   | TOV3   | TOV2   | TOV1  | TOV0  |
| 0x0008<br>TCTL1    | R<br>W | OM7    | OL7    | OM6    | OL6    | OM5    | OL5    | OM4   | OL4   |
| 0x0009<br>Reserved | R      | 0      | 0      | 0      | 0      | 0      | 0      | 0     | 0     |
|                    | w      |        |        |        |        |        |        |       |       |
| 0x000A<br>TCTL3    | R<br>W | EDG7B  | EDG7A  | EDG6B  | EDG6A  | EDG5B  | EDG5A  | EDG4B | EDG4A |

= Unimplemented or Reserved

Figure 13-5. TIM16B4CV1 Register Summary

MC9S12E128 Data Sheet, Rev. 1.07



#### Chapter 15 Background Debug Module (BDMV4)

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

Table 15-5. Hardware Commands

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

NOTE:

If enabled, ACK will occur when data is ready for transmission for all BDM READ commands and will occur after the write is complete for all BDM WRITE commands.

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

## 15.4.4 Standard BDM Firmware Commands

Firmware commands are used to access and manipulate CPU resources. The system must be in active BDM to execute standard BDM firmware commands, see Section 15.4.2, "Enabling and Activating BDM." Normal instruction execution is suspended while the CPU executes the firmware located in the standard BDM firmware lookup table. The hardware command BACKGROUND is the usual way to activate BDM.

As the system enters active BDM, the standard BDM firmware lookup table and BDM registers become visible in the on-chip memory map at 0xFF00–0xFFFF, and the CPU begins executing the standard BDM



# Chapter 16 Debug Module (DBGV1)

# 16.1 Introduction

This section describes the functionality of the debug (DBG) sub-block of the HCS12 core platform.

The DBG module is designed to be fully compatible with the existing BKP\_HCS12\_A module (BKP mode) and furthermore provides an on-chip trace buffer with flexible triggering capability (DBG mode). The DBG module provides for non-intrusive debug of application software. The DBG module is optimized for the HCS12 16-bit architecture.

## 16.1.1 Features

The DBG module in BKP mode includes these distinctive features:

- Full or dual breakpoint mode
  - Compare on address and data (full)
  - Compare on either of two addresses (dual)
- BDM or SWI breakpoint
  - Enter BDM on breakpoint (BDM)
  - Execute SWI on breakpoint (SWI)
- Tagged or forced breakpoint
  - Break just before a specific instruction will begin execution (TAG)
  - Break on the first instruction boundary after a match occurs (Force)
- Single, range, or page address compares
  - Compare on address (single)
  - Compare on address 256 byte (range)
  - Compare on any 16K page (page)
- At forced breakpoints compare address on read or write
- High and/or low byte data compares
- Comparator C can provide an additional tag or force breakpoint (enhancement for BKP mode)



Chapter 16 Debug Module (DBGV1)

## 16.3.2.2 Debug Status and Control Register (DBGSC)



### Figure 16-5. Debug Status and Control Register (DBGSC)

#### Table 16-5. DBGSC Field Descriptions

| Field      | Description                                                                                                                                                                                                                                                                            |
|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>AF    | <ul> <li>Trigger A Match Flag — The AF bit indicates if trigger A match condition was met since arming. This bit is cleared when ARM in DBGC1 is written to a 1 or on any write to this register.</li> <li>0 Trigger A did not match</li> <li>1 Trigger A match</li> </ul>             |
| 6<br>BF    | <ul> <li>Trigger B Match Flag — The BF bit indicates if trigger B match condition was met since arming. This bit is cleared when ARM in DBGC1 is written to a 1 or on any write to this register.</li> <li>0 Trigger B did not match</li> <li>1 Trigger B match</li> </ul>             |
| 5<br>CF    | <ul> <li>Comparator C Match Flag — The CF bit indicates if comparator C match condition was met since arming. This bit is cleared when ARM in DBGC1 is written to a 1 or on any write to this register.</li> <li>0 Comparator C did not match</li> <li>1 Comparator C match</li> </ul> |
| 3:0<br>TRG | <b>Trigger Mode Bits</b> — The TRG bits select the trigger mode of the DBG module as shown Table 16-6. See Section 16.4.2.5, "Trigger Modes," for more detail.                                                                                                                         |

| TRG Value    | Meaning                 |  |  |
|--------------|-------------------------|--|--|
| 0000         | A only                  |  |  |
| 0001         | A or B                  |  |  |
| 0010         | A then B                |  |  |
| 0011         | Event only B            |  |  |
| 0100         | A then event only B     |  |  |
| 0101         | A and B (full mode)     |  |  |
| 0110         | A and Not B (full mode) |  |  |
| 0111         | Inside range            |  |  |
| 1000         | Outside range           |  |  |
| 1001         | Reserved                |  |  |
| $\downarrow$ | (Defaults to A only)    |  |  |
| 1111         |                         |  |  |

#### Table 16-6. Trigger Mode Encoding

MC9S12E128 Data Sheet, Rev. 1.07



control bits PIPOE, LSTRE and RDWE are reset to zero. Writing the opposite value into these bits in single chip mode does not change the operation of the associated Port E pins.

Port E, bit 4 can be configured for a free-running E clock output by clearing NECLK=0. Typically the only use for an E clock output while the MCU is in single chip modes would be to get a constant speed clock for use in the external application system.

### 18.4.3.2.2 Special Test Mode

In expanded wide modes, Ports A and B are configured as a 16-bit multiplexed address and data bus and Port E provides bus control and status signals. In special test mode, the write protection of many control bits is lifted so that they can be thoroughly tested without needing to go through reset.

### 18.4.3.3 Test Operating Mode

There is a test operating mode in which an external master, such as an I.C. tester, can control the on-chip peripherals.

### 18.4.3.3.1 Peripheral Mode

This mode is intended for factory testing of the MCU. In this mode, the CPU is inactive and an external (tester) bus master drives address, data and bus control signals in through Ports A, B and E. In effect, the whole MCU acts as if it was a peripheral under control of an external CPU. This allows faster testing of on-chip memory and peripherals than previous testing methods. Since the mode control register is not accessible in peripheral mode, the only way to change to another mode is to reset the MCU into a different mode. Background debugging should not be used while the MCU is in special peripheral mode as internal bus conflicts between BDM and the external master can cause improper operation of both functions.

### 18.4.4 Internal Visibility

Internal visibility is available when the MCU is operating in expanded wide modes or emulation narrow mode. It is not available in single-chip, peripheral or normal expanded narrow modes. Internal visibility is enabled by setting the IVIS bit in the MODE register.

If an internal access is made while E,  $R/\overline{W}$ , and  $\overline{LSTRB}$  are configured as bus control outputs and internal visibility is off (IVIS=0), E will remain low for the cycle,  $R/\overline{W}$  will remain high, and address, data and the  $\overline{LSTRB}$  pins will remain at their previous state.

When internal visibility is enabled (IVIS=1), certain internal cycles will be blocked from going external. During cycles when the BDM is selected,  $R/\overline{W}$  will remain high, data will maintain its previous state, and address and  $\overline{LSTRB}$  pins will be updated with the internal value. During CPU no access cycles when the BDM is not driving,  $R/\overline{W}$  will remain high, and address, data and the  $\overline{LSTRB}$  pins will remain at their previous state.



injection current may flow out of VDD5 and could result in external power supply going out of regulation. Insure external VDD5 load will shunt current greater than maximum injection current. This will be the greatest risk when the MCU is not consuming power; e.g. if no system clock is present, or if clock rate is very low which would reduce overall power consumption.

## A.1.5 Absolute Maximum Ratings

Absolute maximum ratings are stress ratings only. A functional operation under or outside those maxima is not guaranteed. Stress beyond those limits may affect the reliability or cause permanent damage of the device.

This device contains circuitry protecting against damage due to high static voltage or electrical fields; however, it is advised that normal precautions be taken to avoid application of any voltages higher than maximum-rated voltages to this high-impedance circuit. Reliability of operation is enhanced if unused inputs are tied to an appropriate logic voltage level (e.g., either  $V_{SS5}$  or  $V_{DD5}$ ).

| Num | Rating                                                                                  | Symbol                           | Min   | Мах  | Unit |
|-----|-----------------------------------------------------------------------------------------|----------------------------------|-------|------|------|
| 1   | I/O, Regulator and Analog Supply Voltage                                                | V <sub>DD5</sub>                 | -0.3  | 6.5  | V    |
| 2   | Internal Logic Supply Voltage <sup>1</sup>                                              | V <sub>DD</sub>                  | -0.3  | 3.0  | V    |
| 3   | PLL Supply Voltage <sup>1</sup>                                                         | V <sub>DDPLL</sub>               | -0.3  | 3.0  | V    |
| 4   | Voltage difference VDDX to VDDR and VDDA                                                | $\Delta_{VDDX}$                  | -0.3  | 0.3  | V    |
| 5   | Voltage difference VSSX to VSSR and VSSA                                                | Δ <sub>VSSX</sub>                | -0.3  | 0.3  | V    |
| 6   | Digital I/O Input Voltage                                                               | V <sub>IN</sub>                  | -0.3  | 6.5  | V    |
| 7   | Analog Reference                                                                        | V <sub>RH,</sub> V <sub>RL</sub> | -0.3  | 6.5  | V    |
| 8   | XFC, EXTAL, XTAL inputs                                                                 | V <sub>ILV</sub>                 | -0.3  | 3.0  | V    |
| 9   | TEST input                                                                              | V <sub>TEST</sub>                | -0.3  | 10.0 | V    |
| 10  | Instantaneous Maximum Current<br>Single pin limit for all digital I/O pins <sup>2</sup> | I <sub>D</sub>                   | -25   | +25  | mA   |
| 11  | Instantaneous Maximum Current<br>Single pin limit for XFC, EXTAL, XTAL <sup>3</sup>     | I <sub>DL</sub>                  | -25   | +25  | mA   |
| 12  | Instantaneous Maximum Current<br>Single pin limit for TEST <sup>4</sup>                 | I <sub>DT</sub>                  | -0.25 | 0    | mA   |
| 13  | Operating Temperature Range (packaged)                                                  | T <sub>A</sub>                   | - 40  | 125  | °C   |
| 14  | Operating Temperature Range (junction)                                                  | TJ                               | - 40  | 140  | °C   |
| 15  | Storage Temperature Range                                                               | T <sub>stg</sub>                 | - 65  | 155  | °C   |

#### Table A-1. Absolute Maximum Ratings

<sup>1</sup> The device contains an internal voltage regulator to generate the logic and PLL supply out of the I/O supply. The absolute maximum ratings apply when the device is powered from an external source.

 $^2$  All digital I/O pins are internally clamped to V\_{SSX} and V\_{DDX}, V\_{SSR} and V\_{DDR} or V\_{SSA} and V\_{DDA}.

 $^3$  These pins are internally clamped to V<sub>SSPLL</sub> and V<sub>DDPLL</sub>

<sup>4</sup> This pin is clamped low to V<sub>SSR</sub>, but not clamped high. This pin must be tied low in applications.