

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 ~ 85°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/mc9s12e64cfue |

Email: info@E-XFL.COM

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



# Chapter 9 Serial Peripheral Interface (SPIV3)

| 9.1 | Introdu  | ction                              | . 277 |
|-----|----------|------------------------------------|-------|
|     | 9.1.1    | Features                           | . 277 |
|     | 9.1.2    | Modes of Operation                 | . 277 |
|     | 9.1.3    | Block Diagram                      | . 278 |
| 9.2 | Externa  | l Signal Description               | . 278 |
|     | 9.2.1    | MOSI — Master Out/Slave In Pin     | . 278 |
|     | 9.2.2    | MISO — Master In/Slave Out Pin     | . 279 |
|     | 9.2.3    | $\overline{SS}$ — Slave Select Pin | . 279 |
|     | 9.2.4    | SCK — Serial Clock Pin             | . 279 |
| 9.3 | Memory   | y Map and Register Definition      | . 279 |
|     | 9.3.1    | Module Memory Map                  | . 279 |
|     | 9.3.2    | Register Descriptions              | . 280 |
| 9.4 | Functio  | nal Description                    | . 287 |
|     | 9.4.1    | Master Mode                        | . 288 |
|     | 9.4.2    | Slave Mode                         | . 289 |
|     | 9.4.3    | Transmission Formats               | . 290 |
|     | 9.4.4    | SPI Baud Rate Generation           | . 293 |
|     | 9.4.5    | Special Features                   | . 294 |
|     | 9.4.6    | Error Conditions                   | . 295 |
|     | 9.4.7    | Operation in Run Mode              | . 296 |
|     | 9.4.8    | Operation in Wait Mode             | . 296 |
|     | 9.4.9    | Operation in Stop Mode             | . 296 |
| 9.5 | Reset.   |                                    | . 297 |
| 9.6 | Interrup | ots                                | . 297 |
|     | 9.6.1    | MODF                               | . 297 |
|     | 9.6.2    | SPIF                               | . 297 |
|     | 9.6.3    | SPTEF                              | . 297 |

## Chapter 10 Inter-Integrated Circuit (IICV2)

| 10.1 | Introduction                           | 299 |
|------|----------------------------------------|-----|
|      | 10.1.1 Features                        | 299 |
|      | 10.1.2 Modes of Operation              | 300 |
|      | 10.1.3 Block Diagram                   | 300 |
| 10.2 | External Signal Description            | 301 |
|      | 10.2.1 IIC_SCL — Serial Clock Line Pin | 301 |
|      | 10.2.2 IIC_SDA — Serial Data Line Pin  | 301 |
| 10.3 | Memory Map and Register Definition     | 301 |
|      | 10.3.1 Module Memory Map               | 301 |
|      | 10.3.2 Register Descriptions           | 302 |
| 10.4 | Functional Description                 | 313 |
|      | 10.4.1 I-Bus Protocol                  | 313 |



Chapter 1 MC9S12E128 Device Overview (MC9S12E128DGV1)



The figure shows a useful map, which is not the map out of reset. After reset the map is:

\$0000-\$03FF: Register Space \$0000-\$1FFF: 8K RAM (only 7K RAM visible \$0400-\$1FFF)

Figure 1-2. MC9S12E128 User Configurable Memory Map



Refer to the ATD block description chapter for information on the ATDDIEN0 and ATDDIEN1 registers.

During reset, port AD pins are configured as high-impedance analog inputs (digital input buffer is disabled).

| _      | 7      | 6      | 5      | 4      | 3      | 2      | 1     | 0     |
|--------|--------|--------|--------|--------|--------|--------|-------|-------|
| R<br>W | PTAD15 | PTAD14 | PTAD13 | PTAD12 | PTAD11 | PTAD10 | PTAD9 | PTAD8 |
| KWU:   | KWAD15 | KWAD14 | KWAD13 | KWA12  | KWAD11 | KWAD10 | KWAD9 | KWAD8 |
| ATD:   | AN15   | AN14   | AN13   | AN12   | AN11   | AN10   | AN9   | AN8   |
| Reset  | 0      | 0      | 0      | 0      | 0      | 0      | 0     | 0     |
| _      | 7      | 6      | 5      | 4      | 3      | 2      | 1     | 0     |
| R<br>W | PTAD7  | PTAD6  | PTAD5  | PTAD4  | PTAD3  | PTAD2  | PTAD1 | PTAD0 |
| KWU:   | KWAD7  | KWAD6  | KWAD5  | KWAD4  | KWAD3  | KWAD2  | KWAD1 | KWAD0 |
| ATD:   | AN7    | AN6    | AN5    | AN4    | AN3    | AN2    | AN1   | AN0   |
| Reset  | 0      | 0      | 0      | 0      | 0      | 0      | 0     | 0     |

## 3.3.1.1 Port AD I/O Register (PTAD)

Figure 3-2. Port AD I/O Register (PTAD)

Read: Anytime. Write: Anytime.

If the data direction bit of the associated I/O pin (DDRADx) is set to 1 (output), a write to the corresponding I/O Register bit sets the value to be driven to the Port AD pin. If the data direction bit of the associated I/O pin (DDRADx) is set to 0 (input), a write to the corresponding I/O Register bit takes place but has no effect on the Port AD pin.

If the associated data direction bit (DDRADx) is set to 1 (output), a read returns the value of the I/O register bit.

If the associated data direction bit (DDRADx) is set to 0 (input) and the associated ATDDIEN0(1) bit is set to 0 (digital input buffer is disabled), the associated I/O register bit (PTADx) reads "1".

If the associated data direction bit (DDRADx) is set to 0 (input) and the associated ATDDIEN0(1) bit is set to 1 (digital input buffer is enabled), a read returns the value of the pin.



| Field       | Description                                                                                                                                                                                                                                      |
|-------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1<br>RTIWAI | <ul> <li>RTI Stops in Wait Mode Bit — Write: anytime</li> <li>0 RTI keeps running in wait mode.</li> <li>1 RTI stops and initializes the RTI dividers whenever the part goes into wait mode.</li> </ul>                                          |
| 0<br>COPWAI | <ul> <li>COP Stops in Wait Mode Bit — Normal modes: Write once — Special modes: Write anytime</li> <li>0 COP keeps running in wait mode.</li> <li>1 COP stops and initializes the COP dividers whenever the part goes into wait mode.</li> </ul> |

#### Table 4-4. CLKSEL Field Descriptions (continued)

## 4.3.2.7 CRG PLL Control Register (PLLCTL)

This register controls the PLL functionality.

7 6 5 4 0 3 2 1 R 0 CME PLLON AUTO ACQ PRE PCE SCME W Reset 1 1 1 1 0 0 0 1 = Unimplemented or Reserved

### Figure 4-10. CRG PLL Control Register (PLLCTL)

Read: anytime

Write: refer to each bit for individual write conditions

| Table 4-5. PLLCTL Field Descriptions | Table 4-5 | PLLCTL | . Field | Descriptions |
|--------------------------------------|-----------|--------|---------|--------------|
|--------------------------------------|-----------|--------|---------|--------------|

| Field      | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>CME   | <ul> <li>Clock Monitor Enable Bit — CME enables the clock monitor. Write anytime except when SCM = 1.</li> <li>0 Clock monitor is disabled.</li> <li>1 Clock monitor is enabled. Slow or stopped clocks will cause a clock monitor reset sequence or self-clock mode.</li> </ul>                                                                                                                                                                                                |
|            | Note: Operating with CME = 0 will not detect any loss of clock. In case of poor clock quality this could cause unpredictable operation of the MCU.                                                                                                                                                                                                                                                                                                                              |
|            | <b>Note:</b> In Stop Mode (PSTP = 0) the clock monitor is disabled independently of the CME bit setting and any loss of clock will not be detected.                                                                                                                                                                                                                                                                                                                             |
| 6<br>PLLON | <ul> <li>Phase Lock Loop On Bit — PLLON turns on the PLL circuitry. In self-clock mode, the PLL is turned on, but the PLLON bit reads the last latched value. Write anytime except when PLLSEL = 1.</li> <li>0 PLL is turned off.</li> <li>1 PLL is turned on. If AUTO bit is set, the PLL will lock automatically.</li> </ul>                                                                                                                                                  |
| 5<br>AUTO  | <ul> <li>Automatic Bandwidth Control Bit — AUTO selects either the high bandwidth (acquisition) mode or the low bandwidth (tracking) mode depending on how close to the desired frequency the VCO is running. Write anytime except when PLLWAI=1, because PLLWAI sets the AUTO bit to 1.</li> <li>0 Automatic mode control is disabled and the PLL is under software control, using ACQ bit.</li> <li>1 Automatic mode control is enabled and ACQ bit has no effect.</li> </ul> |
| 4<br>ACQ   | <ul> <li>Acquisition Bit — Write anytime. If AUTO=1 this bit has no effect.</li> <li>0 Low bandwidth filter is selected.</li> <li>1 High bandwidth filter is selected.</li> </ul>                                                                                                                                                                                                                                                                                               |



# 6.3.2 Register Descriptions

This section describes in address order all the ATD10B16C registers and their individual bits.

| Register<br>Name   |        | Bit 7                                    | 6     | 5     | 4            | 3      | 2      | 1      | Bit 0 |
|--------------------|--------|------------------------------------------|-------|-------|--------------|--------|--------|--------|-------|
| 0x0000             | R      | 0                                        | 0     | 0     | 0            | 0      | 0      | 0      | 0     |
| ATDCTL0            | w      |                                          |       |       |              |        |        |        |       |
|                    | г      |                                          | 1     | l     |              |        |        |        |       |
| 0x0001<br>ATDCTL1  | R      | 0                                        | 0     | 0     | 0            | 0      | 0      | 0      | 0     |
|                    | vv     |                                          |       |       |              |        |        |        |       |
| 0x0002             | R      | ADPU                                     | AFEC  | AWAI  | ETRIGI E     | FTRIGP | FTRIGE | ASCIE  | ASCIF |
| AIDCIL2            | w      |                                          |       | ,     |              | 211401 | 211102 | 7.001L |       |
| 0x0003             | R      | 0                                        | 590   | S4C   | 520          | S10    |        |        |       |
| ATDCTL3            | w      |                                          | 300   | 540   | 520          | 510    | FIFO   | FRZI   | FRZU  |
| 0x0004             | R      |                                          |       |       |              |        |        |        |       |
| ATDCTL4            | w      | SRES8                                    | SMP1  | SMP0  | PRS4         | PRS3   | PRS2   | PRS1   | PRS0  |
| 0x0005             | р<br>Г |                                          |       |       |              |        |        |        |       |
| ATDCTL5            | w      | DJM                                      | DSGN  | SCAN  | MULT         | CD     | CC     | СВ     | CA    |
|                    | - [    |                                          | -     |       |              |        |        |        |       |
| 0x0006<br>ATDSTAT0 | R      | SCF                                      | 0     | ETORF | FIFOR        | CC3    | CC2    | CC1    | CC0   |
|                    | vv     |                                          |       |       |              |        |        |        |       |
| 0x0007             | R      |                                          |       |       |              |        |        |        |       |
| Unimplemented      | w      |                                          |       |       |              |        |        |        |       |
| 0x0008             | R      |                                          |       |       | emented      |        |        |        |       |
| ATDTEST0           | w[     |                                          |       |       |              |        |        |        |       |
| 0x0009             | R      |                                          |       | U     | Inimplemente | ed     |        |        |       |
| ATDTEST1           | w      |                                          |       |       |              |        |        |        | SC    |
| 0x000A             | R      | CCF15                                    | CCF14 | CCF13 | CCF12        | CCF11  | CCF10  | CCF9   | CCF8  |
| ATDSTAT2           | w      |                                          |       |       |              |        |        |        |       |
| 0x000P             | י<br>ה | 0057                                     | COER  |       |              |        |        |        |       |
| ATDSTAT1           | W      |                                          | CCFO  | CCFD  | 0074         | COFS   | UCF2   | COFT   | CCFU  |
|                    | [      |                                          |       |       |              |        |        |        |       |
| 0x000C<br>ATDDIEN0 | R      | IEN15                                    | IEN14 | IEN13 | IEN12        | IEN11  | IEN10  | IEN9   | IEN8  |
|                    | vv     |                                          |       |       |              |        |        |        |       |
|                    | [      | = Unimplemented or Reserved u = Unaffect |       |       |              |        |        | ed     |       |

Figure 6-2. ATD Register Summary

MC9S12E128 Data Sheet, Rev. 1.07



## 6.3.2.11 ATD Status Register 1 (ATDSTAT1)

This read-only register contains the Conversion Complete Flags CCF7 to CCF0



#### Figure 6-13. ATD Status Register 1 (ATDSTAT1)

### Read: Anytime

Write: Anytime, no effect

#### Table 6-18. ATDSTAT1 Field Descriptions

| Field           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0<br>CCF[7:0] | <ul> <li>Conversion Complete Flag Bits — A conversion complete flag is set at the end of each conversion in a conversion sequence. The flags are associated with the conversion position in a sequence (and also the result register number). Therefore, CCF0 is set when the first conversion in a sequence is complete and the result is available in result register ATDDR0; CCF1 is set when the second conversion in a sequence is complete and the result is available in ATDDR1, and so forth. A CCF flag is cleared when one of the following occurs:</li> <li>Write to ATDCTL5 (a new conversion sequence is started)</li> <li>If AFFC = 0 and read of ATDSTAT1 followed by read of result register ATDDRx</li> <li>If AFFC = 1 and read of result register ATDDRx</li> <li>In case of a concurrent set and clear on CCFx: The clearing by method A) will overwrite the set. The clearing by methods B) or C) will be overwritten by the set.</li> <li>Conversion number x not completed</li> <li>Conversion number x has completed, result ready in ATDDRx</li> </ul> |



Chapter 6 Analog-to-Digital Converter (ATD10B16CV2)

## 6.3.2.15 Port Data Register 1 (PORTAD1)

The data port associated with the ATD is input-only. The port pins are shared with the analog A/D inputs AN7-0.



### Figure 6-17. Port Data Register 1 (PORTAD1)

Read: Anytime

Write: Anytime, no effect

The A/D input channels may be used for general-purpose digital input.

#### Table 6-22. PORTAD1 Field Descriptions

| Field     | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |
|-----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7:0       | <b>A/D Channel x (ANx) Digital Input Bits</b> — If the digital input buffer on the ANx pin is enabled (IENx=1) or channel x is enabled as external trigger (ETRIGE = 1, ETRIGCH[3-0] = x, ETRIGSEL = 0) read returns the logic level on ANx pin (signal potentials not meeting $V_{IL}$ or $V_{IH}$ specifications will have an indeterminate value)). If the digital input buffers are disabled (IENx = 0) and channel x is not enabled as external trigger, read returns a "1". |
| PTAD[7:8] | Reset sets all PORTAD1 bits to "1".                                                                                                                                                                                                                                                                                                                                                                                                                                               |



# 7.4 Functional Description

The DAC8B1C module consists of analog and digital sub-blocks.

## 7.4.1 Functional Description

Data to be converted is written to DACD register. The data can be mapped either to left end or right end of DACD register by clearing or setting DJM bit of DACC0 register. Also, the data written to DACD can be a signed or unsigned data depending on DSGN bit of DACC0 register. See Table 7-3 below for data formats. The maximum unsigned data that can be written to DACD register is \$FF while the minimum value is \$00. If the data is signed, the maximum value that can be written to DACD is \$7F while the minimum value is \$80, where \$7F (signed) corresponds to \$FF (unsigned) and \$80 (signed) corresponds to \$00 (unsigned). Table 7-4 shows this characteristic between signed, unsigned data values and their corresponding voltage output. See Table 7-4 for DAC signed and un-signed data and DAC output codes.

| DJM | DSGN | Description and Bus Bit Mapping           |  |
|-----|------|-------------------------------------------|--|
| 0   | 0    | 8 bit/left justified/unsigned — bits 15–8 |  |
| 0   | 1    | 8 bit/left justified/signed — bits 15–8   |  |
| 1   | 0    | 8 bit/right justified/unsigned — bits 7–0 |  |
| 1   | 1    | 8 bit/right justified/signed bits — 7–0   |  |

| Table | 7-3. | Data | Formats |
|-------|------|------|---------|
|-------|------|------|---------|

#### Table 7-4. Signed and Unsigned Data and DAC Output Codes

| Input signal<br>V <sub>RL</sub> = 0<br>V <sub>REF</sub> /V <sub>RH</sub> = 5.12volts | Signed<br>8-Bit<br>Codes | Unsigned<br>8-Bit<br>Codes |
|--------------------------------------------------------------------------------------|--------------------------|----------------------------|
| 5.12                                                                                 | 7F                       | FF                         |
| 5.08                                                                                 | 7E                       | FE                         |
| 5.07                                                                                 | 7D                       | FD                         |
|                                                                                      |                          |                            |
| 2.580                                                                                | 01                       | 81                         |
| 2.56                                                                                 | 00                       | 80                         |
| 2.54                                                                                 | FF                       | 7F                         |
| 2.52                                                                                 | FE                       | 7E                         |
|                                                                                      |                          |                            |
| 0.020                                                                                | 81                       | 01                         |
| 0.000                                                                                | 80                       | 00                         |



TDRE flag is set and immediately before writing the next byte to the SCI data register.

If the TE bit is clear and the transmission is complete, the SCI is not the master of the TXD pin

## 8.4.5 Receiver



Figure 8-14. SCI Receiver Block Diagram

### 8.4.5.1 Receiver Character Length

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

### 8.4.5.2 Character Reception

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

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



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

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

| Table 0-15. Data Dit Necovery | Table | 8-15. | Data | Bit | Recovery |
|-------------------------------|-------|-------|------|-----|----------|
|-------------------------------|-------|-------|------|-----|----------|

### NOTE

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

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

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

 Table 8-16. Stop Bit Recovery



Access

R/W

R/W<sup>1</sup>

R/W<sup>1</sup>

 $R^2$ 

\_\_\_\_ 2,3

R/W

\_ 2,3

## 9.2.2 MISO — Master In/Slave Out Pin

This pin is used to transmit data out of the SPI module when it is configured as a slave and receive data when it is configured as master.

## 9.2.3 SS — Slave Select Pin

This pin is used to output the select signal from the SPI module to another peripheral with which a data transfer is to take place when its configured as a master and its used as an input to receive the slave select signal when the SPI is configured as slave.

## 9.2.4 SCK — Serial Clock Pin

This pin is used to output the clock with respect to which the SPI transfers data or receive clock in case of slave.

## 9.3 Memory Map and Register Definition

SPI Baud Rate Register (SPIBR)

SPI Status Register (SPISR)

SPI Data Register (SPIDR)

This section provides a detailed description of address space and registers used by the SPI.

The memory map for the SPIV3 is given below in Table 9-1. The address listed for each register is the sum of a base address and an address offset. The base address is defined at the SoC level and the address offset is defined at the module level. Reads from the reserved bits return zeros and writes to the reserved bits have no effect.

## 9.3.1 Module Memory Map

Address

0x0000

0x0001

0x0002 0x0003

0x0004

0x0005

0x0006

0x0007

|                                 | Use |
|---------------------------------|-----|
| SPI Control Register 1 (SPICR1) |     |
| SPI Control Register 2 (SPICR2) |     |

Table 9-1. SPIV3 Memory Map

<sup>1</sup> Certain bits are non-writable.

<sup>2</sup> Writes to this register are ignored.

Reserved

Reserved

Reserved

<sup>3</sup> Reading from this register returns all zeros.



Chapter 11 Pulse Width Modulator with Fault Protection (PMF15B6CV2)

## 11.3.2.29 PMF Deadtime B Register (PMFDTMB)

Module Base + 0x002E



Figure 11-35. PMF Deadtime B Register (PMFDTMB)

Read anytime and write only if MTG is set. This register cannot be modified after the WP bit is set.

| Field           | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                |
|-----------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 11–0<br>PMFDTMB | <ul> <li>PMF Deadtime B — The 12-bit value written to this register is the number of PWM clock cycles in complementary channel operation. A reset sets the PWM deadtime register to a default value of 0x0FFF, selecting a deadtime of 256-PWM clock cycles minus one bus clock cycle.</li> <li>Note: Deadtime is affected by changes to the prescaler value. The deadtime duration is determined as follows: DT = P × PMFDTMB – 1, where DT is deadtime, P is the prescaler value, PMFDTMB is the programmed value of dead time. For example: if the prescaler is programmed for a divide-by-two and the PMFDTMB is set to five, then P = 2 and the deadtime value is equal to DT = 2 × 5 - 1 = 9 IPbus clock cycles. A special case exists when the P = 1, then DT = PMFDTMB.</li> </ul> |

#### Table 11-38. PMFDTMB Field Descriptions



## 12.3.2.15 PWM Shutdown Register (PWMSDN)

The PWMSDN register provides for the shutdown functionality of the PWM module in the emergency cases.



#### Figure 12-33. PWM Shutdown Register (PWMSDN)

Read: anytime

Write: anytime

| Field         | Description                                                                                                                                                                                                                                                                                                                                    |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>PWMIF    | <ul> <li>PWM Interrupt Flag — Any change from passive to asserted (active) state or from active to passive state will be flagged by setting the PWMIF flag = 1. The flag is cleared by writing a logic 1 to it. Writing a 0 has no effect.</li> <li>0 No change on PWM5IN input.</li> <li>1 Change on PWM5IN input</li> </ul>                  |
| 6<br>PWMIE    | <ul> <li>PWM Interrupt Enable — If interrupt is enabled an interrupt to the CPU is asserted.</li> <li>PWM interrupt is disabled.</li> <li>PWM interrupt is enabled.</li> </ul>                                                                                                                                                                 |
| 5<br>PWMRSTRT | <b>PWM Restart</b> — The PWM can only be restarted if the PWM channel input 5 is deasserted. After writing a logic 1 to the PWMRSTRT bit (trigger event) the PWM channels start running after the corresponding counter passes next "counter = 0" phase.                                                                                       |
|               | Also, if the PWM5ENA bit is reset to 0, the PWM do not start before the counter passes 0x0000.                                                                                                                                                                                                                                                 |
|               | The bit is always read as 0.                                                                                                                                                                                                                                                                                                                   |
| 4<br>PWMLVL   | <ul> <li>PWM Shutdown Output Level — If active level as defined by the PWM5IN input, gets asserted all enabled PWM channels are immediately driven to the level defined by PWMLVL.</li> <li>0 PWM outputs are forced to 0</li> <li>1 PWM outputs are forced to 1.</li> </ul>                                                                   |
| 2<br>PWM5IN   | <b>PWM Channel 5 Input Status</b> — This reflects the current status of the PWM5 pin.                                                                                                                                                                                                                                                          |
| 1<br>PWM5INL  | <ul> <li>PWM Shutdown Active Input Level for Channel 5 — If the emergency shutdown feature is enabled (PWM5ENA = 1), this bit determines the active level of the PWM5 channel.</li> <li>0 Active level is low</li> <li>1 Active level is high</li> </ul>                                                                                       |
| 0<br>PWM5ENA  | <ul> <li>PWM Emergency Shutdown Enable — If this bit is logic 1 the pin associated with channel 5 is forced to input and the emergency shutdown feature is enabled. All the other bits in this register are meaningful only if PWM5ENA = 1.</li> <li>0 PWM emergency feature disabled.</li> <li>1 PWM emergency feature is enabled.</li> </ul> |

#### Table 12-10. PWMSDN Field Descriptions



# **12.4 Functional Description**

## 12.4.1 PWM Clock Select

There are four available clocks called clock A, clock B, clock SA (scaled A), and clock SB (scaled B). These four clocks are based on the bus clock.

Clock A and B can be software selected to be 1, 1/2, 1/4, 1/8,..., 1/64, 1/128 times the bus clock. Clock SA uses clock A as an input and divides it further with a reloadable counter. Similarly, clock SB uses clock B as an input and divides it further with a reloadable counter. The rates available for clock SA are software selectable to be clock A divided by 2, 4, 6, 8, ..., or 512 in increments of divide by 2. Similar rates are available for clock SB. Each PWM channel has the capability of selecting one of two clocks, either the pre-scaled clock (clock A or B) or the scaled clock (clock SA or SB).

The block diagram in Figure 12-34 shows the four different clocks and how the scaled clocks are created.

### 12.4.1.1 Prescale

The input clock to the PWM prescaler is the bus clock. It can be disabled whenever the part is in freeze mode by setting the PFRZ bit in the PWMCTL register. If this bit is set, whenever the MCU is in freeze mode the input clock to the prescaler is disabled. This is useful for emulation in order to freeze the PWM. The input clock can also be disabled when all six PWM channels are disabled (PWME5–PWME0 = 0) This is useful for reducing power by disabling the prescale counter.

Clock A and clock B are scaled values of the input clock. The value is software selectable for both clock A and clock B and has options of 1, 1/2, 1/4, 1/8, 1/16, 1/32, 1/64, or 1/128 times the bus clock. The value selected for clock A is determined by the PCKA2, PCKA1, and PCKA0 bits in the PWMPRCLK register. The value selected for clock B is determined by the PCKB2, PCKB1, and PCKB0 bits also in the PWMPRCLK register.



# Chapter 14 Dual Output Voltage Regulator (VREG3V3V2)

# 14.1 Introduction

The VREG3V3V2 is a dual output voltage regulator providing two separate 2.5 V (typical) supplies differing in the amount of current that can be sourced. The regulator input voltage range is from 3.3 V up to 5 V (typical).

## 14.1.1 Features

The block VREG3V3V2 includes these distinctive features:

- Two parallel, linear voltage regulators — Bandgap reference
- Low-voltage detect (LVD) with low-voltage interrupt (LVI)
- Power-on reset (POR)
- Low-voltage reset (LVR)

## 14.1.2 Modes of Operation

There are three modes VREG3V3V2 can operate in:

• Full-performance mode (FPM) (MCU is not in stop mode)

The regulator is active, providing the nominal supply voltage of 2.5 V with full current sourcing capability at both outputs. Features LVD (low-voltage detect), LVR (low-voltage reset), and POR (power-on reset) are available.

• Reduced-power mode (RPM) (MCU is in stop mode)

The purpose is to reduce power consumption of the device. The output voltage may degrade to a lower value than in full-performance mode, additionally the current sourcing capability is substantially reduced. Only the POR is available in this mode, LVD and LVR are disabled.

• Shutdown mode

Controlled by V<sub>REGEN</sub> (see device overview chapter for connectivity of V<sub>REGEN</sub>).

This mode is characterized by minimum power consumption. The regulator outputs are in a high impedance state, only the POR feature is available, LVD and LVR are disabled.

This mode must be used to disable the chip internal regulator VREG3V3V2, i.e., to bypass the VREG3V3V2 to use external supplies.



# 14.2 External Signal Description

Due to the nature of VREG3V3V2 being a voltage regulator providing the chip internal power supply voltages most signals are power supply signals connected to pads.

Table 14-1 shows all signals of VREG3V3V2 associated with pins.

| Name                          | Port | Function                                     | Reset State | Pull Up |
|-------------------------------|------|----------------------------------------------|-------------|---------|
| V <sub>DDR</sub>              |      | VREG3V3V2 power input (positive supply)      | _           | —       |
| V <sub>DDA</sub>              |      | VREG3V3V2 quiet input (positive supply)      | _           | —       |
| V <sub>SSA</sub>              | _    | VREG3V3V2 quiet input (ground)               | _           | —       |
| V <sub>DD</sub>               | —    | VREG3V3V2 primary output (positive supply)   | —           | _       |
| V <sub>SS</sub>               | —    | VREG3V3V2 primary output (ground)            | —           | —       |
| V <sub>DDPLL</sub>            | —    | VREG3V3V2 secondary output (positive supply) | _           | —       |
| V <sub>SSPLL</sub>            | —    | VREG3V3V2 secondary output (ground)          | —           | _       |
| V <sub>REGEN</sub> (optional) | _    | VREG3V3V2 (Optional) Regulator Enable        | _           | _       |

#### Table 14-1. VREG3V3V2 — Signal Properties

### NOTE

Check device overview chapter for connectivity of the signals.

## 14.2.1 V<sub>DDR</sub> — Regulator Power Input

Signal V<sub>DDR</sub> is the power input of VREG3V3V2. All currents sourced into the regulator loads flow through this pin. A chip external decoupling capacitor (100 nF...220 nF, X7R ceramic) between V<sub>DDR</sub> and V<sub>SSR</sub> can smoothen ripple on V<sub>DDR</sub>.

For entering shutdown mode, pin V<sub>DDR</sub> should also be tied to ground on devices without a V<sub>REGEN</sub> pin.

## 14.2.2 V<sub>DDA</sub>, V<sub>SSA</sub> — Regulator Reference Supply

Signals  $V_{DDA}/V_{SSA}$  which are supposed to be relatively quiet are used to supply the analog parts of the regulator. Internal precision reference circuits are supplied from these signals. A chip external decoupling capacitor (100 nF...220 nF, X7R ceramic) between  $V_{DDA}$  and  $V_{SSA}$  can further improve the quality of this supply.



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

The commands are described as follows:

- ACK\_ENABLE enables the hardware handshake protocol. The target will issue the ACK pulse when a CPU command is executed by the CPU. The ACK\_ENABLE command itself also has the ACK pulse as a response.
- ACK\_DISABLE disables the ACK pulse protocol. In this case, the host needs to use the worst case delay time at the appropriate places in the protocol.

The default state of the BDM after reset is hardware handshake protocol disabled.

All the read commands will ACK (if enabled) when the data bus cycle has completed and the data is then ready for reading out by the BKGD serial pin. All the write commands will ACK (if enabled) after the data has been received by the BDM through the BKGD serial pin and when the data bus cycle is complete. See Section 15.4.3, "BDM Hardware Commands," and Section 15.4.4, "Standard BDM Firmware Commands," for more information on the BDM commands.

The ACK\_ENABLE sends an ACK pulse when the command has been completed. This feature could be used by the host to evaluate if the target supports the hardware handshake protocol. If an ACK pulse is issued in response to this command, the host knows that the target supports the hardware handshake protocol. If the target does not support the hardware handshake protocol the ACK pulse is not issued. In this case, the ACK\_ENABLE command is ignored by the target because it is not recognized as a valid command.

The BACKGROUND command will issue an ACK pulse when the CPU changes from normal to background mode. The ACK pulse related to this command could be aborted using the SYNC command.

The GO command will issue an ACK pulse when the CPU exits from background mode. The ACK pulse related to this command could be aborted using the SYNC command.

The GO\_UNTIL command is equivalent to a GO command with exception that the ACK pulse, in this case, is issued when the CPU enters into background mode. This command is an alternative to the GO command and should be used when the host wants to trace if a breakpoint match occurs and causes the CPU to enter active background mode. Note that the ACK is issued whenever the CPU enters BDM, which could be caused by a breakpoint match or by a BGND instruction being executed. The ACK pulse related to this command could be aborted using the SYNC command.

The TRACE1 command has the related ACK pulse issued when the CPU enters background active mode after one instruction of the application program is executed. The ACK pulse related to this command could be aborted using the SYNC command.

The TAGGO command will not issue an ACK pulse because this would interfere with the tagging function shared on the same pin.



Chapter 18 Multiplexed External Bus Interface (MEBIV3)





## Read: Anytime

### Write: Anytime

This port is associated with the internal memory expansion emulation pins. When the port is not enabled to emulate the internal memory expansion, the port pins are used as general-purpose I/O. When port K is operating as a general-purpose I/O port, DDRK determines the primary direction for each port K pin. A 1 causes the associated port pin to be an output and a 0 causes the associated pin to be a high-impedance input. The value in a DDR bit also affects the source of data for reads of the corresponding PORTK register. If the DDR bit is 0 (input) the buffered pin input is read. If the DDR bit is 1 (output) the output of the port data register is read.

This register is not in the map in peripheral or expanded modes while the EMK control bit in MODE register is set. Therefore, these accesses will be echoed externally.

When inputs, these pins can be selected to be high impedance or pulled up, based upon the state of the PUPKE bit in the PUCR register.

| Field                 | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |
|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7<br>Port K, Bit 7    | <b>Port K, Bit 7</b> — This bit is used as an emulation chip select signal for the emulation of the internal memory expansion, or as general-purpose I/O, depending upon the state of the EMK bit in the MODE register. While this bit is used as a chip select, the external bit will return to its de-asserted state $(V_{DD})$ for approximately 1/4 cycle just after the negative edge of ECLK, unless the external access is stretched and ECLK is free-running (ESTR bit in EBICTL = 0). See the MMC block description chapter for additional details on when this signal will be active. |
| 6<br>Port K, Bit 6    | <b>Port K, Bit 6</b> — This bit is used as an external chip select signal for most external accesses that are not selected by $\overline{\text{ECS}}$ (see the MMC block description chapter for more details), depending upon the state the of the EMK bit in the MODE register. While this bit is used as a chip select, the external pin will return to its deasserted state (V <sub>DD</sub> ) for approximately 1/4 cycle just after the negative edge of ECLK, unless the external access is stretched and ECLK is free-running (ESTR bit in EBICTL = 0).                                 |
| 5:0<br>Port K, Bits 5 | Port K, Bits 5:0 — These six bits are used to determine which FLASH/ROM or external memory array page<br>is being accessed. They can be viewed as expanded addresses XAB19–XAB14 of the 20-bit address used to<br>access up to1M byte internal FLASH/ROM or external memory array. Alternatively, these bits can be used for<br>general-purpose I/O depending upon the state of the EMK bit in the MODE register.                                                                                                                                                                               |



## A.1.9 I/O Characteristics

This section describes the characteristics of all 3.3V/5V I/O pins. All parameters are not always applicable, e.g., not all pins feature pull up/down resistances.

| Conditi | ons are | shown in Table A-4 unless otherwise noted                                                              |                                      |                        |     |                        |      |
|---------|---------|--------------------------------------------------------------------------------------------------------|--------------------------------------|------------------------|-----|------------------------|------|
| Num     | С       | Rating                                                                                                 | Symbol                               | Min                    | Тур | Max                    | Unit |
| 1       | Р       | Input High Voltage                                                                                     | V <sub>IH</sub>                      | 0.65*V <sub>DD5</sub>  | —   | _                      | V    |
|         | Т       | Input High Voltage                                                                                     | V <sub>IH</sub>                      | —                      | _   | V <sub>DD5</sub> + 0.3 | V    |
| 2       | Р       | Input Low Voltage                                                                                      | V <sub>IL</sub>                      | —                      |     | 0.35*V <sub>DD5</sub>  | V    |
|         | Т       | Input Low Voltage                                                                                      | V <sub>IL</sub>                      | V <sub>SS5</sub> - 0.3 | _   | _                      | V    |
| 3       | С       | Input Hysteresis                                                                                       | V <sub>HYS</sub>                     | —                      | 250 | —                      | mV   |
| 4       | Р       | Input Leakage Current (pins in high ohmic input mode) <sup>1</sup><br>$V_{in} = V_{DD5}$ or $V_{SS5}$  | l <sub>in</sub>                      | -1.0                   | _   | 1.0                    | μA   |
| 5       | С       | Output High Voltage (pins in output mode)<br>Partial Drive I <sub>OH</sub> = -2mA                      | V <sub>OH</sub>                      | V <sub>DD5</sub> – 0.8 | —   | _                      | V    |
| 6       | Р       | Output High Voltage (pins in output mode)<br>Full Drive IOH = -10mA                                    | V <sub>OH</sub>                      | V <sub>DD5</sub> – 0.8 |     | _                      | V    |
| 7       | С       | Output Low Voltage (pins in output mode)<br>Partial Drive IOL = +2mA                                   | V <sub>OL</sub>                      | _                      | —   | 0.8                    | V    |
| 8       | Р       | Output Low Voltage (pins in output mode)<br>Full Drive I <sub>OL</sub> = +10mA                         | V <sub>OL</sub>                      | —                      | _   | 0.8                    | V    |
| 9       | Р       | Internal Pull Up Device Current, tested at $V_{IL}$ Max.                                               | I <sub>PUL</sub>                     | —                      | —   | -130                   | μA   |
| 10      | С       | Internal Pull Up Device Current, tested at $V_{H}$ Min.                                                | I <sub>PUH</sub>                     | -10                    | —   | —                      | μA   |
| 11      | Р       | Internal Pull Down Device Current, tested at ${\rm V}_{\rm IH}$ Min.                                   | I <sub>PDH</sub>                     | _                      |     | 130                    | μA   |
| 12      | С       | Internal Pull Down Device Current, tested at V <sub>IL</sub><br>Max.                                   | I <sub>PDL</sub>                     | 10                     | _   | _                      | μA   |
| 13      | D       | Input Capacitance                                                                                      | C <sub>in</sub>                      | —                      | 6   | —                      | pF   |
| 14      | Т       | Injection current <sup>2</sup><br>Single Pin limit<br>Total Device Limit. Sum of all injected currents | I <sub>ICS</sub><br>I <sub>ICP</sub> | -2.5<br>-25            | _   | 2.5<br>25              | mA   |
| 15      | Р       | Port AD Interrupt Input Pulse filtered <sup>3</sup>                                                    | t <sub>PIGN</sub>                    | —                      | —   | 3                      | μs   |
| 16      | Р       | Port AD Interrupt Input Pulse passed <sup>3</sup>                                                      | t <sub>PVAL</sub>                    | 10                     | —   | -                      | μs   |

### Table A-6. 5V I/O Characteristics

<sup>1</sup> Maximum leakage current occurs at maximum operating temperature. Current decreases by approximately one-half for each 8 C to 12 C in the temperature range from 50 C to 125 C

<sup>2</sup> Refer to Section A.1.4, "Current Injection" for more details

<sup>3</sup> Parameter only applies in STOP or Pseudo STOP mode.



**Appendix A Electrical Characteristics** 

### A.4.1.4 Mass Erase

Erasing a NVM block takes:

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

The setup times can be ignored for this operation.

### A.4.1.5 Blank Check

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

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

| Conditions are shown in Table A-4 unless otherwise noted |   |                                                   |                     |                     |     |                     |                               |
|----------------------------------------------------------|---|---------------------------------------------------|---------------------|---------------------|-----|---------------------|-------------------------------|
| Num                                                      | С | Rating                                            | Symbol              | Min                 | Тур | Мах                 | Unit                          |
| 1                                                        | D | External Oscillator Clock                         | f <sub>NVMOSC</sub> | 0.5                 | —   | 50 <sup>1</sup>     | MHz                           |
| 2                                                        | D | Bus frequency for Programming or Erase Operations | f <sub>NVMBUS</sub> | 1                   | —   |                     | MHz                           |
| 3                                                        | D | Operating Frequency                               | f <sub>NVMOP</sub>  | 150                 | _   | 200                 | kHz                           |
| 4                                                        | Р | Single Word Programming Time                      | t <sub>swpgm</sub>  | 46 <sup>2</sup>     | _   | 74.5 <sup>3</sup>   | μs                            |
| 5                                                        | D | Flash Burst Programming consecutive word          | t <sub>bwpgm</sub>  | 20.4 <sup>2</sup>   | _   | 31 <sup>3</sup>     | μs                            |
| 6                                                        | D | Flash Burst Programming Time for 64 Word row      | t <sub>brpgm</sub>  | 1331.2 <sup>2</sup> | _   | 2027.5 <sup>3</sup> | μs                            |
| 7                                                        | Р | Sector Erase Time                                 | t <sub>era</sub>    | 20 <sup>4</sup>     | _   | 26.7 <sup>3</sup>   | ms                            |
| 8                                                        | Р | Mass Erase Time                                   | t <sub>mass</sub>   | 100 <sup>4</sup>    | —   | 133 <sup>3</sup>    | ms                            |
| 9                                                        | D | Blank Check Time Flash per block                  | t <sub>check</sub>  | 11 <sup>5</sup>     | _   | 65546 <sup>6</sup>  | <sup>7</sup> t <sub>cyc</sub> |

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

<sup>1</sup> Restrictions for oscillator in crystal mode apply!

<sup>2</sup> Minimum Programming times are achieved under maximum NVM operating frequency f  $_{NVMOP}$  and maximum bus frequency f  $_{bus}$ .

<sup>3</sup> Maximum Erase and Programming times are achieved under particular combinations of f<sub>NVMOP</sub> and bus frequency f bus. Refer to formulae in Sections A.3.1.1 - A.3.1.4 for guidance.

<sup>4</sup> Minimum Erase times are achieved under maximum NVM operating frequency f NVMOP

<sup>5</sup> Minimum time, if first word in the array is not blank

<sup>6</sup> Maximum time to complete check on an erased block

 $^{7}$  Where t<sub>cyc</sub> is the system bus clock period.