



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

| Details                    |                                                           |
|----------------------------|-----------------------------------------------------------|
| Product Status             | Active                                                    |
| Core Processor             | eZ8                                                       |
| Core Size                  | 8-Bit                                                     |
| Speed                      | 20MHz                                                     |
| Connectivity               | -                                                         |
| Peripherals                | Brown-out Detect/Reset, LED, POR, PWM, WDT                |
| Number of I/O              | 17                                                        |
| Program Memory Size        | 8KB (8K x 8)                                              |
| Program Memory Type        | FLASH                                                     |
| EEPROM Size                | -                                                         |
| RAM Size                   | 256 x 8                                                   |
| Voltage - Supply (Vcc/Vdd) | 2.7V ~ 3.6V                                               |
| Data Converters            | -                                                         |
| Oscillator Type            | Internal                                                  |
| Operating Temperature      | -40°C ~ 105°C (TA)                                        |
| Mounting Type              | Through Hole                                              |
| Package / Case             | 20-DIP (0.300", 7.62mm)                                   |
| Supplier Device Package    | -                                                         |
| Purchase URL               | https://www.e-xfl.com/product-detail/zilog/z8f0831ph020eg |

Email: info@E-XFL.COM

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

## Z8 Encore!<sup>®</sup> F0830 Series Product Specification

| ADC Control Register Definitions10ADC Control Register 010ADC Data High Byte Register10ADC Data Low Bits Register10Sample Settling Time Register10Sample Time Register10                                                                                                                                                                                                                                                                                                                                                                                                 | )2<br>)3<br>)3<br>)4                            |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------|
| Comparator10Operation10Comparator Control Register Definitions10                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | )6                                              |
| Flash Memory       10         Data Memory Address Space       11         Flash Information Area       11         Operation       11         Flash Operation Timing Using the Flash Frequency Registers       11                                                                                                                                                                                                                                                                                                                                                          | 1<br>1<br>2                                     |
| Flash Code Protection Against External Access                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 4                                               |
| Flash Code Protection Against Accidental Program and Erasure11Byte Programming11Page Erase11Mass Erase11Flash Controller Bypass11Flash Controller Behavior in Debug Mode11NVDS Operational Requirements11Flash Control Register Definitions11Flash Control Register Definitions11Flash Status Register12Flash Status Register12Flash Page Select Register12Flash Sector Protect Register12Flash Frequency High and Low Byte Registers12                                                                                                                                  | 6<br>7<br>7<br>7<br>7<br>8<br>8<br>9<br>0<br>21 |
| Flash Option Bits       12.         Operation       12.         Option Bit Configuration by Reset       12.         Option Bit Types       12.         Flash Option Bit Control Register Definitions       12.         Flash Option Bit Control Register Definitions       12.         Flash Option Bit Control Register Definitions       12.         Trim Bit Address Register       12.         Trim Bit Data Register       12.         Flash Option Bit Address Space       12.         Trim Bit Address Space       12.         Nonvolatile Data Storage       13. | 24<br>24<br>25<br>26<br>26<br>26<br>27<br>29    |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | 7                                               |

Calibration and Compensation ..... 101

#### vii

# Z8 Encore!<sup>®</sup> F0830 Series Product Specification

| Table 89.  | Trim Option Bits at 0006H (TCLKFLT) 132                                             |
|------------|-------------------------------------------------------------------------------------|
| Table 90.  | ClkFlt Delay Control Definition                                                     |
| Table 91.  | Write Status Byte 135                                                               |
| Table 92.  | Read Status Byte                                                                    |
| Table 93.  | NVDS Read Time                                                                      |
| Table 94.  | OCD Baud-Rate Limits                                                                |
| Table 95.  | On-Chip Debugger Command Summary 144                                                |
| Table 96.  | OCD Control Register (OCDCTL) 149                                                   |
| Table 97.  | OCD Status Register (OCDSTAT) 150                                                   |
| Table 98.  | Oscillator Configuration and Selection                                              |
| Table 99.  | Oscillator Control Register (OSCCTL) 154                                            |
| Table 100. | Recommended Crystal Oscillator Specifications 158                                   |
| Table 101. | Assembly Language Syntax Example 1                                                  |
| Table 102. | Assembly Language Syntax Example 2 164                                              |
| Table 103. | Notational Shorthand                                                                |
| Table 104. | Additional Symbols 165                                                              |
| Table 105. | Arithmetic Instructions                                                             |
| Table 106. | Bit Manipulation Instructions                                                       |
| Table 107. | Block Transfer Instructions                                                         |
| Table 108. | CPU Control Instructions                                                            |
| Table 109. | Load Instructions                                                                   |
| Table 110. | Rotate and Shift Instructions                                                       |
| Table 111. | Logical Instructions                                                                |
| Table 112. | Program Control Instructions                                                        |
| Table 113. | eZ8 CPU Instruction Summary 171                                                     |
| Table 114. | Op Code Map Abbreviations                                                           |
| Table 115. | Absolute Maximum Ratings                                                            |
| Table 116. | DC Characteristics                                                                  |
| Table 117. | AC Characteristics                                                                  |
| Table 118. | Power-On Reset and Voltage Brown-Out Electrical Characteristics and Tim-<br>ing 190 |

# **Program Memory**

The eZ8 CPU supports 64KB of program memory address space. The Z8 Encore! F0830 Series devices contain 1KB to 12KB of on-chip Flash memory in the program memory address space, depending on the device. Reading from program memory addresses outside the available Flash memory address range returns FFH. Writing to these unimplemented program memory addresses produces no effect. Table 6 shows a program memory map for the Z8 Encore! F0830 Series products.

|                                             | 0 , 1                      |
|---------------------------------------------|----------------------------|
| Program Memory Address (Hex)                | Function                   |
| Z8F0830 and Z8F0831 Products                |                            |
| 0000–0001                                   | Flash Option Bits          |
| 0002–0003                                   | Reset Vector               |
| 0004–003D                                   | Interrupt Vectors*         |
| 003E-1FFF                                   | Program Memory             |
| Z8F0430 and Z8F0431 Products                |                            |
| 0000–0001                                   | Flash Option Bits          |
| 0002–0003                                   | Reset Vector               |
| 0004–003D                                   | Interrupt Vectors*         |
| 003E-0FFF                                   | Program Memory             |
| Z8F0130 and Z8F0131 Products                |                            |
| 0000–0001                                   | Flash Option Bits          |
| 0002–0003                                   | Reset Vector               |
| 0004–003D                                   | Interrupt Vectors*         |
| 003E-03FF                                   | Program Memory             |
| Z8F0230 and Z8F0231 Products                |                            |
| 0000–0001                                   | Flash Option Bits          |
| 0002–0003                                   | Reset Vector               |
| 0004–003D                                   | Interrupt Vectors*         |
| 003E-07FF                                   | Program Memory             |
| Note: *See <u>Table 34</u> on page 54 for a | list of interrupt vectors. |

| Table 6 | . Z8 | Encore! | F0830 | Series | Program | Memory Ma | ips |
|---------|------|---------|-------|--------|---------|-----------|-----|
|---------|------|---------|-------|--------|---------|-----------|-----|

clock and reset signals, the required reset duration may be three or four clock periods. A reset pulse of three clock cycles in duration might trigger a reset and a reset pulse of four cycles in duration always triggers a reset.

While the  $\overline{\text{RESET}}$  input pin is asserted low, the Z8 Encore! F0830 Series devices remain in the Reset state. If the  $\overline{\text{RESET}}$  pin is held low beyond the system reset time-out, the device exits the Reset state on the system clock rising edge following  $\overline{\text{RESET}}$  pin deassertion. Following a system reset initiated by the external  $\overline{\text{RESET}}$  pin, the EXT status bit in the Reset Status (RSTSTAT) Register is set to 1.

## **External Reset Indicator**

During system reset or when enabled by the GPIO logic, the RESET pin functions as an open-drain (active low) RESET mode indicator in addition to the input functionality. This reset output feature allows an Z8 Encore! F0830 Series device to reset other components to which it is connected, even if that reset is caused by internal sources such as POR, VBO or WDT events. See the <u>Port A–D Control Registers</u> section on page 41.

After an internal Reset event occurs, the internal circuitry begins driving the RESET pin low. The  $\overrightarrow{\text{RESET}}$  pin is held low by the internal circuitry until the appropriate delay listed in <u>Table 9</u> (see page 22) has elapsed.

# **On-Chip Debugger Initiated Reset**

A Power-On Reset can be initiated using the On-Chip Debugger by setting the RST bit in the OCD Control Register. The OCD block is not reset, but the remainder of the chip goes through a normal system reset. The RST bit automatically clears during the system reset. Following the system reset, the POR bit in the Reset Status (RSTSTAT) Register is set.

# Stop Mode Recovery

The device enters the STOP Mode when the STOP instruction is executed by the eZ8 CPU. See the <u>Low-Power Modes</u> chapter on page 30 for detailed STOP Mode information. During Stop Mode Recovery, the CPU is held in reset for about 66 IPO cycles if the crystal oscillator is disabled or about 5000 cycles if it is enabled.

Stop Mode Recovery does not affect the on-chip registers other than the Reset Status (RSTSTAT) Register and the Oscillator Control Register (OSCCTL). After any Stop Mode Recovery, the IPO is enabled and selected as the system clock. If another system clock source is required or IPO disabling is required, the Stop Mode Recovery code must reconfigure the oscillator control block such that the correct system clock source is enabled and selected.

#### 32

**Note:** This register is only reset during a Power-On Reset sequence. Other system reset events do not affect it.

| Bit         | 7                                                                                                                                                                                                                                                                                                                                                                | 6           | 5          | 4          | 3        | 2        | 1    | 0        |  |  |
|-------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------|------------|------------|----------|----------|------|----------|--|--|
| Field       |                                                                                                                                                                                                                                                                                                                                                                  | Reserved    |            | VBO        | Reserved | Reserved | COMP | Reserved |  |  |
| RESET       | 1                                                                                                                                                                                                                                                                                                                                                                | 0           | 0          | 0          | 1        | 0        | 0    | 0        |  |  |
| R/W         | R/W                                                                                                                                                                                                                                                                                                                                                              | R/W         | R/W        | R/W        | R/W      | R/W      | R/W  | R/W      |  |  |
| Address     |                                                                                                                                                                                                                                                                                                                                                                  | ·           |            | F8         | 80H      |          |      |          |  |  |
| Bit         | Description                                                                                                                                                                                                                                                                                                                                                      |             |            |            |          |          |      |          |  |  |
| [7:5]       | <b>Reserved</b><br>These registers are reserved and must be programmed to 000.                                                                                                                                                                                                                                                                                   |             |            |            |          |          |      |          |  |  |
| [4]<br>VBO  | Voltage Brown-Out detector disable<br>This bit takes only effect when the VBO_AO Flash option bit is disabled. In STOP Mode, VBO<br>is always disabled when the VBO_AO Flash option bit is disabled. To learn more about the<br>VBO_AO Flash option bit function, see the <u>Flash Option Bits</u> chapter on page 124.<br>0 = VBO enabled.<br>1 = VBO disabled. |             |            |            |          |          |      |          |  |  |
| [3]         | Reserved<br>This bit is re                                                                                                                                                                                                                                                                                                                                       | eserved and | must be pr | ogrammed t | to 1.    |          |      |          |  |  |
| [2]         | Reserved<br>This bit is reserved and must be programmed to 0.                                                                                                                                                                                                                                                                                                    |             |            |            |          |          |      |          |  |  |
| [1]<br>COMP | Comparator Disable<br>0 = Comparator is enabled.<br>1 = Comparator is disabled.                                                                                                                                                                                                                                                                                  |             |            |            |          |          |      |          |  |  |
| [0]         | Reserved<br>This bit is re                                                                                                                                                                                                                                                                                                                                       | eserved and | must be pr | ogrammed t | to 0.    |          |      |          |  |  |

#### Table 14. Power Control Register 0 (PWRCTL0)

>

#### Port A–D Alternate Function Set 2 Subregisters

The Port A–D Alternate Function Set 2 Subregister, shown in Table 28, is accessed through the Port A–D Control Register by writing 08H to the Port A–D Address Register. The Alternate Function Set 2 subregisters select the alternate function available at a port pin. Alternate functions selected by setting or clearing bits in this register are defined in Table 16 in the <u>GPIO Alternate Functions</u> section on page 34.

Note: Alternate function selection on the port pins must also be enabled, as described in the <u>Port</u> <u>A–D Alternate Function Subregisters</u> section on page 42.

| Bit     | 7         | 6                                                                                     | 5      | 4      | 3      | 2      | 1      | 0      |  |  |
|---------|-----------|---------------------------------------------------------------------------------------|--------|--------|--------|--------|--------|--------|--|--|
| Field   | PAFS27    | PAFS26                                                                                | PAFS25 | PAFS24 | PAFS23 | PAFS22 | PAFS21 | PAFS20 |  |  |
| 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    |  |  |
| Address | If 08H ir | If 08H in Port A–D Address Register, accessible through the Port A–D Control Register |        |        |        |        |        |        |  |  |

#### Table 28. Port A–D Alternate Function Set 2 Subregisters (PxAFS2)

#### Bit Description

[7:0] Port Alternate Function Set 2

PAFS2x 0 = The Port Alternate function is selected, as defined in Table 16 in the <u>GPIO Alternate Func-</u> tions section on page 34.

> 1 = The Port Alternate function is selected, as defined in Table 16 in the <u>GPIO Alternate Func-</u> tions section on page 34.

Note: x indicates the specific GPIO port pin number (7–0).

## Table 39. IRQ0 Enable High Bit Register (IRQ0ENH)

| Bit     | 7        | 6     | 5     | 4   | 3        | 2   | 1   | 0   |  |  |
|---------|----------|-------|-------|-----|----------|-----|-----|-----|--|--|
| Field   | Reserved | T1ENH | T0ENH |     | Reserved |     |     |     |  |  |
| 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 |  |  |
| Address |          | FC1H  |       |     |          |     |     |     |  |  |

| Bit           | Description                                                          |
|---------------|----------------------------------------------------------------------|
| [7]           | <b>Reserved</b><br>This bit is reserved and must be programmed to 0. |
| [6]<br>T1ENH  | Timer 1 Interrupt Request Enable High Bit                            |
| [5]<br>T0ENH  | Timer 0 Interrupt Request Enable High Bit                            |
| [4:1]         | Reserved                                                             |
|               | These registers are reserved and must be programmed to 0000.         |
| [0]<br>ADCENH | ADC Interrupt Request Enable High Bit                                |

#### Table 40. IRQ0 Enable Low Bit Register (IRQ0ENL)

| Bit     | 7        | 6     | 5     | 4   | 3        | 2 | 1 | 0   |  |
|---------|----------|-------|-------|-----|----------|---|---|-----|--|
| Field   | Reserved | T1ENL | T0ENL |     | Reserved |   |   |     |  |
| RESET   | 0        | 0     | 0     | 0   | 0        | 0 | 0 | 0   |  |
| R/W     | R        | R/W   | R/W   | R/W | R/W      | R | R | R/W |  |
| Address | FC2H     |       |       |     |          |   |   |     |  |

| Bit           | Description                                                                     |
|---------------|---------------------------------------------------------------------------------|
| [7]           | <b>Reserved</b><br>This bit is reserved and must be programmed to 0.            |
| [6]<br>T1ENL  | Timer 1 Interrupt Request Enable Low Bit                                        |
| [5]<br>T0ENL  | Timer 0 Interrupt Request Enable Low Bit                                        |
| [4:1]         | <b>Reserved</b><br>These registers are reserved and must be programmed to 0000. |
| [0]<br>ADCENL | ADC Interrupt Request Enable Low Bit                                            |

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 \text{ Value}}{\text{Reload Value}} \times 100$$

#### **CAPTURE Mode**

In CAPTURE Mode, the current timer count value is recorded when the appropriate external timer input transition occurs. The capture count value is written to the timer PWM High and Low Byte registers. The timer input is the system clock. The TPOL bit in the Timer Control Register determines if the capture occurs on a rising edge or a falling edge of the timer input signal.

When the capture event occurs, an interrupt is generated and the timer continues counting. The INPCAP bit in the TxCTL1 Register is set to indicate the timer interrupt because of an input capture event.

The timer continues counting up to the 16-bit reload value stored in the Timer Reload High and Low Byte registers. Upon reaching the reload value, the timer generates an interrupt and continues counting. The INPCAP bit in the TxCTL1 Register clears, indicating that the timer interrupt has not occurred because of an input capture event.

Observe the following steps for configuring a timer for CAPTURE Mode and initiating the count:

- 1. Write to the Timer Control Register to:
  - Disable the timer
  - Configure the timer for CAPTURE Mode
  - Set the prescale value
  - Set the capture edge (rising or falling) for the timer input
- 2. Write to the Timer High and Low Byte registers to set the starting count value (typically 0001H).
- 3. Write to the Timer Reload High and Low Byte registers to set the reload value.
- 4. Clear the timer PWM High and Low Byte registers to 0000H. Clearing these registers allows user software to determine if interrupts were generated either by a capture event or by a reload. If the PWM High and Low Byte registers still contain 0000H after the interrupt, the interrupt were generated by a reload.

# Timer 0–1 PWM High and Low Byte Registers

The Timer 0–1 PWM High and Low Byte (TxPWMH and TxPWML) registers, shown in Tables 54 and 55, control PWM operations. These registers also store the capture values for the CAPTURE and CAPTURE/COMPARE modes.

| Bit     | 7    | 6          | 5   | 4   | 3   | 2   | 1   | 0   |  |
|---------|------|------------|-----|-----|-----|-----|-----|-----|--|
| Field   | PWMH |            |     |     |     |     |     |     |  |
| 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 |  |
| Address |      | F04H, F0CH |     |     |     |     |     |     |  |

#### Table 54. Timer 0–1 PWM High Byte Register (TxPWMH)

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

| Bit     | 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 |  |  |  |
| Address |      | F05H, F0DH |     |     |     |     |     |     |  |  |  |

#### Bit Description

| [7:0] | Pulse Width Modulator High and Low Bytes                                                     |
|-------|----------------------------------------------------------------------------------------------|
| PWMH, | These two bytes, {PWMH[7:0], PWML[7:0]}, form a 16-bit value that is compared to the current |
| PWML  | 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).                         |
|       | The TxPWMH and TxPWML registers also store the 16-bit captured timer value when operat-      |
|       | ing in capture or CAPTURE/COMPARE modes.                                                     |

# Flash Option Bits

Programmable Flash option bits allow user configuration of certain aspects of Z8 Encore! F0830 Series operation. The feature configuration data is stored in the Flash program memory and read during reset. The features available for control through the Flash option bits are:

- Watchdog Timer time-out response selection-interrupt or system reset
- Watchdog Timer enabled at reset
- The ability to prevent unwanted read access to user code in program memory
- The ability to prevent accidental programming and erasure of all or a portion of the user code in program memory
- Voltage Brown-Out configuration always enabled or disabled during STOP Mode to reduce STOP Mode power consumption
- OSCILLATOR Mode selection for high, medium and low power crystal oscillators or external RC oscillator
- Factory trimming information for the Internal Precision Oscillator and VBO voltage

# Operation

This section describes the type and configuration of the programmable Flash option bits.

# **Option Bit Configuration by Reset**

Each time the Flash option bits are programmed or erased, the device must be reset for the change to be effective. During any Reset operation (system reset or Stop Mode Recovery), the Flash option bits are automatically read from Flash program memory and written to the Option Configuration registers, which control Z8 Encore! F0830 Series device operation. Option bit control is established before the device exits reset and the eZ8 CPU begins code execution. The Option Configuration registers are not part of the register file and are not accessible for read or write access.

# Nonvolatile Data Storage

Z8 Encore! F0830 Series devices contain a Nonvolatile Data Storage (NVDS) element of up to 64 bytes (except when in Flash 12KB mode). This type of memory can perform over 100,000 write cycles.

# Operation

NVDS is implemented by special-purpose Zilog software stored in areas of program memory that are not user-accessible. These special-purpose routines use Flash memory to store the data, and incorporate a dynamic addressing scheme to maximize the write/erase endurance of the Flash.

**Note:** The products in the Z8 Encore! F0830 Series feature multiple NVDS array sizes. See the <u>Z8 Encore! F0830 Series Family Part Selection Guide</u> section on page 2 for details.

# **NVDS Code Interface**

Two routines are required to access the NVDS: a write routine and a read routine. Both of these routines are accessed with a CALL instruction to a predefined address outside of program memory that is accessible to the user. Both the NVDS address and data are singlebyte values. In order to not disturb the user code, these routines save the working register set before using it so that 16 bytes of stack space are required to preserve the site. After finishing the call to these routines, the working register set of the user code is recovered.

During both read and write accesses to the NVDS, interrupt service is not disabled. Any interrupts that occur during NVDS execution must not disturb the working register and existing stack contents; otherwise, the array can become corrupted. Zilog recommends the user disable interrupts before executing NVDS operations.

Use of the NVDS requires 16 bytes of available stack space. The contents of the working register set are saved before calling NVDS read or write routines.

For correct NVDS operation, the Flash Frequency registers must be programmed based on the system clock frequency. See *the* <u>Flash Operation Timing Using the Flash Frequency</u><u>Registers</u> *section on page 114*.

When selecting a new clock source, the primary oscillator failure detection circuitry and the Watchdog Timer Oscillator failure circuitry must be disabled. If POFEN and WOFEN are not disabled prior to a clock switch-over, it is possible to generate an interrupt for a failure of either oscillator. The failure detection circuitry can be enabled anytime after a successful write of OSCSEL in the Oscillator Control Register.

The Internal Precision Oscillator is enabled by default. If the user code changes to a different oscillator, it may be appropriate to disable the IPO for power savings. Disabling the IPO does not occur automatically.

# **Clock Failure Detection and Recovery**

#### **Primary Oscillator Failure**

The Z8F04xA family devices can generate nonmaskable interrupt-like events when the primary oscillator fails. To maintain system function in this situation, the clock failure recovery circuitry automatically forces the Watchdog Timer Oscillator to drive the system clock. The Watchdog Timer Oscillator must be enabled to allow the recovery. Although this oscillator runs at a much slower speed than the original system clock, the CPU continues to operate, allowing execution of a clock failure vector and software routines that either remedy the oscillator failure or issue a failure alert. This automatic switch-over is not available if the Watchdog Timer is the primary oscillator. It is also unavailable if the Watchdog Timer reset function outlined in the Watchdog Timer chapter of this document.

The primary oscillator failure detection circuitry asserts if the system clock frequency drops below 1 KHz  $\pm$ 50%. If an external signal is selected as the system oscillator, it is possible that a very slow but nonfailing clock can generate a failure condition. Under these conditions, do not enable the clock failure circuitry (POFEN must be deasserted in the OSCCTL Register).

## Watchdog Timer Failure

In the event of failure of a Watchdog Timer Oscillator, a similar nonmaskable interruptlike event is issued. This event does not trigger an attendant clock switch-over, but alerts the CPU of the failure. After a Watchdog Timer failure, it is no longer possible to detect a primary oscillator failure. The failure detection circuitry does not function if the Watchdog Timer is used as the primary oscillator or if the Watchdog Timer Oscillator has been disabled. For either of these cases, it is necessary to disable the detection circuitry by deasserting the WDFEN bit of the OSCCTL Register.

The Watchdog Timer Oscillator failure detection circuit counts system clocks while looking for a Watchdog Timer clock. The logic counts 8004 system clock cycles before determining that a failure has occurred. The system clock rate determines the speed at which the Watchdog Timer failure is detected. A very slow system clock results in very slow detection times.

| Bit             | Description (Continued)                                                                                                                                                                                                                                                                                                                                                                                                                                          |
|-----------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [4]<br>POFEN    | <ul> <li>Primary Oscillator Failure Detection Enable</li> <li>1 = Failure detection and recovery of primary oscillator is enabled.</li> <li>0 = Failure detection and recovery of primary oscillator is disabled.</li> </ul>                                                                                                                                                                                                                                     |
| [3]<br>WDFEN    | Watchdog Timer Oscillator Failure Detection Enable<br>1 = Failure detection of Watchdog Timer Oscillator is enabled.<br>0 = Failure detection of Watchdog Timer Oscillator is disabled.                                                                                                                                                                                                                                                                          |
| [2:0]<br>SCKSEL | System Clock Oscillator Select<br>000 = Internal Precision Oscillator functions as system clock at 5.53MHz.<br>001 = Internal Precision Oscillator functions as system clock at 32 kHz.<br>010 = Crystal oscillator or external RC oscillator functions as system clock.<br>011 = Watchdog Timer Oscillator functions as system clock.<br>100 = External clock signal on PB3 functions as system clock.<br>101 = Reserved.<br>110 = Reserved.<br>111 = Reserved. |

## Example 2

In general, when an instruction format requires an 8-bit register address, the address can specify any register location in the range 0–255 or, using escaped mode addressing, a working register R0–R15. If the contents of register 43H and working register R8 are added and the result is stored in 43H, the assembly syntax and resulting object code is:

#### Table 102. Assembly Language Syntax Example 2

| Assembly Language Code | ADD | 43H, | R8 | (ADD dst, src) |
|------------------------|-----|------|----|----------------|
| Object Code            | 04  | E8   | 43 | (OPC src, dst) |

See the device specific product specification to determine the exact register file range available. The register file size varies, depending on the device type.

# eZ8 CPU Instruction Notation

In the eZ8 CPU instruction summary and description sections, the operands, condition codes, status flags and address modes are represented by the notational shorthand listed in Table 103.

| Notation | Description                    | Operand | Range                                                     |
|----------|--------------------------------|---------|-----------------------------------------------------------|
| b        | Bit                            | b       | b represents a value from 0 to 7 (000B to 111B).          |
| CC       | Condition Code                 | —       | See condition codes overview in the eZ8 CPU User Manual.  |
| DA       | Direct Address                 | Addrs   | Addrs. represents a number in the range of 0000H to FFFFH |
| ER       | Extended Addressing Register   | Reg     | Reg. represents a number in the range of 000H to FFFH     |
| IM       | Immediate Data                 | #Data   | Data is a number between 00H to FFH                       |
| lr       | Indirect Working Register      | @Rn     | n = 0 –15                                                 |
| IR       | Indirect Register              | @Reg    | Reg. represents a number in the range of 00H to FFH       |
| Irr      | Indirect Working Register Pair | @RRp    | p = 0, 2, 4, 6, 8, 10, 12 or 14                           |
| IRR      | Indirect Register Pair         | @Reg    | Reg. represents an even number in the range 00H to FEH    |
| р        | Polarity                       | р       | Polarity is a single bit binary value of either 0B or 1B. |
| r        | Working Register               | Rn      | n = 0 – 15                                                |

#### Table 103. Notational Shorthand

| Assembly         |                                                                                           |     | ress<br>ode | Op<br>Code(s) |   |   | Fla | ags |   |   | _ Fetch | Instr. |
|------------------|-------------------------------------------------------------------------------------------|-----|-------------|---------------|---|---|-----|-----|---|---|---------|--------|
| Mnemonic         | Symbolic Operation                                                                        | dst | src         | (Hex)         | С | Ζ | S   | ۷   | D | Н |         |        |
| AND dst, src     | $dst \gets dst \; AND \; src$                                                             | r   | r           | 52            | _ | * | *   | 0   | _ | _ | 2       | 3      |
|                  |                                                                                           | r   | lr          | 53            | _ |   |     |     |   |   | 2       | 4      |
|                  |                                                                                           | R   | R           | 54            |   |   |     |     |   |   | 3       | 3      |
|                  |                                                                                           | R   | IR          | 55            | _ |   |     |     |   |   | 3       | 4      |
|                  |                                                                                           | R   | IM          | 56            | _ |   |     |     |   |   | 3       | 3      |
|                  |                                                                                           | IR  | IM          | 57            | _ |   |     |     |   |   | 3       | 4      |
| ANDX dst, src    | $dst \gets dst \; AND \; src$                                                             | ER  | ER          | 58            | _ | * | *   | 0   | _ | _ | 4       | 3      |
|                  |                                                                                           | ER  | IM          | 59            | _ |   |     |     |   |   | 4       | 3      |
| ATM              | Block all interrupt and<br>DMA requests during<br>execution of the next 3<br>instructions |     |             | 2F            | - | _ | _   | _   | _ | _ | 1       | 2      |
| BCLR bit, dst    | dst[bit] ← 0                                                                              | r   |             | E2            | _ | * | *   | 0   | _ | _ | 2       | 2      |
| BIT p, bit, dst  | dst[bit] ← p                                                                              | r   |             | E2            | _ | * | *   | 0   | _ | _ | 2       | 2      |
| BRK              | Debugger Break                                                                            |     |             | 00            | - | _ | -   | -   | _ | _ | 1       | 1      |
| BSET bit, dst    | dst[bit] ← 1                                                                              | r   |             | E2            | - | * | *   | 0   | - | - | 2       | 2      |
| BSWAP dst        | dst[7:0] ← dst[0:7]                                                                       | R   |             | D5            | Х | * | *   | 0   | - | - | 2       | 2      |
| BTJ p, bit, src, | if src[bit] = p                                                                           |     | r           | F6            | - | _ | -   | -   | _ | _ | 3       | 3      |
| dst              | $PC \gets PC + X$                                                                         |     | lr          | F7            | _ |   |     |     |   |   | 3       | 4      |
| BTJNZ bit, src,  |                                                                                           |     | r           | F6            | - | - | -   | -   | - | - | 3       | 3      |
| dst              | $PC \leftarrow PC + X$                                                                    |     | lr          | F7            | _ |   |     |     |   |   | 3       | 4      |
| BTJZ bit, src,   | if src[bit] = 0                                                                           |     | r           | F6            | _ | - | _   | _   | - | - | 3       | 3      |
| dst              | $PC \leftarrow PC + X$                                                                    |     | Ir          | F7            |   |   |     |     |   |   | 3       | 4      |
| CALL dst         | $SP \leftarrow SP -\!\!\!\!\!-\!\!\!\!\!2$                                                | IRR |             | D4            | _ | _ | -   | -   | _ | - | 2       | 6      |
|                  | @SP ← PC<br>PC ← dst                                                                      | DA  |             | D6            |   |   |     |     |   |   | 3       | 3      |
| CCF              | $C \leftarrow \sim C$                                                                     |     |             | EF            | * | _ | _   | _   | _ |   | 1       | 2      |

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

Note: Flags Notation:

\* = Value is a function of the result of the operation.

- = Unaffected.

X = Undefined.

0 = Reset to 0.

1 = Set to 1.

| Part Number          | Flash      | RAM   | NVDS | ADC<br>Channels | Description                                    |
|----------------------|------------|-------|------|-----------------|------------------------------------------------|
| Z8F0131PJ020SG       | 1KB        | 256   | Yes  | 0               | PDIP 28-pin                                    |
| Z8F0131QJ020SG       | 1KB        | 256   | Yes  | 0               | QFN 28-pin                                     |
| Extended Temperature | : −40°C to | 105°C |      |                 |                                                |
| Z8F0130SH020EG       | 1KB        | 256   | Yes  | 7               | SOIC 20-pin                                    |
| Z8F0130HH020EG       | 1KB        | 256   | Yes  | 7               | SSOP 20-pin                                    |
| Z8F0130PH020EG       | 1KB        | 256   | Yes  | 7               | PDIP 20-pin                                    |
| Z8F0130QH020EG       | 1KB        | 256   | Yes  | 7               | QFN 20-pin                                     |
| Z8F0131SH020EG       | 1KB        | 256   | Yes  | 0               | SOIC 20-pin                                    |
| Z8F0131HH020EG       | 1KB        | 256   | Yes  | 0               | SSOP 20-pin                                    |
| Z8F0131PH020EG       | 1KB        | 256   | Yes  | 0               | PDIP 20-pin                                    |
| Z8F0131QH020EG       | 1KB        | 256   | Yes  | 0               | QFN 20-pin                                     |
| Z8F0130SJ020EG       | 1KB        | 256   | Yes  | 8               | SOIC 28-pin                                    |
| Z8F0130HJ020EG       | 1KB        | 256   | Yes  | 8               | SSOP 28-pin                                    |
| Z8F0130PJ020EG       | 1KB        | 256   | Yes  | 8               | PDIP 28-pin                                    |
| Z8F0130QJ020EG       | 1KB        | 256   | Yes  | 8               | QFN 28-pin                                     |
| Z8F0131SJ020EG       | 1KB        | 256   | Yes  | 0               | SOIC 28-pin                                    |
| Z8F0131HJ020EG       | 1KB        | 256   | Yes  | 0               | SSOP 28-pin                                    |
| Z8F0131PJ020EG       | 1KB        | 256   | Yes  | 0               | PDIP 28-pin                                    |
| Z8F0131QJ020EG       | 1KB        | 256   | Yes  | 0               | QFN 28-pin                                     |
| ZUSBSC00100ZACG      |            |       |      |                 | USB Smart Cable Accessory Kit                  |
| ZUSBOPTSC01ZACG      |            |       |      |                 | Opto-Isolated USB Smart Cable<br>Accessory Kit |

#### Table 128. Z8 Encore! XP F0830 Series Ordering Matrix

# **Part Number Suffix Designations**

Zilog part numbers consist of a number of components, as indicated in the following example.

**Example.** Part number Z8F0830SH020SG is an 8-bit 20MHz Flash MCU with 8KB Program Memory and equipped with ADC and NVDS in a 20-pin SOIC package, operating within a 0°C to +70°C temperature range and built using lead-free solder.

## Hex Address: F05

#### Table 135. Timer 0 PWM Low Byte Register (T0PWML)

| Bit     | 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 |  |  |  |  |
| Address |     | F05H |     |     |     |     |     |     |  |  |  |  |

## Hex Address: F06

#### Table 136. Timer 0 Control Register 0 (T0CTL0)

| Bit     | 7       | 6        | 5   | 4        | 3   | 2      | 1   | 0   |  |  |  |
|---------|---------|----------|-----|----------|-----|--------|-----|-----|--|--|--|
| Field   | TMODEHI | TICONFIG |     | Reserved |     | INPCAP |     |     |  |  |  |
| 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 |  |  |  |
| Address |         | F06H     |     |          |     |        |     |     |  |  |  |

## Hex Address: F07

#### Table 137. Timer 0 Control Register 1 (T0CTL1)

| Bit     | 7   | 6    | 5   | 4    | 3   | 2     | 1   | 0   |  |  |
|---------|-----|------|-----|------|-----|-------|-----|-----|--|--|
| Field   | TEN | TPOL |     | PRES |     | TMODE |     |     |  |  |
| 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 |  |  |
| Address |     | F07H |     |      |     |       |     |     |  |  |

#### Hex Address: F08

#### Table 138. Timer 1 High Byte Register (T1H)

| Bit     | 7   | 6   | 5   | 4   | 3   | 2   | 1   | 0   |  |  |  |
|---------|-----|-----|-----|-----|-----|-----|-----|-----|--|--|--|
| Field   | ТН  |     |     |     |     |     |     |     |  |  |  |
| 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 |  |  |  |
| Address |     |     |     | F0  | 8H  |     |     |     |  |  |  |

## Hex Address: F71

This address range is reserved.

## Hex Address: F72

## Table 147. ADC Data High Byte Register (ADCD\_H)

| Bit     | 7     | 6 | 5 | 4  | 3  | 2 | 1 | 0 |  |  |  |  |
|---------|-------|---|---|----|----|---|---|---|--|--|--|--|
| Field   | ADCDH |   |   |    |    |   |   |   |  |  |  |  |
| RESET   | X     |   |   |    |    |   |   |   |  |  |  |  |
| R/W     | R     |   |   |    |    |   |   |   |  |  |  |  |
| Address |       |   |   | F7 | 2H |   |   |   |  |  |  |  |

| Bit   | Description                                                                                                                                 |
|-------|---------------------------------------------------------------------------------------------------------------------------------------------|
| [7:0] | <b>ADC High Byte</b><br>00h–FFh = The last conversion output is held in the data registers until the next ADC conver-<br>sion is completed. |

## Hex Address: F73

## Table 148. ADC Data Low Bits Register (ADCD\_L)

| Bit     | 7    | 6   | 5        | 4 | 3 | 2 | 1 | 0 |  |
|---------|------|-----|----------|---|---|---|---|---|--|
| Field   | ADO  | CDL | Reserved |   |   |   |   |   |  |
| RESET   | Х    |     | X        |   |   |   |   |   |  |
| R/W     | F    | २   | R        |   |   | २ |   |   |  |
| Address | F73H |     |          |   |   |   |   |   |  |

| Bit<br>Position | Description                                                                                                                                                                                                                                         |
|-----------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [7:6]           | <b>ADC Low Bits</b><br>00–11b = These bits are the two least significant bits of the 10-bit ADC output. These bits are<br>undefined after a reset. The low bits are latched into this register whenever the ADC Data High<br>Byte Register is read. |
| [5:0]           | <b>Reserved</b><br>These bits are reserved and must be programmed to 000000.                                                                                                                                                                        |

#### Z8 Encore!<sup>®</sup> F0830 Series Product Specification

238

reload high and low byte registers 85 timer control register definitions 83 timer output signal operation 82 timers 0-3 control registers 87, 88 high and low byte registers 83, 86 TM 167 TMX 167 TRAP 169

# V

vector 165 voltage brown-out reset (VBR) 24 voltage measurement timing diagram 100

## W

watch-dog timer approximate time-out delay 92 approximate time-out delays 92, 106, 134, 151, 161 CNTL 24 control register 95, 154 electrical characteristics and timing 194 interrupt in noromal operation 93 interrupt in stop mode 93 operation 92, 106, 134, 151, 161 refresh 93 reload unlock sequence 94 reload upper, high and low registers 96 reset 25 reset in normal operation 94 reset in Stop mode 94 time-out response 93 watchdog timer refresh 168 WDTCTL register 29, 95, 107, 154, 217, 218, 226 WDTH register 96, 227 WDTL register 97, 227 working register 164 working register pair 165 WTDU register 96, 227

# Χ

X 165 XOR 169 XORX 169

# Ζ

Z8 Encore! block diagram 3 features 1 part selection guide 2

# **Customer Support**

To share comments, get your technical questions answered or report issues you may be experiencing with our products, please visit Zilog's Technical Support page at <a href="http://support.zilog.com">http://support.zilog.com</a>.

To learn more about this product, find additional documentation or to discover other facets about Zilog product offerings, please visit the Zilog Knowledge Base at <u>http://zilog.com/</u><u>kb</u> or consider participating in the Zilog Forum at <u>http://zilog.com/forum</u>.

This publication is subject to replacement by a later edition. To determine whether a later edition exists, please visit the Zilog website at <u>http://www.zilog.com</u>.