

Welcome to E-XFL.COM

#### What is "Embedded - Microcontrollers"?

"Embedded - Microcontrollers" refer to small, integrated circuits designed to perform specific tasks within larger systems. These microcontrollers are essentially compact computers on a single chip, containing a processor core, memory, and programmable input/output peripherals. They are called "embedded" because they are embedded within electronic devices to control various functions, rather than serving as standalone computers. Microcontrollers are crucial in modern electronics, providing the intelligence and control needed for a wide range of applications.

Applications of "<u>Embedded -</u> <u>Microcontrollers</u>"

#### Details

E·XFI

| Product Status             | Not For New Designs                                                  |
|----------------------------|----------------------------------------------------------------------|
| Core Processor             | CPU12                                                                |
| Core Size                  | 16-Bit                                                               |
| Speed                      | 8MHz                                                                 |
| Connectivity               | SCI, SPI                                                             |
| Peripherals                | POR, WDT                                                             |
| Number of I/O              | 83                                                                   |
| Program Memory Size        | 4KB (4K x 8)                                                         |
| Program Memory Type        | EEPROM                                                               |
| EEPROM Size                | -                                                                    |
| RAM Size                   | 1K x 8                                                               |
| Voltage - Supply (Vcc/Vdd) | 4.5V ~ 5.5V                                                          |
| Data Converters            | A/D 8x8b                                                             |
| Oscillator Type            | Internal                                                             |
| Operating Temperature      | -40°C ~ 85°C (TA)                                                    |
| Mounting Type              | Surface Mount                                                        |
| Package / Case             | 112-LQFP                                                             |
| Supplier Device Package    | 112-LQFP (20x20)                                                     |
| Purchase URL               | https://www.e-xfl.com/product-detail/nxp-semiconductors/mc812a4cpve8 |

Email: info@E-XFL.COM

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



# Chapter 18 Electrical Characteristics

| 18.1  | Maximum Ratings                            | 221 |
|-------|--------------------------------------------|-----|
| 18.2  | Functional Operating Range                 | 222 |
| 18.3  | Thermal Characteristics                    | 222 |
| 18.4  | DC Electrical Characteristics              | 223 |
| 18.5  | Supply Current                             | 224 |
| 18.6  | ATD Maximum Ratings                        | 224 |
| 18.7  | ATD DC Electrical Characteristcs           | 225 |
| 18.8  | Analog Converter Operating Characteristics | 225 |
| 18.9  | ATD AC Operating Characteristics           | 226 |
| 18.10 | EEPROM Characteristics.                    | 226 |
| 18.11 | Control Timing                             | 227 |
| 18.12 | Peripheral Port Timing                     | 231 |
| 18.13 | Non-Multiplexed Expansion Bus Timing       | 232 |
| 18.14 | SPI Timing                                 | 234 |

# Chapter 19 Mechanical Specifications

| 19.1 | Introduction       | 237 |
|------|--------------------|-----|
| 19.2 | Package Dimensions | 237 |



#### Register Block

| Addr.        | Register Name                             | _               | Bit 7 | 6           | 5     | 4    | 3          | 2     | 1            | Bit 0 |
|--------------|-------------------------------------------|-----------------|-------|-------------|-------|------|------------|-------|--------------|-------|
| \$0041       | Loop Divider Register Low<br>(LDVL)       | Read:<br>Write: | LDV7  | LDV6        | LDV5  | LDV4 | LDV3       | LDV2  | LDV1         | LDV0  |
|              | See page 113.                             | Reset:          | 1     | 1           | 1     | 1    | 1          | 1     | 1            | 1     |
| \$0042       | Reference Divider<br>Register High (RDVH) | Read:<br>Write: | 0     | 0           | 0     | 0    | RDV11      | RDV10 | RDV9         | RDV8  |
|              | See page 114.                             | Reset:          | 0     | 0           | 0     | 0    | 1          | 1     | 1            | 1     |
| \$0043       | Reference Divider<br>Register Low (RDVL)  | Read:<br>Write: | RDV7  | RDV6        | RDV5  | RDV4 | RDV3       | RDV2  | RDV1         | RDV0  |
|              | See page 114.                             | Reset:          | 1     | 1           | 1     | 1    | 1          | 1     | 1            | 1     |
| \$0044       | Reserved                                  |                 | R     | R           | R     | R    | R          | R     | R            | R     |
| \$0045       | Reserved                                  | [               | R     | R           | R     | R    | R          | R     | R            | R     |
| \$0046       | Reserved                                  |                 | R     | R           | R     | R    | R          | R     | R            | R     |
| \$0047       | Clock Control Register<br>(CLKCTL)        | Read:<br>Write: | LCKF  | PLLON       | PLLS  | BCSC | BCSB       | BCSA  | MCSB         | MCSA  |
|              | See page 114.                             | Reset:          | 0     | 0           | 0     | 0    | 0          | 0     | 0            | 0     |
| \$0048       | Reserved                                  |                 | R     | R           | R     | R    | R          | R     | R            | R     |
| $\downarrow$ | $\downarrow$                              | -               |       |             |       |      |            |       |              |       |
| \$005F       | Reserved                                  |                 | R     | R           | R     | R    | R          | R     | R            | R     |
| \$0060       | ATD Control Register 0<br>(ATDCTL0)       | Read:<br>Write: | 0     | 0           | 0     | 0    | 0          | 0     | 0            | 0     |
|              | See page 199.                             | Reset:          | 0     | 0           | 0     | 0    | 0          | 0     | 0            | 0     |
|              | ATD Control Register 1                    | Read:           | 0     | 0           | 0     | 0    | 0          | 0     | 0            | 0     |
| \$0061       | (ATDCTL1)                                 | Write:          |       |             |       |      |            |       |              |       |
|              | See page 199.                             | Reset:          | 0     | 0           | 0     | 0    | 0          | 0     | 0            | 0     |
| *****        | ATD Control Register 2                    | Read:           | ADPU  | AFFC        | AWAI  | 0    | 0          | 0     | ASCIE        | ASCIF |
| \$0062       | (ATDCTL2)<br>See page 200.                | Write:          |       |             |       |      |            |       |              |       |
|              | 000 page 2001                             | Reset:          | 0     | 0           | 0     | 0    | 0          | 0     | 0            | 0     |
| ¢0060        | ATD Control Register 3                    | Read:           | 0     | 0           | 0     | 0    | 0          | 0     | FRZ1         | FRZ0  |
| φ0003        | See page 201.                             | Reset           | 0     | 0           | 0     | 0    | 0          | 0     | 0            | 0     |
|              |                                           | Read            | 0     | 0           | 0     | 0    | 0          | Ŭ     | , v          | 0     |
| \$0064       | ATD Control Register 4<br>(ATDCTL4)       | Write:          |       | SMP1        | SMP0  | PRS4 | PRS3       | PRS2  | PRS1         | PRS0  |
|              | See page 201.                             | Reset:          | 0     | 0           | 0     | 0    | 0          | 0     | 0            | 1     |
|              | ATD Control Register 5                    | Read:           | 0     |             |       |      |            |       |              | •     |
| \$0065       | (ATDCTL5)                                 | Write:          |       | S8CM        | SCAN  | MULT | CD         | CC    | СВ           | CA    |
|              | See page 202.                             | Reset:          | 0     | 0           | 0     | 0    | 0          | 0     | 0            | 0     |
|              |                                           |                 |       | = Unimpleme | ented | R    | = Reserved |       | U = Unaffect | ed    |

Figure 2-1. Register Map (Sheet 6 of 14)



# Chapter 4 Resets and Interrupts

# 4.1 Introduction

Resets and interrupts are exceptions. Each exception has a 16-bit vector that points to the memory location of the associated exception-handling routine. Vectors are stored in the upper 128 bytes of the standard 64-Kbyte address map.

The six highest vector addresses are used for resets and non-maskable interrupt sources. The remainder of the vectors are used for maskable interrupts, and all must be initialized to point to the address of the appropriate service routine.

# 4.2 Exception Priority

A hardware priority hierarchy determines which reset or interrupt is serviced first when simultaneous requests are made. Six sources are not maskable. The remaining sources are maskable and any one of them can be given priority over other maskable interrupts.

The priorities of the non-maskable sources are:

- 1. POR (power-on reset) or RESET pin
- 2. Clock monitor reset
- 3. COP (computer operating properly) watchdog reset
- 4. Unimplemented instruction trap
- 5. Software interrupt instruction (SWI)
- 6.  $\overline{XIRQ}$  signal (if X bit in CCR = 0)

### 4.3 Maskable Interrupts

Maskable interrupt sources include on-chip peripheral systems and external interrupt service requests. Interrupts from these sources are recognized when the global interrupt mask bit (I) in the CCR is cleared. The default state of the I bit out of reset is 1, but it can be written at any time.

Interrupt sources are prioritized by default but any one maskable interrupt source may be assigned the highest priority by means of the HPRIO register. The relative priorities of the other sources remain the same.

An interrupt that is assigned highest priority is still subject to global masking by the I bit in the CCR or by any associated local bits. Interrupt vectors are not affected by priority assignment. HPRIO can only be written while the I bit is set (interrupts inhibited). Table 4-1 lists interrupt sources and vectors in default order of priority.



commands can be executed while the CPU is operating normally. Other BDM commands are firmware based and require the BDM firmware to be enabled and active for execution.

In special single-chip mode, BDM is enabled and active immediately out of reset. BDM is available in all other operating modes, but must be enabled before it can be activated. BDM should not be used in special peripheral mode because of potential bus conflicts.

Once enabled, background mode can be made active by a serial command sent via the BKGD pin or execution of a CPU12 BGND instruction. While background mode is active, the CPU can interpret special debugging commands, and read and write CPU registers, peripheral registers, and locations in memory.

While BDM is active, the CPU executes code located in a small on-chip ROM mapped to addresses \$FF20 to \$FFFF, and BDM control registers are accessible at addresses \$FF00 to \$FF06. The BDM ROM replaces the regular system vectors while BDM is active. While BDM is active, the user memory from \$FF00 to \$FFFF is not in the map except through serial BDM commands.

# 5.3 Internal Resource Mapping

The internal register block, RAM, and EEPROM have default locations within the 64-Kbyte standard address space but may be reassigned to other locations during program execution by setting bits in mapping registers INITRG, INITRM, and INITEE. During normal operating modes, these registers can be written once. It is advisable to explicitly establish these resource locations during the initialization phase of program execution, even if default values are chosen, to protect the registers from inadvertent modification later.

Writes to the mapping registers go into effect between the cycle that follows the write and the cycle after that. To assure that there are no unintended operations, a write to one of these registers should be followed with a NOP (no operation) instruction.

If conflicts occur when mapping resources, the register block takes precedence over the other resources; RAM or EEPROM addresses occupied by the register block are not available for storage. When active, BDM ROM takes precedence over other resources although a conflict between BDM ROM and register space is not possible. Table 5-2 shows resource mapping precedence.

| Precedence | Resource            |
|------------|---------------------|
| 1          | BDM ROM (if active) |
| 2          | Register space      |
| 3          | RAM                 |
| 4          | EEPROM              |
| 5          | External memory     |

| Table 5-2. | Mapping | Precedence |
|------------|---------|------------|
|------------|---------|------------|

All address space not used by internal resources is external memory by default.

The memory expansion module manages three memory overlay windows:

- 1. Program
- 2. Data
- 3. One extra page overlay

The sizes and locations of the program and data overlay windows are fixed. One of two locations can be selected for the extra page (EPAGE).



# Chapter 7 EEPROM

# 7.1 Introduction

The MC68HC812A4 EEPROM (electrically erasable, programmable, read-only memory) serves as a 4096-byte nonvolatile memory which can be used for frequently accessed static data or as fast access program code. Operating system kernels and standard subroutines would benefit from this feature.

The MC68HC812A4 EEPROM is arranged in a 16-bit configuration. The EEPROM array may be read as either bytes, aligned words, or misaligned words. Access times are one bus cycle for byte and aligned word access and two bus cycles for misaligned word operations.

Programming is by byte or aligned word. Attempts to program or erase misaligned words will fail. Only the lower byte will be latched and programmed or erased. Programming and erasing of the user EEPROM can be done in all modes.

Each EEPROM byte or aligned word must be erased before programming. The EEPROM module supports byte, aligned word, row (32 bytes), or bulk erase, all using the internal charge pump. Bulk erasure of odd and even rows is also possible in test modes; the erased state is \$FF. The EEPROM module has hardware interlocks which protect stored data from corruption by accidentally enabling the program/erase voltage. Programming voltage is derived from the internal V<sub>DD</sub> supply with an internal charge pump. The EEPROM has a minimum program/erase life of 10,000 cycles over the complete operating temperature range.

# 7.2 EEPROM Programmer's Model

The EEPROM module consists of two separately addressable sections. The first is a 4-byte memory mapped control register block used for control, testing and configuration of the EEPROM array. The second section is the EEPROM array itself.

At reset, the 4-byte register section starts at address \$00F0 and the EEPROM array is located from addresses \$1000 to \$1FFF (see Figure 7-1). For information on remapping the register block and EEPROM address space, refer to Chapter 5 Operating Modes and Resource Mapping.

Read/write access to the memory array section can be enabled or disabled by the EEON control bit in the INITEE register. This feature allows the access of memory mapped resources that have lower priority than the EEPROM memory array. EEPROM control registers can be accessed and EEPROM locations may be programmed or erased regardless of the state of EEON.

Using the normal EEPROG control, it is possible to continue program/erase operations during wait. For lowest power consumption during wait, stop program/erase by turning off EEPGM.

If the stop mode is entered during programming or erasing, program/erase voltage is automatically turned off and the RC clock (if enabled) is stopped. However, the EEPGM control bit remains set. When stop mode is terminated, the program/erase voltage automatically turns back on if EEPGM is set.

At low bus frequencies, the RC clock must be turned on for program/erase.

#### **EEPROM Control Registers**



| Byte | Row | Block Size                     |
|------|-----|--------------------------------|
| 0    | 0   | Bulk erase entire EEPROM array |
| 0    | 1   | Row erase 32 bytes             |
| 1    | 0   | Byte or aligned word erase     |
| 1    | 1   | Byte or aligned word erase     |

Table 7-2. Erase Selection

#### ERASE — Erase Control Bit

1 = EEPROM configuration for erasure

0 = EEPROM configuration for programming

Write anytime, if EEPGM = 0

This bit configures the EEPROM for erasure or programming.

#### **EELAT — EEPROM Latch Control Bit**

1 = EEPROM address and data bus latches set up for programming or erasing

0 = EEPROM set up for normal reads

Write: Anytime, if EEPGM = 0

#### NOTE

When EELAT is set, the entire EEPROM is unavailable for reads; therefore, no program residing in the EEPROM can be executed while attempting to program unused EEPROM space. Care should be taken that no references to the EEPROM are used while programming. Interrupts should be turned off if the vectors are in the EEPROM. Timing and any serial communications must be done with polling during the programming process.

BYTE, ROW, ERASE, and EELAT bits can be written simultaneously or in any sequence.

#### **EEPGM** — Program and Erase Enable Bit

1 = Applies program/erase voltage to EEPROM

0 = Disables program/erase voltage to EEPROM

The EEPGM bit can be set only after EELAT has been set. When EELAT and EEPGM are set simultaneously, EEPGM remains clear but EELAT is set.

The BULKP, BYTE, ROW, ERASE, and EELAT bits cannot be changed when EEPGM is set. To complete a program or erase, two successive writes to clear EEPGM and EELAT bits are required before reading the programmed data. A write to an EEPROM location has no effect when EEPGM is set. Latched address and data cannot be modified during program or erase.

A program or erase operation should follow this sequence:

- 1. Write BYTE, ROW, and ERASE to the desired value; write EELAT = 1.
- 2. Write a byte or an aligned word to an EEPROM address.
- 3. Write EEPGM = 1.
- 4. Wait for programming (t<sub>PROG</sub>) or erase (t<sub>Erase</sub>) delay time.
- 5. Write EEPGM = 0.
- 6. Write EELAT = 0.

By jumping from step 5 to step 2, it is possible to program/erase more bytes or words without intermediate EEPROM reads.



The external E-clock may be the stretched E-clock, the E-clock, or no clock depending on the selection of control bits ESTR and IVIS in the MODE register and NECLK in the PEAR register.

# 8.4 Memory Expansion Registers

This section describes the memory expansion registers.

### 8.4.1 Port F Data Register



Figure 8-7. Port F Data Register (PORTF)

#### Read: Anytime Write: Anytime

Seven port F pins are associated with chip-selects. Any pin not used as a chip-select can be used as general-purpose I/O. All pins are pulled up when inputs (if pullups are enabled). Enabling a chip-select overrides the associated data direction bit and port data bit.

### 8.4.2 Port G Data Register



Figure 8-8. Port G Data Register (PORTG)

Read: Anytime Write: Anytime

Six port G pins are associated with memory expansion. Any pin not used for memory expansion can be used as general-purpose I/O. All pins are pulled up when inputs (if pullups are enabled). Enabling a memory expansion address with the memory expansion assignment register overrides the associated data direction bit and port data bit.



**Key Wakeups** 

#### 9.2.2 Port D Data Direction Register



Figure 9-2. Port D Data Direction Register (DDRD)

#### Read: Anytime Write: Anytime

This register is not in the map in wide expanded modes or in special expanded narrow mode with MODE register bit EMD set.

Data direction register D is associated with port D and designates each pin as an input or output.

#### DDRD7–DDRD0 — Data Direction Port D Bits

1 = Associated pin is an output.

0 = Associated pin is an input.

#### 9.2.3 Port D Key Wakeup Interrupt Enable Register



#### Figure 9-3. Port D Key Wakeup Interrupt Enable Register (KWIED)

Read: Anytime Write: Anytime

This register is not in the map in wide expanded modes and in special expanded narrow mode with MODE register bit EMD set.

#### KWIED7–KWIED0 — Key Wakeup Port D Interrupt Enable Bits

1 = Interrupt for the associated bit is enabled.

0 = Interrupt for the associated bit is disabled.

#### **Key Wakeup Registers**



#### 9.2.14 Port J Pullup/Pulldown Select Register



Figure 9-14. Port J Pullup/Pulldown Select Register (PUPSJ)

Read: Anytime Write: Anytime

Each bit in the register corresponds to a port J pin. Each bit selects a pullup or pulldown device for the associated port J pin. The pullup or pulldown is active only if enabled by the PULEJ register.

PUPSJ should be initialized before enabling the pullups/pulldowns (PUPEJ).

#### PUPSJ7–PUPSJ0 — Key Wakeup Port J Pullup/Pulldown Select Bits

- 1 = Pullup is selected for the associated port J pin.
- 0 = Pulldown is selected for the associated port J pin.

#### 9.2.15 Port J Pullup/Pulldown Enable Register

Address: \$002E

|                 | Bit 7  | 6      | 5      | 4      | 3      | 2      | 1      | Bit 0  |
|-----------------|--------|--------|--------|--------|--------|--------|--------|--------|
| Read:<br>Write: | PULEJ7 | PULEJ6 | PULEJ5 | PULEJ4 | PULEJ3 | PULEJ2 | PULEJ1 | PULEJ0 |
| Reset:          | 0      | 0      | 0      | 0      | 0      | 0      | 0      | 0      |

Figure 9-15. Port J Pullup/Pulldown Enable Register (PULEJ)

Read: Anytime Write: Anytime

Each bit in the register corresponds to a port J pin. If a pin is configured as an input, each bit enables an active pullup or pulldown device. PUPSJ selects whether a pullup or a pulldown is the active device.

#### PULEJ7–PULEJ0 — Key Wakeup Port J Pullup/Pulldown Enable Bits

1 = Selected pullup/pulldown device for the associated port J pin is enabled if it is an input.

0 = Associated port J pin has no pullup/pulldown device.



Standard Timer Module

#### 12.4.4.2 Gated Time Accumulation Mode

Setting the PAMOD bit configures the PA for gated time accumulation operation. An active level on the PAI pin enables a divided-by-64 clock to drive the PA. The PA edge bit, PEDGE, selects low levels or high levels to enable the divided-by-64 clock.

The trailing edge of the active level at the PAI pin sets the PA input flag, PAIF. The PA input interrupt enable bit, PAI, enables the PAIF flag to generate interrupt requests.

#### NOTE

The PAI input and timer channel 7 use the same pin. To use the PAI input, disconnect it from the output logic by clearing the channel 7 output mode and output level bits, OM7 and OL7. Also clear the channel 7 output compare mask bit, OC7M7.

The PA counter registers, TIMPACNTH/L reflect the number of pulses from the divided-by-64 clock since the last reset.

# **NOTE** The timer prescaler generates the divided-by-64 clock. If the timer is not active, there is no divided-by-64 clock.



Figure 12-3. Channel 7 Output Compare/Pulse Accumulator Logic



Multiple Serial Interface (MSI)

# 13.3 SPI Features

Serial preipheral interface (SPI) fetures include:

- Full-duplex operation
- Master mode and slave mode
- Programmable slave-select output option
- Programmable bidirectional data pin option
- Interrupt-driven operation with two flags:
  - Transmission complete
  - Mode fault
- Read data buffer
- Serial clock with programmable polarity and phase
- Reduced drive control for lower power consumption
- Programmable open-drain output option

For additional information, refer to Chapter 15 Serial Peripheral Interface (SPI)

# 13.4 MSI Block Diagram



Figure 13-1. Multiple Serial Interface Block Diagram



#### Serial Communications Interface Module (SCI)

register can accept new data from the internal data bus. If the transmit interrupt enable bit, TIE, in SCI control register 2 (SCCR2) is also set, the TDRE flag generates an SCI interrupt request.

When the transmit shift register is not transmitting a frame, the TXD pin goes to the idle condition, logic 1. If at any time software clears the TE bit in SCI control register 2 (SCCR2), the transmitter and receiver relinquish control of the port I/O pins.

If software clears TE while a transmission is in progress (TC = 0), the frame in the transmit shift register continues to shift out. Then the TXD pin reverts to being a general-purpose I/O pin even if there is data pending in the SCI data register. To avoid accidentally cutting off the last frame in a message, always wait for TDRE to go high after the last frame before clearing TE.

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

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

When the SCI relinquishes the TXD pin, the PORTS and DDRS registers control the TXD pin.

To force TXD high when turning off the transmitter, set bit 1 of the port S register (PORTS) and bit 1 of the port S data direction register (DDRS). The TXD pin goes high as soon as the SCI relinquishes it.

#### 14.5.3.3 Break Characters

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

The SCI recognizes a break character when a start bit is followed by eight or nine logic 0 data bits and a logic 0 where the stop bit should be. Receiving a break character has these effects on SCI registers:

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

#### 14.5.3.4 Idle Characters

An idle character contains all logic 1s and has no start, stop, or parity bit. Idle character length depends on the M bit in SCI control register 1 (SCCR1). The preamble is a synchronizing idle character that begins the first transmission initiated after writing the TE bit from 0 to 1.

If the TE bit is cleared during a transmission, the TXD pin becomes idle after completion of the transmission in progress. Clearing and then setting the TE bit during a transmission queues an idle character to be sent after the frame currently being transmitted.



**Functional Description** 

Figure 14-10 shows the effect of noise early in the start bit time. Although this noise does not affect proper synchronization with the start bit time, it does set the noise flag.



Figure 14-11 shows a burst of noise near the beginning of the start bit that resets the RT clock. The sample after the reset is low but is not preceded by three high samples that would qualify as a falling edge. Depending on the timing of the start bit search and on the data, the frame may be missed entirely or it may set the framing error flag.



In Figure 14-12 a noise burst makes the majority of data samples RT8, RT9, and RT10 high. This sets the noise flag but does not reset the RT clock. In start bits only, the RT8, RT9, and RT10 data samples are ignored.







#### 16.7.3 Stop Mode

The ATD is inactive in stop mode for reduced power consumption. The STOP instruction aborts any conversion sequence in progress.

## **16.8 Interrupt Sources**

| Interrupt                    | Flag  | Local  | CCR   | Vector         |
|------------------------------|-------|--------|-------|----------------|
| Source                       |       | Enable | Mask  | Address        |
| Conversion sequence complete | ASCIF | ASCIE  | l bit | \$FFD2, \$FFD3 |

#### Table 16-5. ATD Interrupt Sources

#### NOTE

The ASCIF flag is set only when a conversion sequence is completed and ASCIE = 1 or interrupts on the analog-to-digital converter (ATD) module are enabled.

### **16.9 General-Purpose Ports**

Port AD is an input-only port. When the ATD is enabled, port AD is the analog input port for the ATD. Setting the ATD power-up bit, ADPU, in ATD control register 2 enables the ATD.

Port AD is available for general-purpose input when the ATD is disabled. Clearing the ADPU bit disables the ATD.

# 16.10 Port AD Data Register



#### Figure 16-14. Port AD Data Input Register (PORTAD)

Read: Anytime; reads return logic levels on the PAD pins

Write: Has no meaning or effect

#### PAD7–PAD0 — Port AD Data Input Bits



Analog-to-Digital Converter (ATD)



### 17.4.2 BDM Status Register



Figure 17-6. BDM Status Register (STATUS)

This register can be read or written by BDM commands or firmware.

#### ENBDM — Enable BDM Bit (permit active background debug mode)

- 1 = BDM can be made active to allow firmware commands.
- 0 = BDM cannot be made active (hardware commands still allowed).

#### BDMACT — Background Mode Active Status Bit

- 1 = BDM active and waiting for serial commands
- 0 = BDM not active

#### **ENTAG** — Instruction Tagging Enable Bit

Set by the TAGGO instruction and cleared when BDM is entered.

- 1 = Tagging active (BDM cannot process serial commands while tagging is active.)
- 0 = Tagging not enabled or BDM active

#### SDV — Shifter Data Valid Bit

Shows that valid data is in the serial interface shift register. Used by firmware-based instructions.

- 1 = Valid data
- 0 = No valid data

#### **TRACE** — Asserted by the TRACE1 Instruction

#### 17.4.3 BDM Shift Register



This 16-bit register contains data being received or transmitted via the serial interface.



# Chapter 18 Electrical Characteristics

# **18.1 Maximum Ratings**

Maximum ratings are the extreme limits to which the MCU can be exposed without permanently damaging it.

#### NOTE

This device is not guaranteed to operate properly at the maximum ratings. Refer to 18.4 DC Electrical Characteristics for guaranteed operating conditions.

| Rating                                                          | Symbol                                                  | Value        | Unit |
|-----------------------------------------------------------------|---------------------------------------------------------|--------------|------|
| Supply voltage                                                  | V <sub>DD</sub><br>V <sub>DDA</sub><br>V <sub>DDX</sub> | -0.3 to +6.5 | V    |
| Input voltage                                                   | V <sub>In</sub>                                         | -0.3 to +6.5 | V    |
| Maximum current per pin excluding $\rm V_{DD}$ and $\rm V_{SS}$ | l <sub>in</sub>                                         | ± 25         | mA   |
| Storage temperature                                             | T <sub>STG</sub>                                        | -55 to +150  | °C   |
| V <sub>DD</sub> differential voltage                            | V <sub>DD</sub> -V <sub>DDX</sub>                       | 6.5          | V    |

#### NOTE

This device contains circuitry to protect the inputs against damage due to high static voltages or electric fields; however, it is advised that normal precautions be taken to avoid application of any voltage higher than maximum-rated voltages to this high-impedance circuit. For proper operation, it is recommended that  $V_{In}$  and  $V_{Out}$  be constrained to the range  $V_{SS} \leq (V_{In} \text{ or } V_{Out}) \leq V_{DD}$ . Reliability of operation is enhanced if unused inputs are connected to an appropriate logic voltage level (for example, either  $V_{SS}$  or  $V_{DD}$ ).



**Electrical Characteristics** 

# **18.9 ATD AC Operating Characteristics**

| Characteristic <sup>(1)</sup>                                                                                          | Symbol              | Min         | Max          | Unit |
|------------------------------------------------------------------------------------------------------------------------|---------------------|-------------|--------------|------|
| ATD operating clock frequency                                                                                          | f <sub>ATDCLK</sub> | 0.5         | 2.0          | MHz  |
| Conversion time per channel $0.5 \text{ MHz} \leq f_{\text{ATDCLK}} \leq 2 \text{ MHz}$<br>18 ATD clocks 32 ATD clocks | t <sub>CONV</sub>   | 8.0<br>15.0 | 32.0<br>60.0 | μs   |
| Stop recovery time $V_{DDA} = 5.0 \text{ V}$                                                                           | t <sub>SR</sub>     | _           | 50           | μs   |

1. V\_{DD} = 5.0 Vdc  $\pm$  10%, V\_{SS} = 0 Vdc, T\_A = T\_L to T\_H, ATD clock = 2 MHz, unless otherwise noted

# **18.10 EEPROM Characteristics**

| Characteristic <sup>(1)</sup>                               | Symbol              | Min    | Typical               | Max                   | Unit   |
|-------------------------------------------------------------|---------------------|--------|-----------------------|-----------------------|--------|
| Minimum programming clock frequency <sup>(2)</sup>          | f <sub>PROG</sub>   | 4.0    | —                     | _                     | MHz    |
| Programming time                                            | t <sub>PROG</sub>   | 10.0   | —                     | 10.5                  | ms     |
| Clock recovery time following STOP, to continue programming | t <sub>CRSTOP</sub> | _      | _                     | t <sub>PROG</sub> + 1 | ms     |
| Erase time                                                  | t <sub>Erase</sub>  | 10.0   | —                     | 10.5                  | ms     |
| Write/erase endurance                                       | —                   | 10,000 | 30,000 <sup>(3)</sup> |                       | Cycles |
| Data retention                                              | —                   | 10     | —                     | —                     | Years  |

1.  $V_{DD}$  = 5.0 Vdc ± 10%,  $V_{SS}$  = 0 Vdc,  $T_A$  =  $T_L$  to  $T_H$ , unless otherwise noted 2. RC oscillator must be enabled if programming is desired and  $f_{SYS} < f_{PROG}$ .

3. If average  $T_{H}$  is below 85°C



# 18.11 Control Timing

| Chavasteristia                                                                                                            | Symbol             | 8.0 MHz |      | Unit             |
|---------------------------------------------------------------------------------------------------------------------------|--------------------|---------|------|------------------|
| Characteristic                                                                                                            | Symbol             | Min     | Max  | Unit             |
| Frequency of operation                                                                                                    | f <sub>o</sub>     | dc      | 8.0  | MHz              |
| E-clock period                                                                                                            | t <sub>cyc</sub>   | 125     | —    | ns               |
| Crystal frequency                                                                                                         | f <sub>XTAL</sub>  | —       | 16.0 | MHz              |
| External oscillator frequency                                                                                             | 2 f <sub>o</sub>   | dc      | 16.0 | MHz              |
| Processor control setup time<br>$t_{PCSU} = t_{cyc}/2 + 30$                                                               | t <sub>PCSU</sub>  | 82      | —    | ns               |
| Reset input pulse width<br>To guarantee external reset vector<br>Minimum input time (can be pre-empted by internal reset) | PW <sub>RSTL</sub> | 32<br>2 | _    | t <sub>cyc</sub> |
| Mode programming setup time                                                                                               | t <sub>MPS</sub>   | 4       | —    | t <sub>cyc</sub> |
| Mode programming hold time                                                                                                | t <sub>MPH</sub>   | 10      | —    | ns               |
| Interrupt pulse width, $\overline{IRQ}$ , edge-sensitive mode, KWU $PW_{IRQ}$ = 2 $t_{cyc}$ + 20                          | PW <sub>IRQ</sub>  | 270     | _    | ns               |
| Wait recovery startup time                                                                                                | t <sub>WRS</sub>   | —       | 4    | t <sub>cyc</sub> |
| Timer pulse width, input capture pulse accumulator input $PW_{TIM} = 2 t_{cyc} + 20$                                      | PW <sub>TIM</sub>  | 270     | _    | ns               |



Notes:

Rising edge-sensitive input
Falling edge-sensitive input







VIEW Y

SECTION B-B



| © FREES<br>/                | CALE SEMICONDUCTOR, INC.<br>ALL RIGHTS RESERVED. | MECHANICA                | MECHANICAL OUTLINE PRINT VERSION N |        | NOT TO SCALE |  |
|-----------------------------|--------------------------------------------------|--------------------------|------------------------------------|--------|--------------|--|
| TITLE: 112LD LQFP           |                                                  | DOCUMENT NO: 98ASS23330W |                                    | REV: E |              |  |
| 20 X 20 X 1.4<br>0.65 PITCH |                                                  |                          | CASE NUMBER: 987-02                |        | 25 MAY 2005  |  |
|                             |                                                  |                          | STANDARD: JEDEC MS-026 BFA         |        |              |  |