# E·XFL



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             | Obsolete                                                      |
|----------------------------|---------------------------------------------------------------|
| Core Processor             | eZ8                                                           |
| Core Size                  | 8-Bit                                                         |
| Speed                      | 20MHz                                                         |
| Connectivity               | I <sup>2</sup> C, IrDA, SPI, UART/USART                       |
| Peripherals                | Brown-out Detect/Reset, DMA, POR, PWM, WDT                    |
| Number of I/O              | 46                                                            |
| Program Memory Size        | 16KB (16K x 8)                                                |
| Program Memory Type        | FLASH                                                         |
| EEPROM Size                | -                                                             |
| RAM Size                   | 2K x 8                                                        |
| Voltage - Supply (Vcc/Vdd) | 3V ~ 3.6V                                                     |
| Data Converters            | A/D 12x10b                                                    |
| Oscillator Type            | Internal                                                      |
| Operating Temperature      | -40°C ~ 105°C (TA)                                            |
| Mounting Type              | Surface Mount                                                 |
| Package / Case             | 64-LQFP                                                       |
| Supplier Device Package    | -                                                             |
| Purchase URL               | https://www.e-xfl.com/product-detail/zilog/z8f1602ar020ec00tr |

Email: info@E-XFL.COM

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



| External Pin Reset                                     | ) |
|--------------------------------------------------------|---|
| Stop Mode Recovery                                     | ) |
| Stop Mode Recovery Using Watch-Dog Timer Time-Out 29   | ) |
| Stop Mode Recovery Using a GPIO Port Pin Transition 30 | ) |
| Low-Power Modes                                        | L |
| Overview                                               | l |
| Stop Mode                                              | l |
| Halt Mode                                              | L |
| General-Purpose I/O 33                                 | 3 |
| Overview                                               | 3 |
| GPIO Port Availability By Device                       | 3 |
| Architecture                                           | 1 |
| GPIO Alternate Functions 34                            | ł |
| GPIO Interrupts                                        | 5 |
| GPIO Control Register Definitions                      | 5 |
| Port A-H Address Registers                             | 1 |
| Port A-H Control Registers                             | 3 |
| Port A-H Input Data Registers                          | 2 |
| Port A-H Output Data Register 43                       | 3 |
| Interrupt Controller                                   | l |
| Overview                                               | 1 |
| Interrupt Vector Listing                               | ł |
| Architecture                                           | 5 |
| Operation                                              | 5 |
| Master Interrupt Enable 46                             | 5 |
| Interrupt Vectors and Priority 47                      | 1 |
| Interrupt Assertion Types 47                           | 1 |
| Interrupt Control Register Definitions                 | 3 |
| Interrupt Request 0 Register                           | 3 |
| Interrupt Request 1 Register 49                        | ) |
| Interrupt Request 2 Register 50                        | ) |
| IRQ0 Enable High and Low Bit Registers                 | L |
| IRQ1 Enable High and Low Bit Registers                 | 2 |
| IRQ2 Enable High and Low Bit Registers                 | 3 |
| Interrupt Edge Select Register 54                      | ł |
| Interrupt Port Select Register 55                      | 5 |
| Interrupt Control Register 56                          | 5 |
| Timers                                                 | 1 |
| Overview                                               | 7 |
| Architecture                                           | 1 |
| Operation                                              | 3 |



| Figure 31. | Flash Controller Operation Flow Chart 140                               |
|------------|-------------------------------------------------------------------------|
| Figure 32. | On-Chip Debugger Block Diagram 151                                      |
| Figure 33. | Interfacing the On-Chip Debugger's DBG Pin with an RS-232 Interface (1) |
| Figure 34. | Interfacing the On-Chip Debugger's DBG Pin with an RS-232 Interface (2) |
| Figure 35. | OCD Data Format                                                         |
| Figure 36. | Recommended Crystal Oscillator Configuration<br>(20MHz operation)       |
| Figure 37. | Nominal ICC Versus System Clock Frequency 170                           |
| Figure 38. | Nominal Halt Mode ICC Versus System                                     |
|            | Clock Frequency                                                         |
| Figure 39. | Port Input Sample Timing 176                                            |
| Figure 40. | GPIO Port Output Timing 177                                             |
| Figure 41. | On-Chip Debugger Timing 178                                             |
| Figure 42. | SPI Master Mode Timing 179                                              |
| Figure 43. | SPI Slave Mode Timing 180                                               |
| Figure 44. | $I^2C$ Timing                                                           |
| Figure 45. | Flags Register 201                                                      |
| Figure 46. | Opcode Map Cell Description 202                                         |
| Figure 47. | First Opcode Map 204                                                    |
| Figure 48. | Second Opcode Map after 1FH 205                                         |
| Figure 49. | 40-Lead Plastic Dual-Inline Package (PDIP) 206                          |
| Figure 50. | 44-Lead Low-Profile Quad Flat Package (LQFP) 207                        |
| Figure 51. | 44-Lead Plastic Lead Chip Carrier Package (PLCC) 207                    |
| Figure 52. | 64-Lead Low-Profile Quad Flat Package (LQFP) 208                        |
| Figure 53. | 68-Lead Plastic Lead Chip Carrier Package (PLCC) 209                    |
| Figure 54. | 80-Lead Quad-Flat Package (QFP) 210                                     |



- Software stack allows much greater depth in subroutine calls and interrupts than hardware stacks
- Compatible with existing Z8 code
- Expanded internal Register File allows access of up to 4KB
- New instructions improve execution efficiency for code developed using higher-level programming languages, including C
- Pipelined instruction fetch and execution
- New instructions for improved performance including BIT, BSWAP, BTJ, CPC, LDC, LDCI, LEA, MULT, and SRL
- New instructions support 12-bit linear addressing of the Register File
- Up to 10 MIPS operation
- C-Compiler friendly
- 2-9 clock cycles per instruction

For more information regarding the eZ8 CPU, refer to the *eZ8 CPU User Manual* available for download at <u>www.zilog.com</u>.

#### **General Purpose I/O**

The Z8 Encore!<sup>®</sup> features seven 8-bit ports (Ports A-G) and one 4-bit port (Port H) for general purpose I/O (GPIO). Each pin is individually programmable.

#### Flash Controller

The Flash Controller programs and erases the Flash memory.

#### 10-Bit Analog-to-Digital Converter

The Analog-to-Digital Converter (ADC) converts an analog input signal to a 10-bit binary number. The ADC accepts inputs from up to 12 different analog input sources.

#### UARTs

Each UART is full-duplex and capable of handling asynchronous data transfers. The UARTs support 8- and 9-bit data modes and selectable parity.

## l<sup>2</sup>C

The inter-integrated circuit  $(I^2C^{\circledast})$  controller makes the Z8 Encore!<sup>®</sup> compatible with the  $I^2C$  protocol. The  $I^2C$  controller consists of two bidirectional bus lines, a serial data (SDA) line and a serial clock (SCL) line.



#### Port A-H High Drive Enable Sub-Registers

The Port A-H High Drive Enable sub-register (Table 18) is accessed through the Port A-H Control register by writing 04H to the Port A-H Address register. Setting the bits in the Port A-H High Drive Enable sub-registers to 1 configures the specified port pins for high current output drive operation. The Port A-H High Drive Enable sub-register affects the pins directly and, as a result, alternate functions are also affected.

Table 18. Port A-H High Drive Enable Sub-Registers

| BITS  | 7     | 6            | 5            | 4              | 3             | 2            | 1              | 0     |
|-------|-------|--------------|--------------|----------------|---------------|--------------|----------------|-------|
| FIELD | PHDE7 | PHDE6        | PHDE5        | PHDE4          | PHDE3         | PHDE2        | PHDE1          | PHDE0 |
| RESET | 0     | 0            | 0            | 0              | 0             | 0            | 0              | 0     |
| R/W   | R/W   | R/W          | R/W          | R/W            | R/W           | R/W          | R/W            | R/W   |
| ADDR  |       | If 04H in Po | rt A-H Addre | ss Register, a | ccessible via | Port A-H Cor | ntrol Register |       |

PHDE[7:0]—Port High Drive Enabled

0 = The Port pin is configured for standard output current drive.

1 = The Port pin is configured for high output current drive.

### Port A-H Stop Mode Recovery Source Enable Sub-Registers

The Port A-H STOP Mode Recovery Source Enable sub-register (Table 19) is accessed through the Port A-H Control register by writing 05H to the Port A-H Address register. Setting the bits in the Port A-H STOP Mode Recovery Source Enable sub-registers to 1 configures the specified Port pins as a STOP Mode Recovery source. During STOP Mode, any logic transition on a Port pin enabled as a STOP Mode Recovery source initiates STOP Mode Recovery.



Interrupt Port Select register selects between Port A and Port D for the individual interrupts.

| BITS  | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |
|-------|------|------|------|------|------|------|------|------|
| FIELD | IES7 | IES6 | IES5 | IES4 | IES3 | IES2 | IES1 | IES0 |
| RESET | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |
| R/W   | R/W  | R/W  | R/W  | R/W  | R/W  | R/W  | R/W  | R/W  |
| ADDR  |      |      |      | FC   | DH   |      |      |      |

Table 35. Interrupt Edge Select Register (IRQES)

IES*x*—Interrupt Edge Select *x* 

where *x* indicates the specific GPIO Port pin number (0 through 7). The pulse width should be greater than 1 system clock to guarantee capture of the edge triggered interrupt. 0 = An interrupt request is generated on the falling edge of the PA*x*/PD*x* input. 1 = An interrupt request is generated on the rising edge of the PA*x*/PD*x* input.

# **Interrupt Port Select Register**

The Port Select (IRQPS) register (Table 36) determines the port pin that generates the PAx/PDx interrupts. This register allows either Port A or Port D pins to be used as interrupts. The Interrupt Edge Select register controls the active interrupt edge.

| BITS  | 7     | 6     | 5     | 4     | 3     | 2     | 1     | 0     |
|-------|-------|-------|-------|-------|-------|-------|-------|-------|
| FIELD | PAD7S | PAD6S | PAD5S | PAD4S | PAD3S | PAD2S | PAD1S | PAD0S |
| RESET | 0     | 0     | 0     | 0     | 0     | 0     | 0     | 0     |
| R/W   |
| ADDR  |       |       |       | FC    | EH    |       |       |       |

Table 36. Interrupt Port Select Register (IRQPS)

PADxS—PAx/PDx Selection

0 = PAx is used for the interrupt for PAx/PDx interrupt request.

1 = PDx is used for the interrupt for PAx/PDx interrupt request.

where *x* indicates the specific GPIO Port pin number (0 through 7).



mode. Refer to the **Reset and Stop Mode Recovery** chapter for more information on STOP Mode Recovery.

If interrupts are enabled, following completion of the Stop Mode Recovery the eZ8 CPU responds to the interrupt request by fetching the Watch-Dog Timer interrupt vector and executing code from the vector address.

#### WDT Reset in Normal Operation

If configured to generate a Reset when a time-out occurs, the Watch-Dog Timer forces the Z8F640x family device into the Short Reset state. The WDT status bit in the Watch-Dog Timer Control register is set to 1. Refer to the **Reset and Stop Mode Recovery** chapter for more information on Short Reset.

#### WDT Reset in Stop Mode

If configured to generate a Reset when a time-out occurs and the Z8F640x family device is in STOP mode, the Watch-Dog Timer initiates a Stop Mode Recovery. Both the WDT status bit and the STOP bit in the Watch-Dog Timer Control register are set to 1 following WDT time-out in STOP mode. Refer to the **Reset and Stop Mode Recovery** chapter for more information.

#### Watch-Dog Timer Reload Unlock Sequence

Writing the unlock sequence to the Watch-Dog Timer Control register (WDTCTL) unlocks the three Watch-Dog Timer Reload Byte registers (WDTU, WDTH, and WDTL) to allow changes to the time-out period. These write operations to the WDTCTL register address produce no effect on the bits in the WDTCTL register. The locking mechanism prevents spurious writes to the Reload registers. The follow sequence is required to unlock the Watch-Dog Timer Reload Byte registers (WDTU, WDTH, and WDTL) for write access.

- 1. Write 55H to the Watch-Dog Timer Control register (WDTCTL)
- 2. Write AAH to the Watch-Dog Timer Control register (WDTCTL)
- 3. Write the Watch-Dog Timer Reload Upper Byte register (WDTU)
- 4. Write the Watch-Dog Timer Reload High Byte register (WDTH)
- 5. Write the Watch-Dog Timer Reload Low Byte register (WDTL)

All three Watch-Dog Timer Reload registers must be written in the order just listed. There must be no other register writes between each of these operations. If a register write occurs, the lock state machine resets and no further writes can occur, unless the sequence is restarted. The value in the Watch-Dog Timer Reload registers is loaded into the counter when the Watch-Dog Timer is first enabled and every time a WDT instruction is executed.



# **UART**

# **Overview**

The Universal Asynchronous Receiver/Transmitter (UART) is a full-duplex communication channel capable of handling asynchronous data transfers. The Z8F640x family device contains two fully independent UARTs. The UART uses a single 8-bit data mode with selectable parity. Features of the UART include:

- 8-bit asynchronous data transfer
- Selectable even- and odd-parity generation and checking
- Option of one or two Stop bits
- Separate transmit and receive interrupts
- Framing, parity, overrun and break detection
- Separate transmit and receive enables
- Selectable 9-bit multiprocessor (9-bit) mode
- 16-bit Baud Rate Generator (BRG)

# Architecture

The UART consists of three primary functional blocks: transmitter, receiver, and baud rate generator. The UART's transmitter and receiver function independently, but employ the same baud rate and data format. Figure 67 illustrates the UART architecture.



3. Enable the Baud Rate Generator timer function and associated interrupt by setting the BIRQ bit in the UART*x* Control 1 register to 1.

# **UART Control Register Definitions**

The UART control registers support both the UARTs and the associated Infrared Encoder/ Decoders. For more information on the infrared operation, refer to the **Infrared Encoder/ Decoder** chapter on page 95.

## UARTx Transmit Data Register

Data bytes written to the UART*x* Transmit Data register (Table 50) are shifted out on the TXD*x* pin. The Write-only UART*x* Transmit Data register shares a Register File address with the Read-only UART*x* Receive Data register.

| BITS  | 7   | 6 | 5 | 4       | 3       | 2 | 1 | 0 |
|-------|-----|---|---|---------|---------|---|---|---|
| FIELD | TXD |   |   |         |         |   |   |   |
| RESET | Х   | Х | Х | Х       | Х       | Х | Х | Х |
| R/W   | W   | W | W | W       | W       | W | W | W |
| ADDR  |     |   |   | F40H ar | nd F48H |   |   |   |

Table 50. UARTx Transmit Data Register (UxTXD)

TXD—Transmit Data

UART transmitter data byte to be shifted out through the TXD*x* pin.



- 7. The I<sup>2</sup>C Controller loads the I<sup>2</sup>C Shift register with the contents of the I<sup>2</sup>C Data register.
- 8. After one bit of address is shifted out by the SDA signal, the Transmit interrupt is asserted.
- Software responds by writing the second byte of address into the contents of the I<sup>2</sup>C Data register.
- 10. The I<sup>2</sup>C Controller shifts the rest of the first byte of address and write bit out by the SDA signal.
- 11. The I<sup>2</sup>C slave sends an acknowledge by pulling the SDA signal low during the next high period of SCL. The I<sup>2</sup>C Controller sets the ACK bit in the I<sup>2</sup>C Status register.
- 12. The I<sup>2</sup>C Controller loads the contents of the I<sup>2</sup>C Shift register with the contents of the I<sup>2</sup>C Data register.
- 13. The I<sup>2</sup>C Controller shifts the data out by the SDA signal. After the first bit has been sent, the Transmit interrupt is asserted.
- 14. Software responds by writing the data to be written out to the I<sup>2</sup>C Control register.
- 15. The I<sup>2</sup>C Controller shifts out the rest of the second byte of slave address by the SDA signal.
- 16. The I<sup>2</sup>C slave sends an acknowledge by pulling the SDA signal low during the next high period of SCL. The I<sup>2</sup>C Controller sets the ACK bit in the I<sup>2</sup>C Status register.
- 17. The I<sup>2</sup>C Controller shifts the data out by the SDA signal. After the first bit is sent, the Transmit interrupt is asserted.
- 18. Software responds by asserting the STOP bit of the  $I^2C$  Control register.
- 19. The I<sup>2</sup>C Controller completes transmission of the data on the SDA signal.
- 20. The I<sup>2</sup>C Controller sends the STOP condition to the I<sup>2</sup>C bus.

#### Reading a Transaction with a 7-Bit Address

Figure 81 illustrates the data transfer format for a receive operation on a 7-bit addressed slave. The shaded regions indicate data transferred from the  $I^2C$  Controller to slaves and unshaded regions indicate data transferred from the slaves to the  $I^2C$  Controller.

| S | Slave Address | R=1 | А | Data | А | Data | Ā | Р |
|---|---------------|-----|---|------|---|------|---|---|
|---|---------------|-----|---|------|---|------|---|---|

#### Figure 81. Receive Data Transfer Format for a 7-Bit Addressed Slave

The data transfer format for a receive operation on a 7-bit addressed slave is as follows:



1 = DMAx is enabled and initiates a data transfer upon receipt of a request from the trigger source.

#### DLE—DMAx Loop Enable

0 = DMAx reloads the original Start Address and is then disabled after the End Address data is transferred.

1 = DMAx, after the End Address data is transferred, reloads the original Start Address and continues operating.

DDIR—DMAx Data Transfer Direction

0 =Register File  $\rightarrow$  on-chip peripheral control register.

1 = on-chip peripheral control register  $\rightarrow$  Register File.

IRQEN—DMAx Interrupt Enable

0 = DMAx does not generate any interrupts.

1 = DMAx generates an interrupt when the End Address data is transferred.

WSEL-Word Select

0 = DMAx transfers a single byte per request.

1 = DMAx transfers a two-byte word per request. The address for the on-chip peripheral control register must be an even address.

#### RSS-Request Trigger Source Select

The Request Trigger Source Select field determines the peripheral that can initiate a DMA request transfer. The corresponding interrupts do not need to be enabled within the Interrupt Controller to initiate a DMA transfer. However, if the Request Trigger Source can enable or disable the interrupt request sent to the Interrupt Controller, the interrupt request must be enabled within the Request Trigger Source block.

- 000 = Timer 0.
- 001 = Timer 1.
- 010 = Timer 2.
- 011 = Timer 3.

100 = DMA0 Control register: UART0 Received Data register contains valid data. DMA1 Control register: UART0 Transmit Data register empty.

101 = DMA0 Control register: UART1 Received Data register contains valid data. DMA1 Control register: UART1 Transmit Data register empty.

110 = DMA0 Control register: I<sup>2</sup>C Receiver Interrupt. DMA1 Control register: I<sup>2</sup>C Transmitter Interrupt register empty.

111 = Reserved.

## DMAx I/O Address Register

The DMAx I/O Address register contains the low byte of the on-chip peripheral address for data transfer. The full 12-bit Register File address is given by {FH, DMAx\_IO[7:0]}.



- 1. Enable the desired analog inputs by configuring the general-purpose I/O pins for alternate function. This configuration disables the digital input and output drivers.
- 2. Write to the ADC Control register to configure the ADC and begin the conversion. The bit fields in the ADC Control register can be written simultaneously:
  - Write to ANAIN [3:0] to select one of the 12 analog input sources.
  - Clear CONT to 0 to select a single-shot conversion.
  - Write to VREF to enable or disable the internal voltage reference generator.
  - Set CEN to 1 to start the conversion.
- 3. CEN remains 1 while the conversion is in progress. A single-shot conversion requires 5129 system clock cycles to complete. If a single-shot conversion is requested from an ADC powered-down state, the ADC uses 40 additional clock cycles to power-up before beginning the 5129 cycle conversion.
- 4. When the conversion is complete, the ADC control logic performs the following operations:
  - 10-bit data result written to {ADCD\_H[7:0], ADCD\_L[7:6]}.
  - CEN resets to 0 to indicate the conversion is complete.
  - An interrupt request is sent to the Interrupt Controller.
- 5. If the ADC remains idle for 160 consecutive system clock cycles, it is automatically powered-down.

### **Continuous Conversion**

When configured for continuous conversion, the ADC continuously performs an analogto-digital conversion on the selected analog input. Each new data value over-writes the previous value stored in the ADC Data registers. An interrupt is generated only at the end of the first conversion after enabling.

# Caution:

In Continuous mode, users must be aware that ADC updates are limited by the input signal bandwidth of the ADC and the latency of the ADC and its digital filter. Step changes at the input are not seen at the next output from the ADC. The response of the ADC (in all modes) is limited by the input signal bandwidth and the latency.

The steps for setting up the ADC and initiating continuous conversion are as follows:

- 1. Enable the desired analog input by configuring the general-purpose I/O pins for alternate function. This disables the digital input and output driver.
- 2. Write to the ADC Control register to configure the ADC for continuous conversion. The bit fields in the ADC Control register may be written simultaneously:
  - Write to ANAIN [3:0] to select one of the 12 analog input sources.



## **Flash Status Register**

The Flash Status register indicates the current state of the Flash Controller. This register can be read at any time. The Read-only Flash Status Register shares its Register File address with the Write-only Flash Control Register.

| Table | 86. | Flash | Status | Register | (FSTAT) |
|-------|-----|-------|--------|----------|---------|
|-------|-----|-------|--------|----------|---------|

| BITS  | 7    | 6     | 5     | 4           | 3 | 2 | 1 | 0 |  |
|-------|------|-------|-------|-------------|---|---|---|---|--|
| FIELD | Rese | erved | FSTAT |             |   |   |   |   |  |
| RESET | 0    | 0     | 0     | 0           | 0 | 0 | 0 | 0 |  |
| R/W   | R    | R     | R     | R R R R R R |   |   |   |   |  |
| ADDR  |      | FF8H  |       |             |   |   |   |   |  |

Reserved

These bits are reserved and must be 0.

FSTAT—Flash Controller Status

000000 = Flash Controller locked.

000001 = First unlock command received.

000010 = Flash Controller unlocked (second unlock command received).

001xxx = Program operation in progress.

010xxx = Page erase operation in progress.

100xxx = Mass erase operation in progress.



#### FHSWP—Flash High Sector Write Protect FWP—Flash Write Protect These two Option Bits combine to provide 3 levels of Program Memory protection:

| FHSWP  | FWP | Description                                                                                                                                                                                                                                                                                                                                                                                                                    |
|--------|-----|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 0      | 0   | Programming and erasure disabled for all of Program Memory.<br>Programming, Page Erase, and Mass Erase via User Code is disabled. Mass<br>Erase is available through the On-Chip Debugger.                                                                                                                                                                                                                                     |
| 1      | 0   | Programming and Page Erase are enabled for the High Sector of the<br>Program Memory only. The High Sector on the Z8F640x family device<br>contains 1KB to 4KB of Flash with addresses at the top of the available<br>Flash memory. Programming and Page Erase are disabled for the other<br>portions of the Program Memory. Mass erase through user code is disabled.<br>Mass Erase is available through the On-Chip Debugger. |
| 0 or 1 | 1   | Programming, Page Erase, and Mass Erase are enabled for all of Program Memory.                                                                                                                                                                                                                                                                                                                                                 |

# Program Memory Address 0001H

#### Table 91. Options Bits at Program Memory Address 0001H

| BITS      | 7                    | 6            | 5            | 4   | 3   | 2   | 1   | 0   |
|-----------|----------------------|--------------|--------------|-----|-----|-----|-----|-----|
| FIELD     | Reserved             |              |              |     |     |     |     |     |
| RESET     | U                    | U            | U            | U   | U   | U   | U   | U   |
| R/W       | R/W                  | R/W          | R/W          | R/W | R/W | R/W | R/W | R/W |
| ADDR      | Program Memory 0001H |              |              |     |     |     |     |     |
| Note: U = | Unchanged by         | y Reset. R/W | = Read/Write | e.  |     |     |     |     |

Reserved

These Option Bits are reserved for future use and must always be 1. This setting is the default for unprogrammed (erased) Flash.



- Power-on reset
- Voltage Brownout reset
- Asserting the  $\overline{\text{RESET}}$  pin Low to initiate a Reset.
- Driving the DBG pin Low while the Z8F640x family device is in Stop mode initiates a System Reset.

## **OCD Data Format**

The OCD interface uses the asynchronous data format defined for RS-232. Each character is transmitted as 1 Start bit, 8 data bits (least-significant bit first), and 1.5 Stop bits (Figure 89)

| START | D0 | D1 | D2 | D3 | D4 | D5 | D6 | D7 | STOP |
|-------|----|----|----|----|----|----|----|----|------|
|-------|----|----|----|----|----|----|----|----|------|

#### Figure 89. OCD Data Format

## **OCD Auto-Baud Detector/Generator**

To run over a range of baud rates (data bits per second) with various system clock frequencies, the On-Chip Debugger has an Auto-Baud Detector/Generator. After a reset, the OCD is idle until it receives data. The OCD requires that the first character sent from the host is the character 80H. The character 80H has eight continuous bits Low (one Start bit plus 7 data bits). The Auto-Baud Detector measures this period and sets the OCD Baud Rate Generator accordingly.

The Auto-Baud Detector/Generator is clocked by the Z8F640x family device system clock. The minimum baud rate is the system clock frequency divided by 512. For optimal operation, the maximum recommended baud rate is the system clock frequency divided by 8. The theoretical maximum baud rate is the system clock frequency divided by 4. This theoretical maximum is possible for low noise designs with clean signals. Table 92 lists minimum and recommended maximum baud rates for sample crystal frequencies.

| System Clock Frequency<br>(MHz) | Recommended Maximum Baud Rate<br>(kbits/s) | Minimum Baud Rate<br>(kbits/s) |
|---------------------------------|--------------------------------------------|--------------------------------|
| 20.0                            | 2500                                       | 39.1                           |
| 1.0                             | 125.0                                      | 1.96                           |
| 0.032768 (32KHz)                | 4.096                                      | 0.064                          |

#### Table 92. OCD Baud-Rate Limits



If the OCD receives a Serial Break (nine or more continuous bits Low) the Auto-Baud Detector/Generator resets. The Auto-Baud Detector/Generator can then be reconfigured by sending 80H.

# **OCD Serial Errors**

The On-Chip Debugger can detect any of the following error conditions on the DBG pin:

- Serial Break (a minimum of nine continuous bits Low)
- Framing Error (received Stop bit is Low)
- Transmit Collision (OCD and host simultaneous transmission detected by the OCD)

When the OCD detects one of these errors, it aborts any command currently in progress, transmits a four character long Serial Break back to the host, and resets the Auto-Baud Detector/Generator. A Framing Error or Transmit Collision may be caused by the host sending a Serial Break to the OCD. Because of the open-drain nature of the interface, returning a Serial Break break back to the host only extends the length of the Serial Break if the host releases the Serial Break early.

The host should transmit a Serial Break on the DBG pin when first connecting to the Z8F640x family device or when recovering from an error. A Serial Break from the host resets the Auto-Baud Generator/Detector but does not reset the OCD Control register. A Serial Break leaves the Z8F640x family device in Debug mode if that is the current mode. The OCD is held in Reset until the end of the Serial Break when the DBG pin returns High. Because of the open-drain nature of the DBG pin, the host can send a Serial Break to the OCD even if the OCD is transmitting a character.

### **Breakpoints**

Execution Breakpoints are generated using the BRK instruction (opcode 00H). When the eZ8 CPU decodes a BRK instruction, it signals the On-Chip Debugger. If Breakpoints are enabled, the OCD enters Debug mode and idles the eZ8 CPU. If Breakpoints are not enabled, the OCD ignores the BRK signal and the BRK instruction operates as an NOP.

### **Breakpoints in Flash Memory**

The BRK instruction is opcode 00H, which corresponds to the fully programmed state of a byte in Flash memory. To implement a Breakpoint, write 00H to the desired address, overwriting the current instruction. To remove a Breakpoint, the corresponding page of Flash memory must be erased and reprogrammed with the original data.

### Watchpoints

The On-Chip Debugger can set one Watchpoint to cause a Debug Break. The Watchpoint identifies a single Register File address. The Watchpoint can be set to break on reads and/ or writes of the selected Register File address. Additionally, the Watchpoint can be configured to break only when a specific data value is read and/or written from the specified reg-



zero). If the Z8F640x family device is not in Debug mode or if the Read Protect Option Bit is enabled, this command returns FFH for all the data values.

```
DEG <-- 09H
DEG <-- {4'h0,Register Address[11:8]
DEG <-- Register Address[7:0]
DEG <-- Size[7:0]
DEG --> 1-256 data bytes
```

• Write Program Memory (0AH)—The Write Program Memory command writes data to Program Memory. This command is equivalent to the LDC and LDCI instructions. Data can be written 1-65536 bytes at a time (65536 bytes can be written by setting size to zero). The on-chip Flash Controller must be written to and unlocked for the programming operation to occur. If the Flash Controller is not unlocked, the data is discarded. If the Z8F640x family device is not in Debug mode or if the Read Protect Option Bit is enabled, the data is discarded.

```
DBG <-- 0AH

DBG <-- Program Memory Address[15:8]

DBG <-- Program Memory Address[7:0]

DBG <-- Size[15:8]

DBG <-- Size[7:0]

DBG <-- 1-65536 data bytes
```

• **Read Program Memory (0BH)**—The Read Program Memory command reads data from Program Memory. This command is equivalent to the LDC and LDCI instructions. Data can be read 1-65536 bytes at a time (65536 bytes can be read by setting size to zero). If the Z8F640x family device is not in Debug mode or if the Read Protect Option Bit is enabled, this command returns FFH for the data.

```
DEG <-- 0BH
DEG <-- Program Memory Address[15:8]
DEG <-- Program Memory Address[7:0]
DEG <-- Size[15:8]
DEG <-- Size[7:0]
DEG --> 1-65536 data bytes
```

• Write Data Memory (0CH)—The Write Data Memory command writes data to Data Memory. This command is equivalent to the LDE and LDEI instructions. Data can be written 1-65536 bytes at a time (65536 bytes can be written by setting size to zero). If the Z8F640x family device is not in Debug mode or if the Read Protect Option Bit is enabled, the data is discarded.

```
DBG <-- 0CH
DBG <-- Data Memory Address[15:8]
DBG <-- Data Memory Address[7:0]
DBG <-- Size[15:8]
DBG <-- Size[7:0]
DBG <-- 1-65536 data bytes
```



170

#### Table 101. DC Characteristics

|                  |                                | $T_{\rm A} = -40^{0} {\rm C} \text{ to } 105^{0} {\rm C}$ |         |         |       |                       |
|------------------|--------------------------------|-----------------------------------------------------------|---------|---------|-------|-----------------------|
| Symbol           | Parameter                      | Minimum                                                   | Typical | Maximum | Units | Conditions            |
| I <sub>PU</sub>  | Weak Pull-up Current           | 30                                                        | 100     | 350     | μA    | $V_{DD} = 3.0 - 3.6V$ |
| I <sub>CCS</sub> | Supply Current in Stop<br>Mode |                                                           | 600     |         | μA    | $V_{DD} = 3.3 V$      |

<sup>1</sup> This condition excludes all pins that have on-chip pull-ups, when driven Low.

<sup>2</sup> These values are provided for design guidance only and are not tested in production.

Figure 91 illustrates the typical current consumption while operating at 25°C, 3.3V, versus the system clock frequency.



Figure 91. Nominal ICC Versus System Clock Frequency



199

| Accombly        |                                                                                                                        | Addre       | ss Mode      | <b>Oncode</b> (s) |   |            | Fl         | ags           |   |   | Fotch  | Inctr  |
|-----------------|------------------------------------------------------------------------------------------------------------------------|-------------|--------------|-------------------|---|------------|------------|---------------|---|---|--------|--------|
| Mnemonic        | Symbolic Operation                                                                                                     | dst         | src          | (Hex)             | С | Z          | S          | V             | D | Н | Cycles | Cycles |
| TCM dst, src    | (NOT dst) AND src                                                                                                      | r           | r            | 62                | - | *          | *          | 0             | - | - | 2      | 3      |
|                 |                                                                                                                        | r           | Ir           | 63                | - |            |            |               |   |   | 2      | 4      |
|                 |                                                                                                                        | R           | R            | 64                | - |            |            |               |   |   | 3      | 3      |
|                 |                                                                                                                        | R           | IR           | 65                | - |            |            |               |   |   | 3      | 4      |
|                 |                                                                                                                        | R           | IM           | 66                | - |            |            |               |   |   | 3      | 3      |
|                 |                                                                                                                        | IR          | IM           | 67                | - |            |            |               |   |   | 3      | 4      |
| TCMX dst, src   | (NOT dst) AND src                                                                                                      | ER          | ER           | 68                | - | *          | *          | 0             | - | - | 4      | 3      |
|                 |                                                                                                                        | ER          | IM           | 69                |   |            |            |               |   |   | 4      | 3      |
| TM dst, src     | dst AND src                                                                                                            | r           | r            | 72                | - | *          | *          | 0             | - | - | 2      | 3      |
|                 |                                                                                                                        | r           | Ir           | 73                | _ |            |            |               |   |   | 2      | 4      |
|                 |                                                                                                                        | R           | R            | 74                | _ |            |            |               |   |   | 3      | 3      |
|                 |                                                                                                                        | R           | IR           | 75                | _ |            |            |               |   |   | 3      | 4      |
|                 |                                                                                                                        | R           | IM           | 76                | _ |            |            |               |   |   | 3      | 3      |
|                 |                                                                                                                        | IR          | IM           | 77                |   |            |            |               |   |   | 3      | 4      |
| TMX dst, src    | dst AND src                                                                                                            | ER          | ER           | 78                | - | *          | *          | 0             | - | - | 4      | 3      |
|                 |                                                                                                                        | ER          | IM           | 79                |   |            |            |               |   |   | 4      | 3      |
| TRAP Vector     | $SP \leftarrow SP - 2$<br>@SP \leftarrow PC<br>$SP \leftarrow SP - 1$<br>@SP \leftarrow FLAGS<br>PC \leftarrow @Vector |             | Vector       | F2                | - | -          | -          | -             | - | - | 2      | 6      |
| WDT             |                                                                                                                        |             |              | 5F                | - | -          | -          | -             | - | - | 1      | 2      |
| Flags Notation: | * = Value is a function of<br>- = Unaffected<br>X = Undefined                                                          | of the resu | ilt of the o | operation.        |   | 0 =<br>1 = | Res<br>Set | et to<br>to 1 | 0 |   |        |        |

## Table 126. eZ8 CPU Instruction Summary (Continued)

# Z8F640x/Z8F480x/Z8F320x/Z8F240x/Z8F160x Z8 Encore!®



205



Figure 102. Second Opcode Map after 1FH



## **Precharacterization Product**

The product represented by this document is newly introduced and ZiLOG has not completed the full characterization of the product. The document states what ZiLOG knows about this product at this time, but additional features or nonconformance with some aspects of the document might be found, either by ZiLOG or its customers in the course of further application and characterization work. In addition, ZiLOG cautions that delivery might be uncertain at times, due to start-up yield issues.

ZiLOG, Inc. 532 Race Street San Jose, CA 95126 Telephone (408) 558-8500 FAX 408 558-8300 Internet: www.zilog.com

# Document Information

## **Document Number Description**

The Document Control Number that appears in the footer on each page of this document contains unique identifying attributes, as indicated in the following table:

| PS   | Product Specification    |
|------|--------------------------|
| 0176 | Unique Document Number   |
| 01   | Revision Number          |
| 0702 | Month and Year Published |