# E·XFL



Welcome to E-XFL.COM

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

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

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

#### Details

| Product Status             | 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        | 4KB (4K 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      | 0°C ~ 70°C (TA)                                           |
| Mounting Type              | Surface Mount                                             |
| Package / Case             | 20-VQFN Exposed Pad                                       |
| Supplier Device Package    | -                                                         |
| Purchase URL               | https://www.e-xfl.com/product-detail/zilog/z8f0431qh020sg |

Email: info@E-XFL.COM

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

# List of Tables

| Table 1.  | Z8 Encore! F0830 Series Family Part Selection Guide 2              |
|-----------|--------------------------------------------------------------------|
| Table 2.  | Acronyms and Expansions                                            |
| Table 3.  | Z8 Encore! F0830 Series Package Options 7                          |
| Table 4.  | Signal Descriptions                                                |
| Table 5.  | Pin Characteristics (20- and 28-pin Devices) 13                    |
| Table 6.  | Z8 Encore! F0830 Series Program Memory Maps 15                     |
| Table 7.  | Z8 Encore! F0830 Series Flash Memory Information Area Map 16       |
| Table 8.  | Register File Address Map 17                                       |
| Table 9.  | Reset and Stop Mode Recovery Characteristics and Latency 22        |
| Table 10. | Reset Sources and Resulting Reset Type                             |
| Table 11. | Stop Mode Recovery Sources and Resulting Action 27                 |
| Table 12. | POR Indicator Values                                               |
| Table 13. | Reset Status Register (RSTSTAT)                                    |
| Table 14. | Power Control Register 0 (PWRCTL0)                                 |
| Table 15. | Port Availability by Device and Package Type                       |
| Table 16. | Port Alternate Function Mapping                                    |
| Table 17. | GPIO Port Registers and Subregisters                               |
| Table 18. | Port A-D GPIO Address Registers (PxADDR) 40                        |
| Table 19. | Port Control Subregister Access                                    |
| Table 20. | Port A–D Control Registers (PxCTL)                                 |
| Table 21. | Port A–D Data Direction Subregisters (PxDD) 41                     |
| Table 22. | Port A–D Alternate Function Subregisters (PxAF)                    |
| Table 23. | Port A–D Output Control Subregisters (PxOC)                        |
| Table 24. | Port A–D High Drive Enable Subregisters (PxHDE)                    |
| Table 25. | Port A–D Stop Mode Recovery Source Enable Subregisters (PxSMRE) 45 |
| Table 26. | Port A–D Pull-Up Enable Subregisters (PxPUE)                       |
| Table 27. | Port A–D Alternate Function Set 1 Subregisters (PxAFS1) 47         |
| Table 28. | Port A–D Alternate Function Set 2 Subregisters (PxAFS2)            |

# 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 169                                                    |
| 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 |

# Port A–D Alternate Function Subregisters

The Port A–D Alternate Function Subregister is accessed through the Port A–D Control Register by writing 02H to the Port A–D Address Register. See Table 22 on page 42. The Port A–D Alternate Function subregisters enable the alternate function selection on pins. If disabled, the pins function as GPIOs. If enabled, select one of four alternate functions using Alternate Function Set subregisters 1 and 2, as described in the the <u>Port A–D Alternate Function</u> <u>Set 1 Subregisters</u> section on page 47 and the <u>Port A–D Alternate Function</u> <u>Set 2 Subregisters</u> section on page 48. See the <u>GPIO Alternate Functions</u> section on page 34 to determine the alternate functions associated with each port pin.

**Caution:** Do not enable alternate functions for GPIO port pins for which there is no associated Alternate function. Failure to follow this guideline can result in unpredictable operation.

| Bit     | 7           | 6                                                                                          | 5   | 4   | 3   | 2   | 1   | 0   |  |  |
|---------|-------------|--------------------------------------------------------------------------------------------|-----|-----|-----|-----|-----|-----|--|--|
| Field   | AF7         | AF6                                                                                        | AF5 | AF4 | AF3 | AF2 | AF1 | AF0 |  |  |
| RESET   |             | 00H (Ports A–C); 01H (Port D)                                                              |     |     |     |     |     |     |  |  |
| R/W     |             | R/W                                                                                        |     |     |     |     |     |     |  |  |
| Address | If 02H in F | If 02H in Port A–D Address Register, then accessible through the Port A–D Control Register |     |     |     |     |     |     |  |  |
| Bit     | Description |                                                                                            |     |     |     |     |     |     |  |  |
| [7:0]   | Port Altern | Port Alternate Function Enable                                                             |     |     |     |     |     |     |  |  |
| AFx     | •           | = The port pin is in NORMAL Mode and the DDx bit in the Port A–D Data Direction Subregis-  |     |     |     |     |     |     |  |  |

Table 22. Port A–D Alternate Function Subregisters (PxAF)

ter determines the direction of the pin. 1 = The alternate function selected through Alternate function set subregisters is enabled. Port

= The alternate function selected through Alternate function set subregisters is enabled. Port pin operation is controlled by the Alternate function.

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

| Bit                      | 7               | 6                | 5            | 4           | 3             | 2         | 1      | 0      |  |
|--------------------------|-----------------|------------------|--------------|-------------|---------------|-----------|--------|--------|--|
| Field                    | PA7ENL          | PA6CENL          | PA5ENL       | PA4ENL      | <b>PA3ENL</b> | PA2ENL    | PA1ENL | PA0ENL |  |
| 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                  |                 | FC5H             |              |             |               |           |        |        |  |
| Bit                      | Descrip         | Description      |              |             |               |           |        |        |  |
| [7]<br>PA7ENL            | Port A E        | Bit[7] Interru   | ipt Request  | Enable Lo   | w Bit         |           |        |        |  |
| [6]<br>PA6CENL           | Port A E        | Bit[7] or Con    | nparator In  | terrupt Req | uest Enable   | e Low Bit |        |        |  |
| [5:0]<br>PA <i>x</i> ENL |                 |                  |              |             |               |           |        |        |  |
| Note: x inc              | licates registe | er bits in the a | ddress range | e 5–0.      |               |           |        |        |  |

## Table 43. IRQ1 Enable Low Bit Register (IRQ1ENL)

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

Table 44 describes the priority control for IRQ2. The IRQ2 Enable High and Low Bit registers, shown in Tables 45 and 46, form a priority-encoded enabling service for interrupts in the Interrupt Request 2 Register. Priority is generated by setting the bits in each register.

| IRQ2ENH[x]                                                | IRQ2ENL[x] | Priority | Description |  |  |  |  |
|-----------------------------------------------------------|------------|----------|-------------|--|--|--|--|
| 0                                                         | 0          | Disabled | Disabled    |  |  |  |  |
| 0                                                         | 1          | Level 1  | Low         |  |  |  |  |
| 1                                                         | 0          | Level 2  | Nominal     |  |  |  |  |
| 1                                                         | 1          | Level 3  | High        |  |  |  |  |
| Note: x indicates register bits in the address range 7–0. |            |          |             |  |  |  |  |

Table 44. IRQ2 Enable and Priority Encoding

Observe the following steps for configuring a timer for PWM DUAL OUTPUT Mode and for initiating the PWM operation:

- 1. Write to the Timer Control Register to:
  - Disable the timer
  - Configure the timer for PWM DUAL OUTPUT Mode; setting the mode also involves writing to TMODEHI bit in the TxCTL1 Register
  - 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 write 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 PWM Control Register to set the PWM deadband delay value. The deadband delay must be less than the duration of the positive phase of the PWM signal (as defined by the PWM High and Low Byte registers). It must also be less than the duration of the negative phase of the PWM signal (as defined by the difference between the PWM registers and the Timer Reload registers).
- 5. 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.
- 6. If appropriate, enable the timer interrupt and set the timer interrupt priority by writing to the relevant interrupt registers.
- 7. Configure the associated GPIO port pin for the timer output and timer output complement alternate functions. The timer output complement function is shared with the timer input function for both timers. Setting the timer mode to DUAL PWM will automatically switch the function from timer-in to timer-out complement.
- 8. 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, the ONE-SHOT Mode equation determines 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:

## Bit Description (Continued)

### [6] Timer Input/Output Polarity

TPOL Operation of this bit is a function of the current operating mode of the timer.

#### **ONE-SHOT Mode**

When the timer is disabled, the timer output signal is set to the value of this bit. When the timer is enabled, the timer output signal is complemented on timer reload.

#### **CONTINUOUS Mode**

When the timer is disabled, the timer output signal is set to the value of this bit. When the timer is enabled and reloaded, the timer output signal is complemented.

#### **COUNTER Mode**

If the timer is disabled, the timer output signal is set to the value of this bit. If the timer is enabled the timer output signal is complemented after timer reload.

- 0 = Count occurs on the rising edge of the timer input signal.
- 1 = Count occurs on the falling edge of the timer input signal.

#### PWM SINGLE OUTPUT Mode

- 0 = Timer output is forced Low (0), when the timer is disabled. The timer output is forced High (1) when the timer is enabled and the PWM count matches and the timer output is forced Low (0) when the timer is enabled and reloaded.
- 1 = Timer output is forced High (1), when the timer is disabled. The timer output is forced low(0), when the timer is enabled and the PWM count matches and forced High (1) when the timer is enabled and reloaded.

#### CAPTURE Mode

- 0 = Count is captured on the rising edge of the timer input signal.
- 1 = Count is captured on the falling edge of the timer input signal.

#### COMPARE Mode

When the timer is disabled, the timer output signal is set to the value of this bit. When the timer is enabled and reloaded, the timer output signal is complemented.

### GATED Mode

- 0 = Timer counts when the timer input signal is High (1) and interrupts are generated on the falling edge of the timer input.
- 1 = Timer counts when the timer input signal is Low (0) and interrupts are generated on the rising edge of the timer input.

### CAPTURE/COMPARE Mode

- 0 = Counting is started on the first rising edge of the timer input signal. The current count is captured on subsequent rising edges of the timer input signal.
- 1 = Counting is started on the first falling edge of the timer input signal. The current count is captured on subsequent falling edges of the timer input signal.

## 96

# Watchdog Timer Reload Upper, High and Low Byte Registers

The Watchdog Timer Reload Upper, High and Low Byte (WDTU, WDTH, WDTL) registers, shown in Tables 60 through 62, form the 24-bit reload value that is loaded into the Watchdog Timer when a WDT instruction executes. This 24-bit value ranges across bits [23:0] to encompass the three bytes {WDTU[7:0], WDTH[7:0], WDTL[7:0]}. Writing to these registers sets the appropriate reload value; reading from these registers returns the current Watchdog Timer count value.

**Caution:** The 24-bit WDT reload value must not be set to a value less than 000004H.

| Bit                                                                                           | 7    | 6    | 5    | 4    | 3    | 2    | 1    | 0    |  |
|-----------------------------------------------------------------------------------------------|------|------|------|------|------|------|------|------|--|
| Field                                                                                         |      | WDTU |      |      |      |      |      |      |  |
| RESET                                                                                         | 0    | 0    | 0    | 0    | 0    | 0    | 0    | 0    |  |
| R/W                                                                                           | R/W* |  |
| Address                                                                                       | FF1H |      |      |      |      |      |      |      |  |
| Note: *A read returns the current WDT count value; a write sets the appropriate reload value. |      |      |      |      |      |      |      |      |  |

## Table 60. Watchdog Timer Reload Upper Byte Register (WDTU)

| Bit   | Description                                                               |
|-------|---------------------------------------------------------------------------|
| [7:0] | WDT Reload Upper Byte                                                     |
| WDTU  | Most significant byte (MSB), Bits[23:16], of the 24-bit WDT reload value. |

| Bit         | 7                                                                                             | 6    | 5    | 4    | 3    | 2    | 1    | 0    |  |
|-------------|-----------------------------------------------------------------------------------------------|------|------|------|------|------|------|------|--|
| Field       |                                                                                               | WDTH |      |      |      |      |      |      |  |
| RESET       | 0                                                                                             | 0    | 0    | 0    | 0    | 1    | 0    | 0    |  |
| R/W         | R/W*                                                                                          | R/W* | R/W* | R/W* | R/W* | R/W* | R/W* | R/W* |  |
| Address     | FF2H                                                                                          |      |      |      |      |      |      |      |  |
| Note: *A re | Note: *A read returns the current WDT count value; a write sets the appropriate reload value. |      |      |      |      |      |      |      |  |

| Bit   | Description                                             |
|-------|---------------------------------------------------------|
| [7:0] | WDT Reload High Byte                                    |
| WDTH  | Middle byte, bits[15:8] of the 24-bit WDT reload value. |

# Sample Time Register

The Sample Time Register, shown in Table 67, is used to program the length of active time for a sample after a conversion has begun by setting the START bit in the ADC Control Register. The number of system clock cycles required for the sample time varies from system to system, depending on the clock period used. The system designer should program this register to contain the number of system clocks required to meet a  $1 \mu s$  minimum sample time.

| Bit     | 7        | 6 | 5  | 4 | 3  | 2 | 1 | 0 |  |
|---------|----------|---|----|---|----|---|---|---|--|
| Field   | Reserved |   | ST |   |    |   |   |   |  |
| RESET   | 0        |   | 1  | 1 | 1  | 1 | 1 | 1 |  |
| R/W     | R/       | W |    |   | R/ | W |   |   |  |
| Address | F75H     |   |    |   |    |   |   |   |  |

| Table 67 | Sample Time | e (ADCST) |
|----------|-------------|-----------|
|----------|-------------|-----------|

| Bit         | Description                                                                           |
|-------------|---------------------------------------------------------------------------------------|
| [7:6]       | Reserved<br>These bits are reserved and must be programmed to 00.                     |
| [5:0]<br>ST | 0h–Fh = Sample-hold time in number of system clock periods to meet 1 $\mu$ s minimum. |

| Bit           | Description (Continued)                                                                                                                                                                                                                                                                                                                                                                              |
|---------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| [4]<br>XTLDIS | <ul> <li>State of the Crystal Oscillator at Reset</li> <li>This bit enables only the crystal oscillator. Selecting the crystal oscillator as the system clock must be performed manually.</li> <li>0 = The crystal oscillator is enabled during reset, resulting in longer reset timing.</li> <li>1 = The crystal oscillator is disabled during reset, resulting in shorter reset timing.</li> </ul> |
| [3:0]         | <b>Reserved</b> These bits are reserved and must be programmed to 1111.                                                                                                                                                                                                                                                                                                                              |

# **Trim Bit Address Space**

All available trim bit addresses and their functions are listed in Tables 83 through 90.

Because the minimum read time is much less than the write time, however, actual speed benefits are not always realized.

2. Use as few unique addresses as possible to optimize the impact of refreshing.



Figure 22. Interfacing the On-Chip Debugger's DBG Pin with an RS-232 Interface, #2 of 2

# **DEBUG Mode**

The operating characteristics of the devices in DEBUG Mode are:

- The eZ8 CPU fetch unit stops, idling the eZ8 CPU, unless directed by the OCD to execute specific instructions
- The system clock operates, unless the device is in STOP Mode
- All enabled on-chip peripherals operate, unless the device is in STOP Mode
- Automatically exits HALT Mode
- Constantly refreshes the Watchdog Timer, if enabled

## **Entering DEBUG Mode**

- The device enters DEBUG Mode after the eZ8 CPU executes a Breakpoint (BRK) instruction
- If the DBG pin is held low during the most recent clock cycle of system reset, the device enters DEBUG Mode on exiting system reset

## **Exiting DEBUG Mode**

The device exits DEBUG Mode following any of these operations:

- Clearing the DBGMODE bit in the OCD Control Register to 0
- Power-On Reset
- Voltage Brown-Out reset

```
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]
DBG \leftarrow Size[15:8]
DBG \leftarrow Size[7:0]
DBG \leftarrow 1-65536 data bytes
```

**Read Data Memory (0DH).** The read data memory command, reads from data memory. This command is equivalent to the LDE and LDEI instructions. Data can be read from 1 to 65536 bytes at a time (65536 bytes can be read by setting size to 0). If the device is not in DEBUG Mode, this command returns FFH for the data.

```
DBG \leftarrow 0DH
DBG \leftarrow Data Memory Address[15:8]
DBG \leftarrow Data Memory Address[7:0]
DBG \leftarrow Size[15:8]
DBG \leftarrow Size[7:0]
DBG \rightarrow 1-65536 data bytes
```

**Read Program Memory CRC (0EH).** The read program memory CRC command, computes and returns the cyclic redundancy check (CRC) of program memory using the 16-bit CRC-CCITT polynomial. If the device is not in DEBUG Mode, this command returns FFFFH for the CRC value. Unlike the other OCD read commands, there is a delay from issuing of the command until the OCD returns the data. The OCD reads program memory, calculates the CRC value and returns the result. The delay is a function of program mem-

149

## Table 96. OCD Control Register (OCDCTL)

| Bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 7                                                                                                                                                                                                                                                                                                                                                                                   | 6                                                                          | 5      | 4        | 3 | 2 | 1   | 0   |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------|--------|----------|---|---|-----|-----|
| Field                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | DBGMODE                                                                                                                                                                                                                                                                                                                                                                             | BRKEN                                                                      | DBGACK | Reserved |   |   | RST |     |
| RESET                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 0                                                                                                                                                                                                                                                                                                                                                                                   | 0                                                                          | 0      | 0        | 0 | 0 | 0   | 0   |
| R/W                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | R/W                                                                                                                                                                                                                                                                                                                                                                                 | R/W                                                                        | R/W    | R        | R | R | R   | R/W |
| Bit                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Descriptio                                                                                                                                                                                                                                                                                                                                                                          | on                                                                         |        |          |   |   |     |     |
| <ul> <li>[7] DEBUG Mode</li> <li>DBGMODE The device enters DEBUG Mode when this bit is 1. When in DEBUG Mode, the eZ8 CPU stops fetching new instructions. Clearing this bit causes the eZ8 CPU to restart. This bit is automatically set when a BRK instruction is decoded and breakpoints are enabled. If the Flash read protect option bit is enabled, this bit can only be cleared by resetting the device. It cannot be written to 0.</li> <li>0 = The Z8 Encore! F0830 Series device is operating in NORMAL Mode.</li> <li>1 = The Z8 Encore! F0830 Series device is in DEBUG Mode.</li> </ul> |                                                                                                                                                                                                                                                                                                                                                                                     |                                                                            |        |          |   |   |     |     |
| [6]<br>BRKEN                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Breakpoint Enable<br>This bit controls the behavior of the BRK instruction (opcode 00H). By default, breakpoints are disabled and the BRK instruction behaves similar to an NOP instruction. If this bit is 1 when a BRK instruction is decoded, the DBGMODE bit of the OCDCTL register is automatically set to 1.<br>0 = Breakpoints are disabled.<br>1 = Breakpoints are enabled. |                                                                            |        |          |   |   |     |     |
| [5]<br>DBGACK                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | <ul> <li>Debug Acknowledge</li> <li>This bit enables the debug acknowledge feature. If this bit is set to 1, the OCD sends a Debug acknowledge character (FFH) to the host when a breakpoint occurs.</li> <li>0 = Debug acknowledge is disabled.</li> <li>1 = Debug acknowledge is enabled.</li> </ul>                                                                              |                                                                            |        |          |   |   |     |     |
| [4:1]                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Reserved<br>These bits                                                                                                                                                                                                                                                                                                                                                              | <b>Reserved</b><br>These bits are reserved and must be programmed to 0000. |        |          |   |   |     |     |
| [0]<br>RST                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | <ul> <li>Reset</li> <li>Setting this bit to 1 resets the Z8F04xA family device. The device goes through a normal Power-On Reset sequence with the exception that the On-Chip Debugger is not reset. This bit is automatically cleared to 0 at the end of the reset sequence.</li> <li>0 = No effect.</li> <li>1 = Reset the Flash read protect option bit device.</li> </ul>        |                                                                            |        |          |   |   |     |     |

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.





Figure 24. Oscillator Control Clock Switching Flow Chart

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

Figure 26 displays a recommended configuration for connection with an external resistorcapacitor (RC) network.



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

An external resistance value of  $45 \text{ k}\Omega$  is recommended for oscillator operation with an external RC network. The minimum resistance value to ensure operation is  $40 \text{ 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)}$ 

Figure 27 displays the typical (3.3V and 25°C) oscillator frequency as a function of the capacitor (C in pF) employed in the RC network assuming a 45 k $\Omega$  external resistor. For very small values of C, the parasitic capacitance of the oscillator X<sub>IN</sub> pin and the printed circuit board should be included in the estimation of the oscillator frequency.

It is possible to operate the RC oscillator using only the parasitic capacitance of the package and printed circuit board. To minimize sensitivity to external parasitics, external capacitance values in excess of 20pF are recommended. 159

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





Figure 27. Typical RC Oscillator Frequency as a Function of External Capacitance with a 45 k $\Omega$  Resistor

**Caution:** When using the external RC OSCILLATOR Mode, the oscillator can stop oscillating if the power supply drops below 2.7V but before it drops to the Voltage Brown-Out threshold. The oscillator resumes oscillation when the supply voltage exceeds 2.7V.

160

4000

## Table 105. Arithmetic Instructions (Continued)

| Mnemonic | Operands | Instruction                                   |
|----------|----------|-----------------------------------------------|
| 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 106. Bit Manipulation Instructions

| Mnemonic | Operands    | Instruction                                             |
|----------|-------------|---------------------------------------------------------|
| BCLR     | bit, dst    | Bit Clear                                               |
| BIT      | p, bit, dst | Bit Set or Clear                                        |
| BSET     | bit, dst    | Bit Set                                                 |
| BSWAP    | dst         | Bit Swap                                                |
| CCF      | —           | Complement Carry Flag                                   |
| RCF      | —           | Reset Carry Flag                                        |
| SCF      | —           | Set Carry Flag                                          |
| ТСМ      | dst, src    | Test Complement Under Mask                              |
| ТСМХ     | dst, src    | Test Complement Under Mask using Extended<br>Addressing |
| ТМ       | dst, src    | Test Under Mask                                         |
| TMX      | dst, src    | Test Under Mask using Extended Addressing               |

## Table 107. Block Transfer Instructions

| Mnemonic | Operands | Instruction                                                             |
|----------|----------|-------------------------------------------------------------------------|
| LDCI     | dst, src | Load Constant to/from Program Memory and Auto-<br>Increment Addresses   |
| LDEI     | dst, src | Load External Data to/from Data Memory and Auto-<br>Increment Addresses |

## 195

## General Purpose I/O Port Input Data Sample Timing

Figure 33 displays timing of the GPIO port input sampling. The input value on a GPIO port pin is sampled on the rising edge of the system clock. The port value is available to the eZ8 CPU on the second rising clock edge following the change of the port value.



## Figure 33. Port Input Sample Timing

## Table 124. GPIO Port Input Timing

|                     |                                                                                                    | Delay (ns) |         |
|---------------------|----------------------------------------------------------------------------------------------------|------------|---------|
| Parameter           | Abbreviation                                                                                       | Minimum    | Maximum |
| T <sub>S_PORT</sub> | Port Input Transition to X <sub>IN</sub> Rise Setup Time (not pictured)                            | 5          | -       |
| T <sub>H_PORT</sub> | X <sub>IN</sub> Rise to Port Input Transition Hold Time (not pictured)                             | 0          | -       |
| T <sub>SMR</sub>    | GPIO port pin pulse width to ensure Stop Mode Recovery (for GPIO port pins enabled as SMR sources) | 1µs        |         |

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

read program memory CRC (0EH) 147 read register (09H) 146 read runtime counter (03H) 145 step instruction (10H) 148 stuff instruction (11H) 148 write data memory (0CH) 147 write OCD control register (04H) 145 write program counter (06H) 146 write program memory (0AH) 146 write register (08H) 146 on-chip debugger (OCD) 139 on-chip debugger signals 12 on-chip oscillator 157 one-shot mode 89 opcode map abbreviations 181 cell description 180 first 182 second after 1FH 183 operation 100 current measurement 99 voltage measurement timing diagram 100 Operational Description 21, 30, 33, 53, 68, 92, 98, 106, 108, 124, 134, 139, 151, 157, 161 OR 169 ordering information 200 ORX 169 oscillator signals 12

# Ρ

p 164
Packaging 199
part selection guide 2
PC 165
peripheral AC and DC electrical characteristics 190
pin characteristics 13
Pin Descriptions 7
polarity 164
POP 168
pop using extended addressing 168
POPX 168
port availability, device 33
port input timing (GPIO) 195

port output timing, GPIO 196 power supply signals 12 power-on reset (POR) 23 program control instructions 169 program memory 15 PUSH 168 push using extended addressing 168 PUSHX 168 PWM mode 89, 90 PxADDR register 40, 222, 223, 224, 225 PxCTL register 41, 222, 223, 224, 225

# R

R 165 r 164 RA register address 165 RCF 167, 168 register 165 flash control (FCTL) 119, 126, 127, 228 flash high and low byte (FFREQH and FRE-EQL) 123 flash page select (FPS) 121, 122 flash status (FSTAT) 120 GPIO port A-H address (PxADDR) 40, 222, 223, 224, 225 GPIO port A-H alternate function sub-registers 42 GPIO port A-H control address (PxCTL) 41, 222, 223, 224, 225 GPIO port A-H data direction sub-registers 41 OCD control 148 OCD status 150 watch-dog timer control (WDTCTL) 95, 107, 154, 217, 218, 226 watchdog timer control (WDTCTL) 29 watch-dog timer reload high byte (WDTH) 227 watchdog timer reload high byte (WDTH) 96 watch-dog timer reload low byte (WDTL) 227 watchdog timer reload low byte (WDTL) 97 watch-dog timer reload upper byte (WDTU) 227

236