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 - Microcontrollers</u>" | Details | | |----------------------------|-----------------------------------------------------------| | Product Status | Obsolete | | Core Processor | eZ8 | | Core Size | 8-Bit | | Speed | 20MHz | | Connectivity | IrDA, UART/USART | | Peripherals | Brown-out Detect/Reset, LED, LVD, POR, PWM, WDT | | Number of I/O | 17 | | Program Memory Size | 8KB (8K x 8) | | Program Memory Type | FLASH | | EEPROM Size | - | | RAM Size | 1K x 8 | | Voltage - Supply (Vcc/Vdd) | 2.7V ~ 3.6V | | Data Converters | - | | Oscillator Type | Internal | | Operating Temperature | -40°C ~ 105°C (TA) | | Mounting Type | Surface Mount | | Package / Case | 20-SSOP (0.209", 5.30mm Width) | | Supplier Device Package | - | | Purchase URL | https://www.e-xfl.com/product-detail/zilog/z8f081ahh020eg | Warning: DO NOT USE THIS PRODUCT IN LIFE SUPPORT SYSTEMS. #### LIFE SUPPORT POLICY ZILOG'S PRODUCTS ARE NOT AUTHORIZED FOR USE AS CRITICAL COMPONENTS IN LIFE SUPPORT DEVICES OR SYSTEMS WITHOUT THE EXPRESS PRIOR WRITTEN APPROVAL OF THE PRESIDENT AND GENERAL COUNSEL OF ZILOG CORPORATION. #### As used herein Life support devices or systems are devices which (a) are intended for surgical implant into the body, or (b) support or sustain life and whose failure to perform when properly used in accordance with instructions for use provided in the labeling can be reasonably expected to result in a significant injury to the user. A critical component is any component in a life support device or system whose failure to perform can be reasonably expected to cause the failure of the life support device or system or to affect its safety or effectiveness. #### **Document Disclaimer** ©2012 Zilog, Inc. All rights reserved. Information in this publication concerning the devices, applications, or technology described is intended to suggest possible uses and may be superseded. ZILOG, INC. DOES NOT ASSUME LIABILITY FOR OR PROVIDE A REPRESENTATION OF ACCURACY OF THE INFORMATION, DEVICES, OR TECHNOLOGY DESCRIBED IN THIS DOCUMENT. ZILOG ALSO DOES NOT ASSUME LIABILITY FOR INTELLECTUAL PROPERTY INFRINGEMENT RELATED IN ANY MANNER TO USE OF INFORMATION, DEVICES, OR TECHNOLOGY DESCRIBED HEREIN OR OTHERWISE. The information contained within this document has been verified according to the general principles of electrical and mechanical engineering. Z8, Z8 Encore! and Z8 Encore! XP are trademarks or registered trademarks of Zilog, Inc. All other product or service names are the property of their respective owners. # **Table of Contents** | Revision History | |---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | List of Figuresx | | List of Tablesxii | | Overview Features Part Selection Guide Block Diagram CPU and Peripheral Overview 10-Bit Analog-to-Digital Converter Low-Power Operational Amplifier Internal Precision Oscillator Temperature Sensor Analog Comparator External Crystal Oscillator External Crystal Oscillator Low Voltage Detector On-Chip Debugger Universal Asynchronous Receiver/Transmitter Timers General-Purpose Input/Output Direct LED Drive Flash Controller Non-Volatile Data Storage Interrupt Controller Reset Controller | | Pin Description8Available Packages8Pin Configurations8Signal Descriptions10Pin Characteristics12 | | Address Space 15 Register File 15 Program Memory 15 Data Memory 17 Flash Information Area 17 | | Register Man 18 | | LED Drive Level Low Register | . 54 | |----------------------------------------------------------|------| | GPIO Mode Interrupt Controller | . 55 | | Interrupt Vector Listing | . 55 | | Architecture | . 57 | | Operation | . 57 | | Master Interrupt Enable | . 57 | | Interrupt Vectors and Priority | . 58 | | Interrupt Assertion | . 58 | | Software Interrupt Assertion | . 59 | | Watchdog Timer Interrupt Assertion | . 59 | | Interrupt Control Register Definitions | | | Interrupt Request 0 Register | 60 | | Interrupt Request 1 Register | 61 | | Interrupt Request 2 Register | | | IRQ0 Enable High and Low Bit Registers | . 62 | | IRQ1 Enable High and Low Bit Registers | | | IRQ2 Enable High and Low Bit Registers | | | Interrupt Edge Select Register | | | Shared Interrupt Select Register | | | Interrupt Control Register | 69 | | Timers | . 70 | | Architecture | . 70 | | Operation | . 71 | | Timer Operating Modes | . 71 | | Reading the Timer Count Values | . 84 | | Timer Pin Signal Operation | . 84 | | Timer Control Register Definitions | 85 | | Timer 0–1 Control Registers | 85 | | Timer 0–1 High and Low Byte Registers | . 89 | | Timer Reload High and Low Byte Registers | | | Timer 0–1 PWM High and Low Byte Registers | . 92 | | Watchdog Timer | 93 | | Operation | | | Watchdog Timer Refresh | | | Watchdog Timer Time-Out Response | | | Watchdog Timer Reload Unlock Sequence | | | Watchdog Timer Calibration | | | Watchdog Timer Control Register Definitions | | | Watchdog Timer Control Register | | | Watchdog Timer Reload Upper, High and Low Byte Registers | | | | | - Up to 8 ports capable of direct LED drive with no current limit resistor required - On-Chip Debugger (OCD) - Voltage Brown-Out (VBO) protection - Programmable low battery detection (LVD) (8-pin devices only) - Bandgap generated precision voltage references available for the ADC, comparator, VBO and LVD - Power-On Reset (POR) - 2.7 V to 3.6 V operating voltage - 8-, 20- and 28-pin packages - $0^{\circ}$ C to $+70^{\circ}$ C and $-40^{\circ}$ C to $+105^{\circ}$ C for operating temperature ranges ## **Part Selection Guide** Table 1 identifies the basic features and package styles available for each device within the Z8 Encore! XP F082A Series product line. Table 1. Z8 Encore! XP F082A Series Family Part Selection Guide | Part<br>Number | Flash<br>(KB) | RAM<br>(B) | NVDS <sup>1</sup><br>(B) | I/O | Comparator | Advanced<br>Analog <sup>2</sup> | ADC<br>Inputs | Packages | |----------------|---------------|------------|--------------------------|------|------------|---------------------------------|---------------|--------------------| | Z8F082A | 8 | 1024 | 0 | 6–23 | Yes | Yes | 4–8 | 8-, 20- and 28-pin | | Z8F081A | 8 | 1024 | 0 | 6–25 | Yes | No | 0 | 8-, 20- and 28-pin | | Z8F042A | 4 | 1024 | 128 | 6–23 | Yes | Yes | 4–8 | 8-, 20- and 28-pin | | Z8F041A | 4 | 1024 | 128 | 6–25 | Yes | No | 0 | 8-, 20- and 28-pin | | Z8F022A | 2 | 512 | 64 | 6–23 | Yes | Yes | 4–8 | 8-, 20- and 28-pin | | Z8F021A | 2 | 512 | 64 | 6–25 | Yes | No | 0 | 8-, 20- and 28-pin | | Z8F012A | 1 | 256 | 16 | 6–23 | Yes | Yes | 4–8 | 8-, 20- and 28-pin | | Z8F011A | 1 | 256 | 16 | 6–25 | Yes | No | 0 | 8-, 20- and 28-pin | ### Notes: - 1. Non-volatile data storage. - 2. Advanced Analog includes ADC, temperature sensor and low-power operational amplifier. Table 7. Register File Address Map (Continued) | Address (Hex) | Address (Hex) Register Description | | Reset (Hex) | Page | |------------------|---------------------------------------|---------|-------------|-------------| | FD9 | Port C Control | PCCTL | 00 | <u>46</u> | | FDA | Port C Input Data | PCIN | XX | <u>46</u> | | FDB | Port C Output Data | PCOUT | 00 | <u>46</u> | | GPIO Port D | | | | | | FDC | Port D Address | PDADDR | 00 | <u>44</u> | | FDD | Port D Control | PDCTL | 00 | <u>46</u> | | FDE | Reserved | _ | XX | | | FDF | Port D Output Data | PDOUT | 00 | <u>46</u> | | FE0-FEF | Reserved | _ | XX | | | Watchdog Time | r (WDT) | | | | | FF0 | Reset Status (Read-only) | RSTSTAT | X0 | <u>29</u> | | | Watchdog Timer Control (Write-only) | WDTCTL | N/A | <u>96</u> | | FF1 | Watchdog Timer Reload Upper Byte | WDTU | 00 | <u>97</u> | | FF2 | Watchdog Timer Reload High Byte | WDTH | 04 | <u>97</u> | | FF3 | Watchdog Timer Reload Low Byte | WDTL | 00 | <u>98</u> | | FF4–FF5 Reserved | | _ | XX | | | Trim Bit Contro | I | | | | | FF6 | Trim Bit Address | TRMADR | 00 | <u>161</u> | | FF7 | Trim Bit Data | TRMDR | 00 | <u>162</u> | | Flash Memory C | Controller | | | | | FF8 | Flash Control | FCTL | 00 | <u>155</u> | | FF8 | Flash Status | FSTAT | 00 | <u>155</u> | | FF9 | Flash Page Select | FPS | 00 | <u>156</u> | | | Flash Sector Protect | FPROT | 00 | <u>157</u> | | FFA | Flash Programming Frequency High Byte | FFREQH | 00 | <u>158</u> | | FFB | Flash Programming Frequency Low Byte | FFREQL | 00 | <u>158</u> | | eZ8 CPU | | | | | | FFC | Flags | _ | XX | See | | FFD | Register Pointer | RP | XX | foot- | | FFE | Stack Pointer High Byte | SPH | XX | -note 2 | | FFF | Stack Pointer Low Byte | SPL | XX | <del></del> | #### Notes: - 1. XX = Undefined. - 2. Refer to the <u>eZ8 CPU Core User Manual (UM0128)</u>. # General-Purpose Input/Output The Z8 Encore! XP F082A Series products support a maximum of 25 port pins (Ports A–D) for general-purpose input/output (GPIO) operations. Each port contains control and data registers. The GPIO control registers determine data direction, open-drain, output drive current, programmable pull-ups, Stop Mode Recovery functionality and alternate pin functions. Each port pin is individually programmable. In addition, the Port C pins are capable of direct LED drive at programmable drive strengths. # **GPIO Port Availability By Device** Table 14 lists the port pins available with each device and package type. Table 14. Port Availability by Device and Package Type | Devices | Package | ADC | Port A | Port B | Port C | Port D | Total I/O | |------------------------------------------------------------------------------------------------------------------------------------------|---------|-----|--------|--------|--------|--------|-----------| | Z8F082ASB, Z8F082APB, Z8F082AQB<br>Z8F042ASB, Z8F042APB, Z8F042AQB<br>Z8F022ASB, Z8F022APB, Z8F022AQB<br>Z8F012ASB, Z8F012APB, Z8F012AQB | 8-pin | Yes | [5:0] | No | No | No | 6 | | Z8F081ASB, Z8F081APB, Z8F081AQB<br>Z8F041ASB, Z8F041APB, Z8F041AQB<br>Z8F021ASB, Z8F021APB, Z8F021AQB<br>Z8F011ASB, Z8F011APB, Z8F011AQB | 8-pin | No | [5:0] | No | No | No | 6 | | Z8F082APH, Z8F082AHH, Z8F082ASH<br>Z8F042APH, Z8F042AHH, Z8F042ASH<br>Z8F022APH, Z8F022AHH, Z8F022ASH<br>Z8F012APH, Z8F012AHH, Z8F012ASH | 20-pin | Yes | [7:0] | [3:0] | [3:0] | [0] | 17 | | Z8F081APH, Z8F081AHH, Z8F081ASH<br>Z8F041APH, Z8F041AHH, Z8F041ASH<br>Z8F021APH, Z8F021AHH, Z8F021ASH<br>Z8F011APH, Z8F011AHH, Z8F011ASH | 20-pin | No | [7:0] | [3:0] | [3:0] | [0] | 17 | | Z8F082APJ, Z8F082ASJ, Z8F082AHJ<br>Z8F042APJ, Z8F042ASJ, Z8F042AHJ<br>Z8F022APJ, Z8F022ASJ, Z8F022AHJ<br>Z8F012APJ, Z8F012ASJ, Z8F012AHJ | 28-pin | Yes | [7:0] | [5:0] | [7:0] | [0] | 23 | | Z8F081APJ, Z8F081ASJ, Z8F081AHJ<br>Z8F041APJ, Z8F041ASJ, Z8F041AHJ<br>Z8F021APJ, Z8F021ASJ, Z8F021AHJ<br>Z8F011APJ, Z8F011ASJ, Z8F011AHJ | 28-pin | No | [7:0] | [7:0] | [7:0] | [0] | 25 | - Set the initial logic level (High or Low) for the Timer Output alternate function, if appropriate - 2. Write to the Timer High and Low Byte registers to set the starting count value. - 3. Write to the Timer Reload High and Low Byte registers to set the Compare value. - 4. Enable the timer interrupt, if appropriate and set the timer interrupt priority by writing to the relevant interrupt registers. - 5. If using the Timer Output function, configure the associated GPIO port pin for the Timer Output alternate function. - 6. Write to the Timer Control Register to enable the timer and initiate counting. In COMPARE Mode, the system clock always provides the timer input. The Compare time can be calculated by the following equation: $$\begin{array}{ll} \text{COMPARE Mode Time (s) } = & \frac{\text{(Compare Value - Start Value)} \times \text{Prescale}}{\text{System Clock Frequency (Hz)}} \\ \end{array}$$ #### **GATED Mode** In GATED Mode, the timer counts only when the Timer Input signal is in its active state (asserted), as determined by the TPOL bit in the Timer Control Register. When the Timer Input signal is asserted, counting begins. A timer interrupt is generated when the Timer Input signal is deasserted or a timer reload occurs. To determine if a Timer Input signal deassertion generated the interrupt, read the associated GPIO input value and compare to the value stored in the TPOL bit. The timer counts up to the 16-bit reload value stored in the Timer Reload High and Low Byte registers. The timer input is the system clock. When reaching the reload value, the timer generates an interrupt, the count value in the Timer High and Low Byte registers is reset to 0001H and counting resumes (assuming the Timer Input signal remains asserted). Also, if the Timer Output alternate function is enabled, the Timer Output pin changes state (from Low to High or from High to Low) at timer reset. Observe the following steps for configuring a timer for GATED Mode and initiating the count: - 1. Write to the Timer Control Register to: - Disable the timer | Bit | Description (Continued) | |----------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | [5:3]<br>PRES | Prescale value The timer input clock is divided by 2 <sup>PRES</sup> , where PRES can be set from 0 to 7. The prescaler is reset each time the Timer is disabled. This reset ensures proper clock division each time the Timer is restarted. 000 = Divide by 1. 001 = Divide by 2. 010 = Divide by 4. 011 = Divide by 8. 100 = Divide by 16. 101 = Divide by 32. 110 = Divide by 64. 111 = Divide by 128. | | [2:0]<br>TMODE | Timer Mode This field, along with the TMODEHI bit in the TxCTL0 Register, determines the operating mode of the timer. TMODEHI is the most significant bit of the Timer mode selection value. The entire operating mode bits are expressed as {TMODEHI, TMODE[2:0]}. The TMODEHI is bit 7 of the TxCTL0 Register while TMODE[2:0] is the lower 3 bits of the TxCTL1 Register. 0000 = ONE-SHOT Mode. 0001 = CONTINUOUS Mode. 0010 = COUNTER Mode. 0111 = PWM SINGLE OUTPUT Mode. 0110 = GAPTURE Mode. 0111 = CAPTURE/COMPARE Mode. 1010 = PWM DUAL OUTPUT Mode. 1001 = CAPTURE RESTART Mode. 1010 = COMPARATOR COUNTER Mode. | # Timer 0-1 High and Low Byte Registers The Timer 0–1 High and Low Byte (TxH and TxL) registers, shown in Tables 52 and 53, contain the current 16-bit timer count value. When the timer is enabled, a read from TxH causes the value in TxL to be stored in a temporary holding register. A read from TxL always returns this temporary register when the timers are enabled. When the timer is disabled, reads from TxL read the register directly. Writing to the Timer High and Low Byte registers while the timer is enabled is not recommended. There are no temporary holding registers available for write operations, so simultaneous 16-bit writes are not possible. If either the Timer High or Low Byte registers are written during counting, the 8-bit written value is placed in the counter (High or Low Byte) at the next clock edge. The counter continues counting from the new value. **Table 94. LVD Trim Values** | | 1.VD TI 1 - 1.1 (V) | | |----------|---------------------------|-----------------------| | LVD TRIM | LVD Threshold (V) Typical | Description | | 00000 | 3.60 | Maximum LVD threshold | | | | Maximum EVD timeshold | | 00001 | 3.55 | | | 00010 | 3.50 | | | 00011 | 3.45 | | | 00100 | 3.40 | | | 00101 | 3.35 | | | 00110 | 3.30 | | | 00111 | 3.25 | | | 01000 | 3.20 | | | 01001 | 3.15 | | | 01010 | 3.10 | Default on Reset | | 01011 | 3.05 | | | 01100 | 3.00 | | | 01101 | 2.95 | | | 01110 | 2.90 | | | 01111 | 2.85 | | | 10000 | 2.80 | | | 10001 | 2.75 | | | 10010 | 2.70 | | | 10011 | 2.70 | | | to | to | | | 11111 | 1.65 | Minimum LVD threshold | ### **ADC Calibration Data** **Table 96. ADC Calibration Bits** | Bit | 7 | 6 | 5 | 4 | 3 | 2 | 1 | 0 | |-----------|-------------------------------------------------|-----|-----|-----|-----|-----|-----|-----| | Field | ADC_CAL | | | | | | | | | RESET | U | U | U | U | U | U | U | U | | R/W | Address | ress Information Page Memory 0060H–007DH | | | | | | | | | Note: U = | Note: U = Unchanged by Reset. R/W = Read/Write. | | | | | | | | | Bit | Description | |---------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | [7:0] | Analog-to-Digital Converter Calibration Values | | ADC_CAL | Contains factory-calibrated values for ADC gain and offset compensation. Each of the ten supported modes has one byte of offset calibration and two bytes of gain calibration. These values are read by the software to compensate ADC measurements as described in the <a href="Software Compensation Procedure Using Factory Calibration Data">Software Compensation Procedure Using Factory Calibration Data</a> section on page 129. The location of each calibration byte is provided in Table 97. | **Table 97. ADC Calibration Data Location** | Info Page | Memory | | | | |-----------|---------|--------------------|--------------------------|----------------| | Address | Address | Compensation Usage | ADC Mode | Reference Type | | 60 | FE60 | Offset | Single-Ended Unbuffered | Internal 2.0 V | | 08 | FE08 | Gain High Byte | Single-Ended Unbuffered | Internal 2.0 V | | 09 | FE09 | Gain Low Byte | Single-Ended Unbuffered | Internal 2.0 V | | 63 | FE63 | Offset | Single-Ended Unbuffered | Internal 1.0 V | | 0A | FE0A | Gain High Byte | Single-Ended Unbuffered | Internal 1.0 V | | 0B | FE0B | Gain Low Byte | Single-Ended Unbuffered | Internal 1.0 V | | 66 | FE66 | Offset | Single-Ended Unbuffered | External 2.0 V | | 0C | FE0C | Gain High Byte | Single-Ended Unbuffered | External 2.0 V | | 0D | FE0D | Gain Low Byte | Single-Ended Unbuffered | External 2.0 V | | 69 | FE69 | Offset | Single-Ended 1x Buffered | Internal 2.0 V | | 0E | FE0E | Gain High Byte | Single-Ended 1x Buffered | Internal 2.0 V | | 0F | FE0F | Gain Low Byte | Single-Ended 1x Buffered | Internal 2.0 V | | 6C | FE6C | Offset | Single-Ended 1x Buffered | External 2.0 V | | 10 | FE10 | Gain High Byte | Single-Ended 1x Buffered | External 2.0 V | | 11 | FE11 | Gain Low Byte | Single-Ended 1x Buffered | External 2.0 V | | 6F | FE6F | Offset | Differential Unbuffered | Internal 2.0 V | When selecting a new clock source, the system clock oscillator failure detection circuitry and the Watchdog Timer oscillator failure circuitry must be disabled. If SOFEN 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 OSCCTL 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** Should an oscillator or timer fail, there are methods of recovery, as this section describes. ### **System Clock 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 selected as the system clock oscillator. It is also unavailable if the Watchdog Timer oscillator is disabled, though it is not necessary to enable the Watchdog Timer reset function (see the Watchdog Timer chapter on page 93). The primary oscillator failure detection circuitry asserts if the system clock frequency drops below $1\,\mathrm{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 (SOFEN must be deasserted in the OSCCTL Register). ### **Watchdog Timer Failure** In the event of a Watchdog Timer oscillator failure, a similar nonmaskable interrupt-like 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 system clock 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 ## Oscillator Operation with an External RC Network Figure 28 displays a recommended configuration for connection with an external resistor-capacitor (RC) network. Figure 28. Connecting the On-Chip Oscillator to an External RC Network An external resistance value of $45\,\mathrm{k}\Omega$ is recommended for oscillator operation with an external RC network. The minimum resistance value to ensure operation is $40\,\mathrm{k}\Omega$ . The typical oscillator frequency can be estimated from the values of the resistor (R in $\mathrm{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 29 displays the typical (3.3 V 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_{IN}$ pin and the printed circuit board must 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. Register file size varies depending on the device type. See the device-specific Z8 Encore! XP Product Specification to determine the exact register file range available. ### **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 a notational shorthand that is described in Table 118. **Table 118. Notational Shorthand** | Notation | Description | Operand | Range | |----------|--------------------------------|---------|-------------------------------------------------------------------------------------------------------------------------| | b | Bit | b | b represents a value from 0 to 7 (000B to 111B). | | СС | Condition code | _ | Refer to the Condition Codes section in the <u>eZ8</u> CPU Core User Manual (UM0128). | | DA | Direct address | Addrs | Represents a number in the range 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. | | Ir | 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. | | R | Register | Reg | Reg. represents a number in the range of 00H to FFH. | | RA | Relative address | Х | X represents an index in the range of +127 to – 128 which is an offset relative to the address of the next instruction. | | rr | Working register pair | RRp | p = 0, 2, 4, 6, 8, 10, 12, or 14. | | RR | Register pair | Reg | Reg. represents an even number in the range of 00H to FEH. | **Table 126. Program Control Instructions** | Mnemonic | Operands | Instruction | |----------|-----------------|-------------------------------| | BRK | _ | On-Chip Debugger Break | | BTJ | p, bit, src, DA | Bit Test and Jump | | BTJNZ | bit, src, DA | Bit Test and Jump if Non-Zero | | BTJZ | bit, src, DA | Bit Test and Jump if Zero | | CALL | dst | Call Procedure | | DJNZ | dst, src, RA | Decrement and Jump Non-Zero | | IRET | _ | Interrupt Return | | JP | dst | Jump | | JP cc | dst | Jump Conditional | | JR | DA | Jump Relative | | JR cc | DA | Jump Relative Conditional | | RET | _ | Return | | TRAP | vector | Software Trap | | | | | Table 127. Rotate and Shift Instructions | Mnemonic | Operands | Instruction | |----------|----------|----------------------------| | BSWAP | dst | Bit Swap | | RL | dst | Rotate Left | | RLC | dst | Rotate Left through Carry | | RR | dst | Rotate Right | | RRC | dst | Rotate Right through Carry | | SRA | dst | Shift Right Arithmetic | | SRL | dst | Shift Right Logical | | SWAP | dst | Swap Nibbles | Table 139. Analog-to-Digital Converter Electrical Characteristics and Timing $V_{DD} = 3.0 \text{ V to } 3.6 \text{ V}$ $T_A = 0^{\circ}\text{C to } +70^{\circ}\text{C}$ (unless otherwise stated) | | | • | | , | | | | |--------------------------|-----------------------------------------------------------|------------|--------------|------------|--------------------------------|-------------------------------------------------------------------------------------|--| | Symbol | Parameter | Minimum | Typical | Maximum | Units | Conditions | | | | Resolution | 10 | | _ | bits | | | | | Differential Nonlinearity (DNL) | -1.0 | - | 1.0 | LSB <sup>3</sup> | External $V_{REF}$ = 2.0 V;<br>$R_S \leftarrow 3.0 \text{ k}\Omega$ | | | | Integral Nonlinearity (INL) | -3.0 | - | 3.0 | LSB <sup>3</sup> | External $V_{REF}$ = 2.0 V;<br>$R_S \leftarrow 3.0 \text{ k}\Omega$ | | | | Offset Error with Calibration | | <u>+</u> 1 | | LSB <sup>3</sup> | | | | | Absolute Accuracy with Calibration | | <u>+</u> 3 | | LSB <sup>3</sup> | | | | V <sub>REF</sub> | Internal Reference Voltage | 1.0<br>2.0 | 1.1<br>2.2 | 1.2<br>2.4 | V | REFSEL=01<br>REFSEL=10 | | | V <sub>REF</sub> | Internal Reference Variation with Temperature | | <u>+</u> 1.0 | | % | Temperature variation with V <sub>DD</sub> = 3.0 | | | V <sub>REF</sub> | Internal Reference Voltage Variation with V <sub>DD</sub> | | <u>+</u> 0.5 | | % | Supply voltage variation with T <sub>A</sub> = 30°C | | | R <sub>RE-</sub><br>FOUT | Reference Buffer Output Impedance | | 850 | | W | When the internal reference is buffered and driven out to the VREF pin (REFOUT = 1) | | | | Single-Shot Conversion<br>Time | - | 5129 | - | Sys-<br>tem<br>clock<br>cycles | All measurements but temperature sensor | | | | | | 10258 | | | Temperature sensor measurement | | ### Notes: - 1. Analog source impedance affects the ADC offset voltage (because of pin leakage) and input settling time. - 2. Devices are factory calibrated at $V_{DD} = 3.3 \,\text{V}$ and $T_A = +30 \,^{\circ}\text{C}$ , so the ADC is maximally accurate under these conditions. - 3. LSBs are defined assuming 10-bit resolution. - 4. This is the maximum recommended resistance seen by the ADC input pin. - 5. The input impedance is inversely proportional to the system clock frequency. ### **UART Timing** Figure 37 and Table 146 provide timing information for UART pins for the case where CTS is used for flow control. The CTS to DE assertion delay (T1) assumes the Transmit Data Register has been loaded with data prior to CTS assertion. Figure 37. UART Timing With CTS **Table 146. UART Timing With CTS** | | | Delay (ns) | | | | | | |----------------|----------------------------------------------------|----------------------------|--------------------------------------------|--|--|--|--| | Parameter | Abbreviation | Minimum | Maximum | | | | | | UART | | | | | | | | | T <sub>1</sub> | CTS Fall to DE output delay | 2 * X <sub>IN</sub> period | 2 * X <sub>IN</sub> period +<br>1 bit time | | | | | | T <sub>2</sub> | DE assertion to TXD falling edge (start bit) delay | = | ± 5 | | | | | | T <sub>3</sub> | End of Stop Bit(s) to DE deassertion delay | = | ± 5 | | | | | Table 148. Z8 Encore! XP F082A Series Ordering Matrix | Part Number | Flash | RAM | NVDS | I/O Lines | Interrupts | 16-Bit Timers w/PWM | 10-Bit A/D Channels | UART with IrDA | Comparator | <b>Temperature Sensor</b> | Description | |---------------------|-----------|---------|---------|-----------|------------|---------------------|---------------------|----------------|------------|---------------------------|---------------------| | Z8 Encore! XP F082A | Series | with 4 | KB Flas | h, 10 | -Bit / | Analo | og-to | -Digi | tal Co | onve | erter | | Standard Temperatur | re: 0°C t | :o 70°C | ; | | | | | | | | | | Z8F042APB020SG | 4 KB | 1KB | 128 B | 6 | 14 | 2 | 4 | 1 | 1 | 1 | PDIP 8-pin package | | Z8F042AQB020SG | 4 KB | 1KB | 128 B | 6 | 14 | 2 | 4 | 1 | 1 | 1 | QFN 8-pin package | | Z8F042ASB020SG | 4 KB | 1KB | 128 B | 6 | 14 | 2 | 4 | 1 | 1 | 1 | SOIC 8-pin package | | Z8F042ASH020SG | 4 KB | 1KB | 128 B | 17 | 20 | 2 | 7 | 1 | 1 | 1 | SOIC 20-pin package | | Z8F042AHH020SG | 4 KB | 1KB | 128 B | 17 | 20 | 2 | 7 | 1 | 1 | 1 | SSOP 20-pin package | | Z8F042APH020SG | 4 KB | 1KB | 128 B | 17 | 20 | 2 | 7 | 1 | 1 | 1 | PDIP 20-pin package | | Z8F042ASJ020SG | 4 KB | 1KB | 128 B | 23 | 20 | 2 | 8 | 1 | 1 | 1 | SOIC 28-pin package | | Z8F042AHJ020SG | 4 KB | 1KB | 128 B | 23 | 20 | 2 | 8 | 1 | 1 | 1 | SSOP 28-pin package | | Z8F042APJ020SG | 4 KB | 1KB | 128 B | 23 | 20 | 2 | 8 | 1 | 1 | 1 | PDIP 28-pin package | | Extended Temperatu | re: –40° | C to 10 | )5°C | | | | | | | | | | Z8F042APB020EG | 4 KB | 1KB | 128 B | 6 | 14 | 2 | 4 | 1 | 1 | 1 | PDIP 8-pin package | | Z8F042AQB020EG | 4 KB | 1KB | 128 B | 6 | 14 | 2 | 4 | 1 | 1 | 1 | QFN 8-pin package | | Z8F042ASB020EG | 4 KB | 1KB | 128 B | 6 | 14 | 2 | 4 | 1 | 1 | 1 | SOIC 8-pin package | | Z8F042ASH020EG | 4 KB | 1KB | 128 B | 17 | 20 | 2 | 7 | 1 | 1 | 1 | SOIC 20-pin package | | Z8F042AHH020EG | 4 KB | 1KB | 128 B | 17 | 20 | 2 | 7 | 1 | 1 | 1 | SSOP 20-pin package | | Z8F042APH020EG | 4 KB | 1KB | 128 B | 17 | 20 | 2 | 7 | 1 | 1 | 1 | PDIP 20-pin package | | Z8F042ASJ020EG | 4 KB | 1KB | 128 B | 23 | 20 | 2 | 8 | 1 | 1 | 1 | SOIC 28-pin package | | Z8F042AHJ020EG | 4 KB | 1KB | 128 B | 23 | 20 | 2 | 8 | 1 | 1 | 1 | SSOP 28-pin package | | Z8F042APJ020EG | 4 KB | 1KB | 128 B | 23 | 20 | 2 | 8 | 1 | 1 | 1 | PDIP 28-pin package | Table 148. Z8 Encore! XP F082A Series Ordering Matrix | Part Number | Flash | RAM | NVDS | I/O Lines | Interrupts | 16-Bit Timers w/PWM | 10-Bit A/D Channels | UART with IrDA | Comparator | <b>Temperature Sensor</b> | Description | |---------------------|----------|----------|---------|-----------|------------|---------------------|---------------------|----------------|------------|---------------------------|---------------------| | Z8 Encore! XP F082A | A Series | with 2 | KB Flas | sh | | | | | | | | | Standard Temperatu | re: 0°C | to 70°C | | | | | | | | | | | Z8F021APB020SG | 2 KB | 512 B | 64 B | 6 | 13 | 2 | 0 | 1 | 1 | 0 | PDIP 8-pin package | | Z8F021AQB020SG | 2 KB | 512 B | 64 B | 6 | 13 | 2 | 0 | 1 | 1 | 0 | QFN 8-pin package | | Z8F021ASB020SG | 2 KB | 512 B | 64 B | 6 | 13 | 2 | 0 | 1 | 1 | 0 | SOIC 8-pin package | | Z8F021ASH020SG | 2 KB | 512 B | 64 B | 17 | 19 | 2 | 0 | 1 | 1 | 0 | SOIC 20-pin package | | Z8F021AHH020SG | 2 KB | 512 B | 64 B | 17 | 19 | 2 | 0 | 1 | 1 | 0 | SSOP 20-pin package | | Z8F021APH020SG | 2 KB | 512 B | 64 B | 17 | 19 | 2 | 0 | 1 | 1 | 0 | PDIP 20-pin package | | Z8F021ASJ020SG | 2 KB | 512 B | 64 B | 25 | 19 | 2 | 0 | 1 | 1 | 0 | SOIC 28-pin package | | Z8F021AHJ020SG | 2 KB | 512 B | 64 B | 25 | 19 | 2 | 0 | 1 | 1 | 0 | SSOP 28-pin package | | Z8F021APJ020SG | 2 KB | 512 B | 64 B | 25 | 19 | 2 | 0 | 1 | 1 | 0 | PDIP 28-pin package | | Extended Temperatu | re: –40° | °C to 10 | 5°C | | | | | | | | | | Z8F021APB020EG | 2 KB | 512 B | 64 B | 6 | 13 | 2 | 0 | 1 | 1 | 0 | PDIP 8-pin package | | Z8F021AQB020EG | 2 KB | 512 B | 64 B | 6 | 13 | 2 | 0 | 1 | 1 | 0 | QFN 8-pin package | | Z8F021ASB020EG | 2 KB | 512 B | 64 B | 6 | 13 | 2 | 0 | 1 | 1 | 0 | SOIC 8-pin package | | Z8F021ASH020EG | 2 KB | 512 B | 64 B | 17 | 19 | 2 | 0 | 1 | 1 | 0 | SOIC 20-pin package | | Z8F021AHH020EG | 2 KB | 512 B | 64 B | 17 | 19 | 2 | 0 | 1 | 1 | 0 | SSOP 20-pin package | | Z8F021APH020EG | 2 KB | 512 B | 64 B | 17 | 19 | 2 | 0 | 1 | 1 | 0 | PDIP 20-pin package | | Z8F021ASJ020EG | 2 KB | 512 B | 64 B | 25 | 19 | 2 | 0 | 1 | 1 | 0 | SOIC 28-pin package | | Z8F021AHJ020EG | 2 KB | 512 B | 64 B | 25 | 19 | 2 | 0 | 1 | 1 | 0 | SSOP 28-pin package | | Z8F021APJ020EG | 2 KB | 512 B | 64 B | 25 | 19 | 2 | 0 | 1 | 1 | 0 | PDIP 28-pin package | | Watchdog Timer 235, 238 | |-------------------------------------------| | enable interrupt 209 | | ER 206 | | extended addressing register 206 | | external pin reset 26 | | eZ8 CPU features 4 | | eZ8 CPU instruction classes 207 | | eZ8 CPU instruction notation 206 | | eZ8 CPU instruction set 204 | | eZ8 CPU instruction summary 212 | | | | | | F | | FCTL register 155, 161, 162 | | features, Z8 Encore! 1 | | first opcode map 224 | | FLAGS 207 | | flags register 207 | | flash | | controller 6 | | option bit address space 162 | | option bit configuration - reset 159 | | program memory address 0000H 162 | | program memory address 0001H 164 | | flash memory 146 | | arrangement 147 | | byte programming 151 | | code protection 149 | | configurations 146 | | control register definitions 153, 161 | | controller bypass 152 | | electrical characteristics and timing 234 | | flash control register 155, 161, 162 | | flash option bits 150 | | flash status register 155 | | flow chart 148 | | frequency high and low byte registers 157 | | mass erase 152 | | operation 147 | | operation timing 149 | | page erase 152 | | page select register 156, 157 | | FPS register 156, 157 | | FSTAT register 155 | | | | LEA 210 | b 206 | |-------------------------------------------------------|-------------------------------------| | load 210 | cc 206 | | load constant 209 | DA 206 | | load constant to/from program memory 210 | ER 206 | | load constant with auto-increment addresses 210 | IM 206 | | load effective address 210 | IR 206 | | load external data 210 | Ir 206 | | load external data to/from data memory and auto- | IRR 206 | | increment addresses 209 | Irr 206 | | load external to/from data memory and auto-incre- | p 206 | | ment addresses 210 | R 206 | | load using extended addressing 210 | r 206 | | logical AND 210 | RA 206 | | logical AND/extended addressing 210 | RR 206 | | logical exclusive OR 210 | rr 206 | | logical exclusive OR/extended addressing 210 | vector 207 | | logical instructions 210 | X 207 | | logical OR 210 | notational shorthand 206 | | | notational shorthand 200 | | logical OR/extended addressing 210 low power modes 32 | | | low power modes 32 | 0 | | | _ | | M | OCD | | ••• | architecture 180 | | master interrupt enable 57 | auto-baud detector/generator 183 | | memory | baud rate limits 184 | | data 17 | block diagram 180 | | program 15 | breakpoints 185 | | mode | commands 186 | | CAPTURE 87, 88 | control register 191 | | CAPTURE/COMPARE 88 | data format 183 | | CONTINUOUS 87 | DBG pin to RS-232 Interface 181 | | COUNTER 87 | debug mode 182 | | GATED 88 | debugger break 211 | | ONE-SHOT 87 | interface 181 | | PWM 87, 88 | serial errors 184 | | modes 87 | status register 192 | | MULT 208 | timing 242 | | multiply 208 | OCD commands | | multiprocessor mode, UART 105 | execute instruction (12H) 190 | | | read data memory (0DH) 190 | | NI. | read OCD control register (05H) 188 | | N | read OCD revision (00H) 187 | | NOP (no operation) 209 | read OCD status register (02H) 187 | | notation | read program counter (07H) 188 | | | |