



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

| 20000                      |                                                              |
|----------------------------|--------------------------------------------------------------|
| Product Status             | Obsolete                                                     |
| Core Processor             | eZ8                                                          |
| Core Size                  | 8-Bit                                                        |
| Speed                      | 20MHz                                                        |
| Connectivity               | IrDA, UART/USART                                             |
| Peripherals                | Brown-out Detect/Reset, LED, LVD, POR, PWM, Temp Sensor, WDT |
| Number of I/O              | 6                                                            |
| Program Memory Size        | 1KB (1K x 8)                                                 |
| Program Memory Type        | FLASH                                                        |
| EEPROM Size                | 16 x 8                                                       |
| RAM Size                   | 256 x 8                                                      |
| Voltage - Supply (Vcc/Vdd) | 2.7V ~ 3.6V                                                  |
| Data Converters            | A/D 4x10b                                                    |
| Oscillator Type            | Internal                                                     |
| Operating Temperature      | -40°C ~ 105°C (TA)                                           |
| Mounting Type              | Surface Mount                                                |
| Package / Case             | 8-SOIC (0.154", 3.90mm Width)                                |
| Supplier Device Package    | -                                                            |
| Purchase URL               | https://www.e-xfl.com/product-detail/zilog/z8f012asb020ec    |
|                            |                                                              |

Email: info@E-XFL.COM

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



| Reset, Stop Mode Recovery, and Low Voltage Detection | 23 |
|------------------------------------------------------|----|
| Reset Types                                          | 23 |
| Reset Sources                                        |    |
| Power-On Reset                                       |    |
| Voltage Brownout Reset                               |    |
| Watchdog Timer Reset       External Reset Input      |    |
| External Reset Indicator                             |    |
| On-Chip Debugger Initiated Reset                     |    |
| Stop Mode Recovery                                   | 28 |
| Stop Mode Recovery Using Watchdog Timer Time-Out     | 29 |
| Stop Mode Recovery Using a GPIO Port Pin Transition  |    |
| Stop Mode Recovery Using the External RESET Pin      |    |
| Low Voltage Detection                                |    |
| Reset Register Definitions                           | 30 |
| Low-Power Modes                                      | 33 |
| STOP Mode                                            | 33 |
| HALT Mode                                            | 34 |
| Peripheral-Level Power Control                       | 34 |
| Power Control Register Definitions                   | 34 |
| General-Purpose Input/Output                         | 37 |
| GPIO Port Availability By Device                     | 37 |
| Architecture                                         | 38 |
| GPIO Alternate Functions                             | 38 |
| Direct LED Drive                                     | 39 |
| Shared Reset Pin                                     | 39 |
| Shared Debug Pin                                     | 39 |
| Crystal Oscillator Override                          | 40 |
| 5 V Tolerance                                        | 40 |
| External Clock Setup                                 | 40 |
| GPIO Interrupts                                      | 45 |
| GPIO Control Register Definitions                    | 45 |
| Port A–D Address Registers                           |    |
| Port A–D Control Registers                           |    |
| Port A D Data Direction Sub-Registers                |    |
| Port A–D Alternate Function Sub-Registers            | 41 |



mation Area data rather than the Program Memory data. Access to the Flash Information Area is read-only.

| Program Memory Address (Hex) | Function                                                                                  |
|------------------------------|-------------------------------------------------------------------------------------------|
| FE00–FE3F                    | Zilog Option Bits/Calibration Data                                                        |
| FE40-FE53                    | Part Number<br>20-character ASCII alphanumeric code<br>Left justified and filled with FFH |
| FE54–FE5F                    | Reserved                                                                                  |
| FE60–FE7F                    | Zilog Calibration Data                                                                    |
| FE80–FFFF                    | Reserved                                                                                  |

Table 6. Z8 Encore! XP F082A Series Flash Memory Information Area Map

zilog

vector address. Following Stop Mode Recovery, the STOP bit in the Reset Status (RSTSTAT) Register is set to 1. Table 10 lists the Stop Mode Recovery sources and resulting actions. The text following provides more detailed information about each of the Stop Mode Recovery sources.

| Operating Mode | Stop Mode Recovery Source                                                         | Action                                                               |
|----------------|-----------------------------------------------------------------------------------|----------------------------------------------------------------------|
| STOP mode      | Watchdog Timer time-out when configured for Reset                                 | Stop Mode Recovery                                                   |
|                | Watchdog Timer time-out when configured for interrupt                             | Stop Mode Recovery followed by interrupt (if interrupts are enabled) |
|                | Data transition on any GPIO Port<br>pin enabled as a Stop Mode<br>Recovery source | Stop Mode Recovery                                                   |
|                | Assertion of external RESET Pin                                                   | System Reset                                                         |
|                | Debug Pin driven Low                                                              | System Reset                                                         |

#### Table 10. Stop Mode Recovery Sources and Resulting Action

## Stop Mode Recovery Using Watchdog Timer Time-Out

If the Watchdog Timer times out during STOP mode, the device undergoes a Stop Mode Recovery sequence. In the Reset Status (RSTSTAT) register, the WDT and STOP bits are set to 1. If the Watchdog Timer is configured to generate an interrupt upon time-out and the Z8 Encore! XP F082A Series device is configured to respond to interrupts, the eZ8 CPU services the Watchdog Timer interrupt request following the normal Stop Mode Recovery sequence.

## Stop Mode Recovery Using a GPIO Port Pin Transition

Each of the GPIO Port pins may be configured as a Stop Mode Recovery input source. On any GPIO pin enabled as a Stop Mode Recovery source, a change in the input pin value (from High to Low or from Low to High) initiates Stop Mode Recovery.

**Note:** The SMR pulses shorter than specified does not trigger a recovery (see Table 131 on page 229). When this happens, the STOP bit in the Reset Status (RSTSTAT) register is set to 1.

**Caution:** In STOP mode, the GPIO Port Input Data registers (PxIN) are disabled. The Port Input Data registers record the Port transition only if the signal stays on the Port pin through the end of the Stop Mode Recovery delay. As a result, short pulses on the Port pin can

zilog | 3

initiate Stop Mode Recovery without being written to the Port Input Data register or without initiating an interrupt (if enabled for that pin).

# Stop Mode Recovery Using the External RESET Pin

When the Z8 Encore! XP F082A Series device is in STOP mode and the external <u>RESET</u> pin is driven Low, a system reset occurs. Because of a glitch filter operating on the <u>RESET</u> pin, the Low pulse must be greater than the minimum width specified, or it is ignored. See Electrical Characteristics on page 221 for details.

# Low Voltage Detection

In addition to the Voltage Brownout (VBO) Reset described above, it is also possible to generate an interrupt when the supply voltage drops below a user-selected value. For details about configuring the Low Voltage Detection (LVD) and the threshold levels available, see Trim Bit Address 0003H on page 159. The LVD function is available on the 8-pin product versions only.

When the supply voltage drops below the LVD threshold, the LVD bit of the Reset Status (RSTSTAT) register is set to one. This bit remains one until the low-voltage condition goes away. Reading or writing this bit does not clear it. The LVD circuit can also generate an interrupt when so enabled, see Interrupt Vectors and Priority on page 58. The LVD bit is NOT latched, so enabling the interrupt is the only way to guarantee detection of a transient low voltage event.

The LVD functionality depends on circuitry shared with the VBO block; therefore, disabling the VBO also disables the LVD.

# **Reset Register Definitions**

The following sections define the Reset registers.

#### **Reset Status Register**

The Reset Status (RSTSTAT) register is a read-only register that indicates the source of the most recent Reset event, indicates a Stop Mode Recovery event, and indicates a Watchdog Timer time-out. Reading this register resets the upper four bits to 0.

This register shares its address with the Watchdog Timer control register, which is write-only (see Table 11 on page 31).



# **HALT Mode**

Executing the eZ8 CPU's HALT instruction places the device into HALT mode, which powers down the CPU but leaves all other peripherals active. In HALT mode, the operating characteristics are:

- Primary oscillator is enabled and continues to operate.
- System clock is enabled and continues to operate.
- eZ8 CPU is stopped.
- Program counter (PC) stops incrementing.
- Watchdog Timer's internal RC oscillator continues to operate.
- If enabled, the Watchdog Timer continues to operate.
- All other on-chip peripherals continue to operate, if enabled.

The eZ8 CPU can be brought out of HALT mode by any of the following operations:

- Interrupt
- Watchdog Timer time-out (interrupt or reset)
- Power-On Reset
- Voltage Brownout reset
- External **RESET** pin assertion

To minimize current in HALT mode, all GPIO pins that are configured as inputs must be driven to one of the supply rails ( $V_{CC}$  or GND).

# **Peripheral-Level Power Control**

In addition to the STOP and HALT modes, it is possible to disable each peripheral on each of the Z8 Encore! XP F082A Series devices. Disabling a given peripheral minimizes its power consumption.

# **Power Control Register Definitions**

The following sections define the Power Control registers.

## **Power Control Register 0**

Each bit of the following registers disables a peripheral block, either by gating its system clock input or by removing power from the block. The default state of the low-power

zilog

50

during STOP mode do not initiate Stop Mode Recovery.

1 = The Port pin is configured as a Stop Mode Recovery source. Any logic transition on this pin during STOP mode initiates Stop Mode Recovery.

#### Port A–D Pull-up Enable Sub-Registers

The Port A–D Pull-up Enable sub-register (Table 24) is accessed through the Port A–D Control register by writing 06H to the Port A–D Address register. Setting the bits in the Port A–D Pull-up Enable sub-registers enables a weak internal resistive pull-up on the specified Port pins.

#### Table 24. Port A–D Pull-Up Enable Sub-Registers (PxPUE)

| BITS  | 7        | 6                                                           | 5           | 4             | 3             | 2             | 1            | 0        |  |  |
|-------|----------|-------------------------------------------------------------|-------------|---------------|---------------|---------------|--------------|----------|--|--|
| FIELD | PPUE7    | PPUE6                                                       | PPUE5       | PPUE4         | PPUE3         | PPUE2         | PPUE1        | PPUE0    |  |  |
| RESET |          | 00H (Ports A-C); 01H (Port D); 04H (Port A of 8-pin device) |             |               |               |               |              |          |  |  |
| R/W   | R/W      | R/W R/W R/W R/W R/W R/W                                     |             |               |               |               |              |          |  |  |
| ADDR  | lf 06H i | n Port A–D /                                                | Address Reg | gister, acces | sible through | n the Port A- | -D Control F | Register |  |  |

PPUE[7:0]—Port Pull-up Enabled

0 = The weak pull-up on the Port pin is disabled.

1 = The weak pull-up on the Port pin is enabled.

#### Port A–D Alternate Function Set 1 Sub-Registers

The Port A–D Alternate Function Set1 sub-register (Table 25) is accessed through the Port A–D Control register by writing 07H to the Port A–D Address register. The Alternate Function Set 1 sub-registers selects the alternate function available at a port pin. Alternate Functions selected by setting or clearing bits of this register are defined in GPIO Alternate Functions on page 38.

**Note:** Alternate function selection on port pins must also be enabled as described in Port A–D Alternate Function Sub-Registers on page 47.

#### Table 25. Port A–D Alternate Function Set 1 Sub-Registers (PxAFS1)

| BITS  | 7        | 6            | 5           | 4             | 3             | 2             | 1            | 0        |
|-------|----------|--------------|-------------|---------------|---------------|---------------|--------------|----------|
| FIELD | PAFS17   | PAFS16       | PAFS15      | PAFS14        | PAFS13        | PAFS12        | PAFS11       | PAFS10   |
| 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  | lf 07H i | n Port A–D / | Address Reg | gister, acces | sible through | n the Port A- | -D Control F | Register |



Interrupts are globally enabled by any of the following actions:

- Execution of an EI (Enable Interrupt) instruction
- Execution of an IRET (Return from Interrupt) instruction
- Writing a 1 to the IRQE bit in the Interrupt Control register

Interrupts are globally disabled by any of the following actions:

- Execution of a DI (Disable Interrupt) instruction
- eZ8 CPU acknowledgement of an interrupt service request from the interrupt controller
- Writing a 0 to the IRQE bit in the Interrupt Control register
- Reset
- Execution of a Trap instruction
- Illegal Instruction Trap
- Primary Oscillator Fail Trap
- Watchdog Oscillator Fail Trap

### **Interrupt Vectors and Priority**

The interrupt controller supports three levels of interrupt priority. Level 3 is the highest priority, Level 2 is the second highest priority, and Level 1 is the lowest priority. If all of the interrupts are enabled with identical interrupt priority (all as Level 2 interrupts, for example), the interrupt priority is assigned from highest to lowest as specified in Table 32 on page 56. Level 3 interrupts are always assigned higher priority than Level 2 interrupts which, in turn, always are assigned higher priority than Level 1 interrupts. Within each interrupt priority level (Level 1, Level 2, or Level 3), priority is assigned as specified in Table 32, above. Reset, Watchdog Timer interrupt (if enabled), Primary Oscillator Fail Trap, Watchdog Oscillator Fail Trap, and Illegal Instruction Trap always have highest (level 3) priority.

#### **Interrupt Assertion**

Interrupt sources assert their interrupt requests for only a single system clock period (single pulse). When the interrupt request is acknowledged by the eZ8 CPU, the corresponding bit in the Interrupt Request register is cleared until the next interrupt occurs. Writing a 0 to the corresponding bit in the Interrupt Request register likewise clears the interrupt request.



# **IRQ2 Enable High and Low Bit Registers**

Table 42 describes the priority control for IRQ2. The IRQ2 Enable High and Low Bit registers (Table 43 and Table 44) form a priority encoded enabling for interrupts in the Interrupt Request 2 register.

| IRQ2ENL[x] | Priority                                                | Description               |
|------------|---------------------------------------------------------|---------------------------|
| 0          | Disabled                                                | Disabled                  |
| 1          | Level 1                                                 | Low                       |
| 0          | Level 2                                                 | Medium                    |
| 1          | Level 3                                                 | High                      |
|            | <b>IRQ2ENL[x]</b> 0 1 0 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 | 0Disabled1Level 10Level 2 |

#### Table 42. IRQ2 Enable and Priority Encoding

where x indicates the register bits from 0–7.

#### Table 43. IRQ2 Enable High Bit Register (IRQ2ENH)

| BITS  | 7   | 6    | 5     | 4   | 3     | 2     | 1     | 0     |
|-------|-----|------|-------|-----|-------|-------|-------|-------|
| FIELD |     | Rese | erved |     | C3ENH | C2ENH | C1ENH | C0ENH |
| 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  | 7H    |       |       |       |

Reserved—Must be 0.

C3ENH—Port C3 Interrupt Request Enable High Bit C2ENH—Port C2 Interrupt Request Enable High Bit C1ENH—Port C1 Interrupt Request Enable High Bit C0ENH—Port C0 Interrupt Request Enable High Bit

#### Table 44. IRQ2 Enable Low Bit Register (IRQ2ENL)

| BITS  | 7   | 6    | 5     | 4   | 3     | 2     | 1     | 0     |
|-------|-----|------|-------|-----|-------|-------|-------|-------|
| FIELD |     | Rese | erved |     | C3ENL | C2ENL | C1ENL | C0ENL |
| 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  | 8H    |       |       |       |

zilog<sup>\*</sup>

If the TPOL bit in the Timer Control register is set to 0, the Timer Output signal begins as a Low (0) and transitions to a High (1) when the timer value matches the PWM value. The Timer Output signal returns to a Low (0) after the timer reaches the Reload value and is reset to 0001H.

Follow the steps below for configuring a timer for PWM SINGLE OUTPUT mode and initiating the PWM operation:

- 1. Write to the Timer Control register to:
  - Disable the timer.
  - Configure the timer for PWM SINGLE OUTPUT mode.
  - Set the prescale value.
  - Set the initial logic level (High or Low) and PWM High/Low transition for the Timer Output alternate function.
- 2. Write to the Timer High and Low Byte registers to set the starting count value (typically 0001H). This only affects the first pass in PWM mode. After the first timer reset in PWM mode, counting always begins at the reset value of 0001H.
- 3. Write to the PWM High and Low Byte registers to set the PWM value.
- 4. Write to the Timer Reload High and Low Byte registers to set the Reload value (PWM period). The Reload value must be greater than the PWM value.
- 5. If appropriate, enable the timer interrupt and set the timer interrupt priority by writing to the relevant interrupt registers.
- 6. Configure the associated GPIO port pin for the Timer Output alternate function.
- 7. Write to the Timer Control register to enable the timer and initiate counting.

The PWM period is represented by the following equation:

 $PWM Period (s) = \frac{Reload Value \times Prescale}{System Clock Frequency (Hz)}$ 

If an initial starting value other than 0001H is loaded into the Timer High and Low Byte registers, use the ONE-SHOT mode equation to determine the first PWM time-out period.

If TPOL is set to 0, the ratio of the PWM output High time to the total period is represented by:

PWM Output High Time Ratio (%) =  $\frac{\text{Reload Value} - \text{PWM Value}}{\text{Reload Value}} \times 100$ 

If TPOL is set to 1, the ratio of the PWM output High time to the total period is represented by:

PWM Output High Time Ratio (%) =  $\frac{PWM Value}{Reload Value} \times 100$ 



89

| BITS  | 7   | 6    | 5   | 4     | 3    | 2   | 1   | 0   |  |  |  |  |
|-------|-----|------|-----|-------|------|-----|-----|-----|--|--|--|--|
| FIELD |     | PWML |     |       |      |     |     |     |  |  |  |  |
| 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  |     |      |     | F05H, | F0DH |     |     |     |  |  |  |  |

#### Table 55. Timer 0–1 PWM Low Byte Register (TxPWML)

PWMH and PWML—Pulse-Width Modulator High and Low Bytes These two bytes, {PWMH[7:0], PWML[7:0]}, form a 16-bit value that is compared to the current 16-bit timer count. When a match occurs, the PWM output changes state. The PWM output value is set by the TPOL bit in the Timer Control Register (TxCTL1) register.

The TxPWMH and TxPWML registers also store the 16-bit captured timer value when operating in CAPTURE or CAPTURE/COMPARE modes.



MPRX—Multiprocessor Receive

Returns the value of the most recent multiprocessor bit received. Reading from the UART Receive Data register resets this bit to 0.

# **UART Transmit Data Register**

Data bytes written to the UART Transmit Data (UxTXD) register (Table 65) are shifted out on the TXDx pin. The Write-only UART Transmit Data register shares a Register File address with the read-only UART 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  |   |     |   | F4 | 0H |   |   |   |  |  |  |  |

#### Table 65. UART Transmit Data Register (U0TXD)

TXD-Transmit Data

UART transmitter data byte to be shifted out through the TXDx pin.

## **UART Receive Data Register**

Data bytes received through the RXDx pin are stored in the UART Receive Data (UxRXD) register (Table 66). The read-only UART Receive Data register shares a Register File address with the Write-only UART Transmit Data register.

#### Table 66. UART Receive Data Register (U0RXD)

| BITS      | 7              | 6 | 5 | 4 | 3 | 2 | 1 | 0 |  |  |  |
|-----------|----------------|---|---|---|---|---|---|---|--|--|--|
| FIELD     | RXD            |   |   |   |   |   |   |   |  |  |  |
| RESET     | Х              | Х | Х | Х | Х | Х | Х | Х |  |  |  |
| R/W       | R              | R | R | R | R | R | R | R |  |  |  |
| ADDR      | F40H           |   |   |   |   |   |   |   |  |  |  |
| X = Undef | X = Undefined. |   |   |   |   |   |   |   |  |  |  |

RXD—Receive Data

UART receiver data byte from the RXDx pin

# zilog

# **Temperature Sensor**

The on-chip Temperature Sensor allows you to measure temperature on the die with either the on-board ADC or on-board comparator. This block is factory calibrated for in-circuit software correction. Uncalibrated accuracy is significantly worse, therefore the temperature sensor is not recommended for uncalibrated use.

# **Temperature Sensor Operation**

The on-chip temperature sensor is a Proportional to Absolute Temperature (PTAT) topology. A pair of Flash option bytes contain the calibration data. The temperature sensor can be disabled by a bit in the Power Control Register 0 on page 34 to reduce power consumption.

The temperature sensor can be directly read by the ADC to determine the absolute value of its output. The temperature sensor output is also available as an input to the comparator for threshold type measurement determination. The accuracy of the sensor when used with the comparator is substantially less than when measured by the ADC.

If the temperature sensor is routed to the ADC, the ADC must be configured in unity-gain buffered mode (see Input Buffer Stage on page 129) The value read back from the ADC is a signed number, although it is always positive.

The sensor is factory-trimmed through the ADC using the external 2.0 V reference. Unless the sensor is re-trimmed for use with a different reference, it is most accurate when used with the external 2.0 V reference.

Because this sensor is an on-chip sensor it is recommended that the user account for the difference between ambient and die temperature when inferring ambient temperature conditions.

During normal operation, the die undergoes heating that causes a mismatch between the ambient temperature and that measured by the sensor. For best results, the Z8 Encore! XP<sup>®</sup> device must be placed into STOP mode for sufficient time such that the die and ambient temperatures converge (this time is dependent on the thermal design of the system). The temperature sensor measurement must then be made immediately after recovery from STOP mode.

The following equation defines the transfer function between the temperature sensor output voltage and the die temperature. This is needed for comparator threshold measurements.

 $V = 0.01 \times T + 0.65$ 

where, T is the temperature in °C; V is the sensor output in volts.

zilog

163

| Info Page<br>Address | Memory<br>Address | Compensation Usage      | ADC Mode                 | Reference<br>Type |
|----------------------|-------------------|-------------------------|--------------------------|-------------------|
| 34                   | FE34              | Negative Gain High Byte | Differential Unbuffered  | External 2.0 V    |
| 35                   | FE35              | Negative Gain Low Byte  | Differential Unbuffered  | External 2.0 V    |
| 78                   | FE78              | Offset                  | Differential 1x Buffered | Internal 2.0 V    |
| 18                   | FE18              | Positive Gain High Byte | Differential 1x Buffered | Internal 2.0 V    |
| 19                   | FE19              | Positive Gain Low Byte  | Differential 1x Buffered | Internal 2.0 V    |
| 36                   | FE36              | Negative Gain High Byte | Differential 1x Buffered | Internal 2.0 V    |
| 37                   | FE37              | Negative Gain Low Byte  | Differential 1x Buffered | Internal 2.0 V    |
| 7B                   | FE7B              | Offset                  | Differential 1x Buffered | External 2.0 V    |
| 1A                   | FE1A              | Positive Gain High Byte | Differential 1x Buffered | External 2.0 V    |
| 1B                   | FE1B              | Positive Gain Low Byte  | Differential 1x Buffered | External 2.0 V    |
| 38                   | FE38              | Negative Gain High Byte | Differential 1x Buffered | External 2.0 V    |
| 39                   | FE39              | Negative Gain Low Byte  | Differential 1x Buffered | External 2.0 V    |

## Table 94. ADC Calibration Data Location (Continued)

zilog 1

# Operation

# **OCD** Interface

The on-chip debugger uses the DBG pin for communication with an external host. This one-pin interface is a bi-directional, open-drain interface that transmits and receives data. Data transmission is half-duplex, in that transmit and receive cannot occur simultaneously. The serial data on the DBG pin is sent using the standard asynchronous data format defined in RS-232. This pin creates an interface from the Z8 Encore! XP<sup>®</sup> F082A Series products to the serial port of a host PC using minimal external hardware. Two different methods for connecting the DBG pin to an RS-232 interface are displayed in Figure 24 and Figure 25. The recommended method is the buffered implementation displayed in Figure 25. The DBG pin has a internal pull-up resistor which is sufficient for some applications (for more details on the pull-up current, see Electrical Characteristics on page 221). For OCD operation at higher data rates or in noisy systems, an external pull-up resistor is recommended.

# Caution:

For operation of the on-chip debugger, all power pins ( $V_{DD}$  and  $AV_{DD}$ ) must be supplied with power, and all ground pins ( $V_{SS}$  and  $AV_{SS}$ ) must be properly grounded. The DBG pin is open-drain and may require an external pull-up resistor to ensure proper operation.



#### Figure 24. Interfacing the On-Chip Debugger's DBG Pin with an RS-232 Interface (1)

zilog

- **-** 18
- **Read Register (09H)**—The Read Register command reads data from the Register File. Data can be read 1–256 bytes at a time (256 bytes can be read by setting size to 0). If the device is not in DEBUG mode or if the Flash Read Protect Option bit is enabled, this command returns FFH for all the data values.

```
DBG \leftarrow 09H
DBG \leftarrow {4'h0,Register Address[11:8]
DBG \leftarrow Register Address[7:0]
DBG \leftarrow Size[7:0]
DBG \rightarrow 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 0). 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 device is not in DEBUG mode or if the Flash Read Protect Option bit is enabled, the data is discarded.

```
DBG \leftarrow 0AH
DBG \leftarrow Program Memory Address[15:8]
DBG \leftarrow Program Memory Address[7:0]
DBG \leftarrow Size[15:8]
DBG \leftarrow Size[7:0]
DBG \leftarrow 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 0). If the device is not in DEBUG mode or if the Flash Read Protect Option bit is enabled, this command returns FFH for the data.

```
DBG \leftarrow 0BH
DBG \leftarrow Program Memory Address[15:8]
DBG \leftarrow Program Memory Address[7:0]
DBG \leftarrow Size[15:8]
DBG \leftarrow Size[7:0]
DBG \rightarrow 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 0). If the device is not in DEBUG mode or if the Flash Read Protect Option bit is enabled, the data is discarded.

```
DBG \leftarrow 0CH
DBG \leftarrow Data Memory Address[15:8]
DBG \leftarrow Data Memory Address[7:0]
```

**z**ilog<sup>®</sup>

| Mode         | Crystal<br>Frequency Range | Function                            | Transconductance<br>(mA/V)<br>Use this range for<br>calculations |      |      |  |
|--------------|----------------------------|-------------------------------------|------------------------------------------------------------------|------|------|--|
| Low Gain*    | 32 kHz–1 MHz               | Low Power/Frequency Applications    | 0.02                                                             | 0.04 | 0.09 |  |
| Medium Gain* | 0.5 MHz–10 MHz             | Medium Power/Frequency Applications | 0.84                                                             | 1.7  | 3.1  |  |
| High Gain*   | 8 MHz–20 MHz               | High Power/Frequency Applications   | 1.1                                                              | 2.3  | 4.2  |  |

#### Table 111. Transconductance Values for Low, Medium, and High Gain Operating Modes

**Note:** \*Printed circuit board layout must not add more than 4 pF of stray capacitance to either XIN or XOUT pins. if no Oscillation occurs, reduce the values of the capacitors C1 and C2 to decrease the loading.

# **Oscillator Operation with an External RC Network**

Figure 28 displays a recommended configuration for connection with an external resistor-capacitor (RC) network.



#### Figure 28. Connecting the On-Chip Oscillator to an External RC Network

An external resistance value of 45 k $\Omega$  is recommended for oscillator operation with an external RC network. The minimum resistance value to ensure operation is 40 k $\Omega$ . The typical oscillator frequency can be estimated from the values of the resistor (*R* in k $\Omega$ ) and capacitor (*C* in pF) elements using the following equation:

Oscillator Frequency (kHz) = 
$$\frac{1 \times 10^{6}}{(0.4 \times R \times C) + (4 \times C)}$$

195



202

#### Table 115. Additional Symbols

| Definition                   |
|------------------------------|
| Destination Operand          |
| Source Operand               |
| Indirect Address Prefix      |
| Stack Pointer                |
| Program Counter              |
| Flags Register               |
| Register Pointer             |
| Immediate Operand Prefix     |
| Binary Number Suffix         |
| Hexadecimal Number<br>Prefix |
| Hexadecimal Number<br>Suffix |
|                              |

Assignment of a value is indicated by an arrow. For example,

 $dst \leftarrow dst + src$ 

indicates the source data is added to the destination data and the result is stored in the destination location.

# eZ8 CPU Instruction Classes

eZ8 CPU instructions can be divided functionally into the following groups:

- Arithmetic
- Bit Manipulation
- Block Transfer
- CPU Control
- Load
- Logical
- Program Control
- Rotate and Shift

**z**ilog<sup>®</sup>

203

Table 116 through Table 123 lists the instructions belonging to each group and the number of operands required for each instruction. Some instructions appear in more than one table as these instruction can be considered as a subset of more than one category. Within these tables, the source operand is identified as 'src', the destination operand is 'dst' and a condition code is 'cc'.

| Mnemonic | Operands | Instruction                                   |
|----------|----------|-----------------------------------------------|
| ADC      | dst, src | Add with Carry                                |
| ADCX     | dst, src | Add with Carry using Extended Addressing      |
| ADD      | dst, src | Add                                           |
| ADDX     | dst, src | Add using Extended Addressing                 |
| СР       | dst, src | Compare                                       |
| CPC      | dst, src | Compare with Carry                            |
| CPCX     | dst, src | Compare with Carry using Extended Addressing  |
| CPX      | dst, src | Compare using Extended Addressing             |
| DA       | dst      | Decimal Adjust                                |
| DEC      | dst      | Decrement                                     |
| DECW     | dst      | Decrement Word                                |
| INC      | dst      | Increment                                     |
| INCW     | dst      | Increment Word                                |
| MULT     | dst      | Multiply                                      |
| SBC      | dst, src | Subtract with Carry                           |
| SBCX     | dst, src | Subtract with Carry using Extended Addressing |
| SUB      | dst, src | Subtract                                      |
| SUBX     | dst, src | Subtract using Extended Addressing            |

#### **Table 116. Arithmetic Instructions**





| ג<br>ש<br>ק<br>ע<br>ק<br>ע<br>ק<br>ע<br>ק<br>ע<br>ק<br>ע<br>ק<br>ע<br>ק<br>ע<br>ק<br>ע<br>ק<br>ע<br>ק | Flash<br>Serie | S Devel                                           | SQ<br>NN<br>Opmen | t Kit | Interrupts | 16-Bit Timers w/PWM | 10-Bit A/D Channels | UART with IrDA | Comparator | Temperature Sensor | Description |  |  |
|-------------------------------------------------------------------------------------------------------|----------------|---------------------------------------------------|-------------------|-------|------------|---------------------|---------------------|----------------|------------|--------------------|-------------|--|--|
| Z8F08A28100KITG                                                                                       | •              |                                                   |                   |       |            |                     |                     |                |            |                    |             |  |  |
| Z8F04A28100KITG                                                                                       |                | Z8 Encore! XP F042A Series 28-Pin Development Kit |                   |       |            |                     |                     |                |            |                    |             |  |  |
| Z8F04A08100KITG Z8 Encore! XP F042A Series 8-Pin Development Kit                                      |                |                                                   |                   |       |            |                     |                     |                |            |                    |             |  |  |
| ZUSBSC00100ZACG                                                                                       |                | USB Smart Cable Accessory Kit                     |                   |       |            |                     |                     |                |            |                    |             |  |  |
| ZUSBOPTSC01ZACG                                                                                       |                | USB Opto-Isolated Smart Cable Accessory Kit       |                   |       |            |                     |                     |                |            |                    |             |  |  |
| ZENETSC0100ZACG                                                                                       |                | Ethernet Smart Cable Accessory Kit                |                   |       |            |                     |                     |                |            |                    |             |  |  |
|                                                                                                       |                |                                                   |                   |       |            |                     |                     |                |            |                    |             |  |  |